EventEntryInfo

Macros

Line Code
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