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 53 54
#include "DataFormats/Provenance/interface/ProductProvenance.h"
#include "DataFormats/Provenance/interface/ParentageRegistry.h"

#include <cassert>
#include <ostream>

/*----------------------------------------------------------------------

----------------------------------------------------------------------*/

namespace {
  edm::Parentage const s_emptyParentage;
}
namespace edm {
  ProductProvenance::ProductProvenance() : branchID_(), parentageID_() {}

  ProductProvenance::ProductProvenance(BranchID bid) : branchID_(bid), parentageID_() {}

  ProductProvenance::ProductProvenance(BranchID bid, ParentageID edid) : branchID_(bid), parentageID_(edid) {}

  ProductProvenance::ProductProvenance(BranchID bid, std::vector<BranchID> const& parents)
      : branchID_(bid), parentageID_() {
    Parentage p;
    p.setParents(parents);
    parentageID_ = p.id();
    ParentageRegistry::instance()->insertMapped(p);
  }

  ProductProvenance::ProductProvenance(BranchID bid, std::vector<BranchID>&& parents) : branchID_(bid), parentageID_() {
    Parentage p;
    p.setParents(std::move(parents));
    parentageID_ = p.id();
    ParentageRegistry::instance()->insertMapped(std::move(p));
  }

  ProductProvenance ProductProvenance::makeProductProvenance() const { return *this; }

  Parentage const& ProductProvenance::parentage() const {
    auto p = ParentageRegistry::instance()->getMapped(parentageID_);
    if (p) {
      return *p;
    }
    return s_emptyParentage;
  }

  void ProductProvenance::write(std::ostream& os) const {
    os << "branch ID = " << branchID() << '\n';
    os << "entry description ID = " << parentageID() << '\n';
  }

  bool operator==(ProductProvenance const& a, ProductProvenance const& b) {
    return a.branchID() == b.branchID() && a.parentageID() == b.parentageID();
  }
}  // namespace edm