1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
#ifndef DataFormats_Provenance_EventEntryInfo_h
#define DataFormats_Provenance_EventEntryInfo_h
/*----------------------------------------------------------------------
EventEntryInfo: The event dependent portion of the description of a product
and how it came into existence, plus the product identifier.
----------------------------------------------------------------------*/
#include <iosfwd>
#include <vector>
#include "DataFormats/Provenance/interface/BranchID.h"
#include "DataFormats/Provenance/interface/EntryDescriptionID.h"
#include "DataFormats/Provenance/interface/ProductID.h"
/*
EventEntryInfo
*/
namespace edm {
class EventEntryDescription;
class EventEntryInfo {
public:
EventEntryInfo();
~EventEntryInfo();
void write(std::ostream& os) const;
BranchID const& branchID() const { return branchID_; }
ProductID const& productID() const { return productID_; }
EntryDescriptionID const& entryDescriptionID() const { return entryDescriptionID_; }
private:
BranchID branchID_;
ProductID productID_;
EntryDescriptionID entryDescriptionID_;
};
inline bool operator<(EventEntryInfo const& a, EventEntryInfo const& b) { return a.branchID() < b.branchID(); }
inline std::ostream& operator<<(std::ostream& os, EventEntryInfo const& p) {
p.write(os);
return os;
}
// Only the 'salient attributes' are testing in equality comparison.
bool operator==(EventEntryInfo const& a, EventEntryInfo const& b);
inline bool operator!=(EventEntryInfo const& a, EventEntryInfo const& b) { return !(a == b); }
typedef std::vector<EventEntryInfo> EventEntryInfoVector;
} // namespace edm
#endif
|