CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes | Friends
edm::Ptr< T > Class Template Reference

#include <DataFormats/Common/interface/Ptr.h>

Public Types

typedef unsigned long key_type
 
typedef T value_type
 

Public Member Functions

T const * get () const
 Returns C++ pointer to the item. More...
 
bool hasProductCache () const
 
ProductID id () const
 Accessor for product ID. More...
 
bool isAvailable () const
 
bool isNonnull () const
 Checks for non-null. More...
 
bool isNull () const
 Checks for null. More...
 
bool isTransient () const
 Checks if this Ptr is transient (i.e. not persistable). More...
 
key_type key () const
 
bool operator! () const
 Checks for null. More...
 
T const & operator* () const
 Dereference operator. More...
 
T const * operator-> () const
 Member dereference operator. More...
 
void const * product () const
 
EDProductGetter const * productGetter () const
 Accessor for product getter. More...
 
template<typename C >
 Ptr (Handle< C > const &handle, key_type itemKey, bool=true)
 
template<typename C >
 Ptr (OrphanHandle< C > const &handle, key_type itemKey, bool=true)
 
template<typename C >
 Ptr (C const *iProduct, key_type iItemKey, bool=true)
 
 Ptr (T const *item, key_type iItemKey)
 
template<typename C >
 Ptr (TestHandle< C > const &handle, key_type itemKey, bool=true)
 
 Ptr (ProductID const &productID, key_type itemKey, EDProductGetter const *prodGetter)
 
 Ptr (ProductID const &productID, T const *item, key_type item_key)
 
 Ptr (ProductID const &productID, T const *item, key_type item_key, bool transient)
 
 Ptr (ProductID const &iId)
 
 Ptr ()
 
template<typename U >
 Ptr (Ptr< U > const &iOther, std::enable_if_t< std::is_base_of< T, U >::value > *=nullptr)
 
template<typename U >
 Ptr (Ptr< U > const &iOther, std::enable_if_t< std::is_base_of< U, T >::value > *=nullptr)
 
RefCore const & refCore () const
 
 ~Ptr ()
 Destructor. More...
 

Static Public Member Functions

static short Class_Version ()
 

Private Member Functions

void getData_ (bool throwIfNotFound=true) const
 
template<typename C >
T const * getItem_ (C const *product, key_type iKey)
 

Private Attributes

RefCore core_
 
key_type key_
 

Friends

class PtrVectorBase
 

Detailed Description

template<typename T>
class edm::Ptr< T >

Description: Persistent 'pointer' to an item in a collection where the collection is in the edm::Event

Usage: <usage>

Definition at line 30 of file AssociationVector.h.

Member Typedef Documentation

template<typename T>
typedef unsigned long edm::Ptr< T >::key_type

Definition at line 44 of file Ptr.h.

template<typename T>
typedef T edm::Ptr< T >::value_type

Definition at line 45 of file Ptr.h.

Constructor & Destructor Documentation

template<typename T>
template<typename C >
edm::Ptr< T >::Ptr ( Handle< C > const &  handle,
key_type  itemKey,
bool  = true 
)
inline

Definition at line 49 of file Ptr.h.

49  :
50  core_(handle.id(), getItem_(handle.product(), itemKey), nullptr, false), key_(itemKey) {}
T const * getItem_(C const *product, key_type iKey)
Definition: Ptr.h:229
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
template<typename C >
edm::Ptr< T >::Ptr ( OrphanHandle< C > const &  handle,
key_type  itemKey,
bool  = true 
)
inline

Definition at line 54 of file Ptr.h.

54  :
55  core_(handle.id(), getItem_(handle.product(), itemKey), nullptr, false), key_(itemKey) {}
T const * getItem_(C const *product, key_type iKey)
Definition: Ptr.h:229
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
template<typename C >
edm::Ptr< T >::Ptr ( C const *  iProduct,
key_type  iItemKey,
bool  = true 
)
inline

Definition at line 70 of file Ptr.h.

70  :
71  core_(ProductID(), iProduct != nullptr ? getItem_(iProduct,iItemKey) : nullptr, nullptr, true),
72  key_(iProduct != nullptr ? iItemKey : key_traits<key_type>::value) {}
static const key_type value
Definition: traits.h:36
T const * getItem_(C const *product, key_type iKey)
Definition: Ptr.h:229
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
edm::Ptr< T >::Ptr ( T const *  item,
key_type  iItemKey 
)
inline

Definition at line 74 of file Ptr.h.

74  :
75  core_(ProductID(), item, nullptr, true),
76  key_(item != nullptr ? iItemKey : key_traits<key_type>::value) {}
static const key_type value
Definition: traits.h:36
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
template<typename C >
edm::Ptr< T >::Ptr ( TestHandle< C > const &  handle,
key_type  itemKey,
bool  = true 
)
inline

Definition at line 82 of file Ptr.h.

82  :
83  core_(handle.id(), getItem_(handle.product(), itemKey), 0, true), key_(itemKey) {}
T const * getItem_(C const *product, key_type iKey)
Definition: Ptr.h:229
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
edm::Ptr< T >::Ptr ( ProductID const &  productID,
key_type  itemKey,
EDProductGetter const *  prodGetter 
)
inline

Constructor for those users who do not have a product handle, but have a pointer to a product getter (such as the EventPrincipal). prodGetter will ususally be a pointer to the event principal.

Definition at line 88 of file Ptr.h.

88  :
89  core_(productID, nullptr, mustBeNonZero(prodGetter, "Ptr", productID), false), key_(itemKey) {
90  }
EDProductGetter const * mustBeNonZero(EDProductGetter const *prodGetter, std::string refType, ProductID const &productID)
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
edm::Ptr< T >::Ptr ( ProductID const &  productID,
T const *  item,
key_type  item_key 
)
inline

Constructor for use in the various X::fillView(...) functions or for extracting a persistent Ptr from a PtrVector. It is an error (not diagnosable at compile- or run-time) to call this constructor with a pointer to a T unless the pointed-to T object is already in a collection of type C stored in the Event. The given ProductID must be the id of the collection in the Event.

Definition at line 99 of file Ptr.h.

99  :
100  core_(productID, item, nullptr, false),
101  key_(item_key) {
102  }
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
edm::Ptr< T >::Ptr ( ProductID const &  productID,
T const *  item,
key_type  item_key,
bool  transient 
)
inline

Definition at line 104 of file Ptr.h.

104  :
105  core_(productID, item, nullptr, transient),
106  key_(item_key) {
107  }
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
edm::Ptr< T >::Ptr ( ProductID const &  iId)
inlineexplicit

Constructor that creates an invalid ("null") Ptr that is associated with a given product (denoted by that product's ProductID).

Definition at line 113 of file Ptr.h.

113  :
114  core_(iId, nullptr, nullptr, false),
116  { }
static const key_type value
Definition: traits.h:36
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
edm::Ptr< T >::Ptr ( )
inline

Definition at line 118 of file Ptr.h.

118  :
119  core_(),
121  {}
static const key_type value
Definition: traits.h:36
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
template<typename T>
template<typename U >
edm::Ptr< T >::Ptr ( Ptr< U > const &  iOther,
std::enable_if_t< std::is_base_of< T, U >::value > *  = nullptr 
)
inline

Definition at line 124 of file Ptr.h.

124  :
125  core_(iOther.id(),
126  (iOther.hasProductCache() ? static_cast<T const*>(iOther.get()): static_cast<T const*>(nullptr)),
127  iOther.productGetter(),
128  iOther.isTransient()),
129  key_(iOther.key()) {
130  //make sure a race condition didn't happen where between the call to hasProductCache() and
131  // productGetter() the object was gotten
132  if(iOther.hasProductCache() and not hasProductCache()) {
133  core_.setProductPtr(static_cast<T const*>(iOther.get()) );
134  }
135  }
void setProductPtr(void const *prodPtr) const
Definition: RefCore.h:58
key_type key_
Definition: Ptr.h:224
bool hasProductCache() const
Definition: Ptr.h:187
RefCore core_
Definition: Ptr.h:223
long double T
template<typename T>
template<typename U >
edm::Ptr< T >::Ptr ( Ptr< U > const &  iOther,
std::enable_if_t< std::is_base_of< U, T >::value > *  = nullptr 
)
inlineexplicit

Definition at line 139 of file Ptr.h.

139  :
140  core_(iOther.id(),
141  dynamic_cast<T const*>(iOther.get()),
142  nullptr,
143  iOther.isTransient()),
144  key_(iOther.key()) {
145  }
key_type key_
Definition: Ptr.h:224
RefCore core_
Definition: Ptr.h:223
long double T
template<typename T>
edm::Ptr< T >::~Ptr ( )
inline

Destructor.

Definition at line 148 of file Ptr.h.

148 {}

Member Function Documentation

template<typename T>
static short edm::Ptr< T >::Class_Version ( )
inlinestatic

Definition at line 195 of file Ptr.h.

197 :
198 
template<typename T>
T const* edm::Ptr< T >::get ( ) const
inline

Returns C++ pointer to the item.

Definition at line 159 of file Ptr.h.

Referenced by Options.Options::__getitem__(), betterConfigParser.BetterConfigParser::__updateDict(), TransientTrackBuilder::build(), PFRecoTauAlgorithm::buildPFTau(), PFEGammaAlgo::buildRefinedSuperCluster(), PFECALSuperClusterAlgo::buildSuperCluster(), HPSPFRecoTauAlgorithm::buildThreeProngs(), util.rrapi.RRApi::columns(), rrapi.RRApi::columns(), PileupJetIdAlgo::computeIdVariables(), util.rrapi.RRApi::count(), rrapi.RRApi::count(), DeepTauId::createHadronsBlockInputs(), DeepTauId::createInputsV1(), DeepTauId::createTauBlockInputs(), util.rrapi.RRApi::data(), rrapi.RRApi::data(), edm::FwdPtr< T >::get(), pat::EventHypothesis::getAs(), reco::CaloJet::getCaloConstituent(), betterConfigParser.BetterConfigParser::getCompares(), ECFAdder::getECF(), MultipleAlgoIterator::getEt(), ReflectedIterator::getEt(), ParametrizedSubtractor::getEt(), MultipleAlgoIterator::getEta(), ReflectedIterator::getEta(), ParametrizedSubtractor::getEta(), betterConfigParser.BetterConfigParser::getGeneral(), reco::PFJet::getPFConstituent(), betterConfigParser.BetterConfigParser::getResultingSection(), reco::tau::getTrackFromChargedHadron(), PileUpSubtractor::ieta(), cms::SubEventGenJetProducer::inputTowers(), PileUpSubtractor::iphi(), TTClusterAssociationMap< T >::isCombinatoric(), TTClusterAssociationMap< T >::isGenuine(), MuonPFIsolationWithConeVeto::isInIsolationCone(), ElectronPFIsolationWithConeVeto::isInIsolationCone(), PhotonPFIsolationWithConeVeto::isInIsolationCone(), ElectronPFIsolationWithMapBasedVeto::isInIsolationCone(), PhotonPFIsolationWithMapBasedVeto::isInIsolationCone(), TTClusterAssociationMap< T >::isUnknown(), reco::tau::lead_track_chi2(), pat::MET::MET(), AntiElectronIDMVA6::MVAValue(), GsfEleCalPFClusterIsoCut::operator()(), AntiElectronDeadECAL::operator()(), pat::PATObject< ObjectType >::originalObject(), reco::PFClusterJet::pfCluster(), reco::RecoTauPiZero::print(), TTTrackAssociator< T >::produce(), EcalDigiSelector::produce(), SoftPFMuonTagInfoProducer::produce(), NoPileUpPFMEtDataProducer::produce(), pat::PATTauProducer::produce(), rrapi.RRApi::report(), util.rrapi.RRApi::report(), util.rrapi.RRApi::reports(), rrapi.RRApi::reports(), BoostedDoubleSVProducer::setTracksPV(), util.rrapi.RRApi::tables(), rrapi.RRApi::tables(), rrapi.RRApi::tags(), util.rrapi.RRApi::tags(), util.rrapi.RRApi::templates(), rrapi.RRApi::templates(), toTrackRef(), reco::TrackJet::track(), GsfEleCalPFClusterIsoCut::value(), util.rrapi.RRApi::workspaces(), and rrapi.RRApi::workspaces().

159  {
160  return isNull() ? nullptr : this->operator->();
161  }
T const * operator->() const
Member dereference operator.
Definition: Ptr.h:250
bool isNull() const
Checks for null.
Definition: Ptr.h:164
template<typename T>
void edm::Ptr< T >::getData_ ( bool  throwIfNotFound = true) const
inlineprivate

Definition at line 202 of file Ptr.h.

Referenced by edm::Ptr< T >::isAvailable(), edm::Ptr< T >::operator*(), and edm::Ptr< T >::operator->().

202  {
203  EDProductGetter const* getter = productGetter();
204  if(getter != nullptr) {
205  WrapperBase const* prod = getter->getIt(core_.id());
206  unsigned int iKey = key_;
207  if(prod == nullptr) {
208  prod = getter->getThinnedProduct(core_.id(), iKey);
209  if(prod == nullptr) {
210  if(throwIfNotFound) {
212  } else {
213  return;
214  }
215  }
216  }
217  void const* ad = nullptr;
218  prod->setPtr(typeid(T), iKey, ad);
219  core_.setProductPtr(ad);
220  }
221  }
void setProductPtr(void const *prodPtr) const
Definition: RefCore.h:58
EDProductGetter const * productGetter() const
Accessor for product getter.
Definition: Ptr.h:183
key_type key_
Definition: Ptr.h:224
void productNotFoundException(std::type_info const &type) const
Definition: RefCore.cc:141
RefCore core_
Definition: Ptr.h:223
ProductID id() const
Definition: RefCore.h:49
long double T
template<typename T >
template<typename C >
T const * edm::Ptr< T >::getItem_ ( C const *  product,
key_type  iKey 
)
private

Definition at line 229 of file Ptr.h.

References edm::detail::GetProduct< COLLECTION >::address().

229  {
230  assert (iProduct != nullptr);
231  typename C::const_iterator it = iProduct->begin();
232  std::advance(it,iKey);
233  T const* address = detail::GetProduct<C>::address(it);
234  return address;
235  }
static const element_type * address(const iter &i)
Definition: GetProduct.h:33
long double T
template<typename T>
bool edm::Ptr< T >::hasProductCache ( ) const
inline

Definition at line 187 of file Ptr.h.

Referenced by edm::FwdPtr< T >::hasProductCache(), edm::Ptr< T >::isAvailable(), edm::Ptr< reco::Muon >::Ptr(), and edm::PtrVector< reco::reco::PFCluster >::push_back().

187 { return nullptr != core_.productPtr(); }
void const * productPtr() const
Definition: RefCore.h:52
RefCore core_
Definition: Ptr.h:223
template<typename T>
ProductID edm::Ptr< T >::id ( ) const
inline

Accessor for product ID.

Definition at line 180 of file Ptr.h.

Referenced by reco::tau::RecoTauPiZeroStripPlugin2::addCandsToStrip(), reco::tau::RecoTauPiZeroStripPlugin3::addCandsToStrip(), MuonTrajectoryCleaner::clean(), pat::PATElectronProducer::fillElectron2(), edm::PtrVector< T >::fillView(), reco::PFCandidate::flag(), reco::CaloJet::getCaloConstituent(), reco::PFJet::getPFConstituent(), edm::FwdPtr< T >::id(), PhoFull5x5SigmaIEtaIEtaValueMapCut::operator()(), PhoMVACut::operator()(), GsfEleMVACut::operator()(), PhoAnyPFIsoWithEAAndExpoScalingCut::operator()(), PhoAnyPFIsoWithEAAndExpoScalingEBCut::operator()(), PhoAnyPFIsoWithEAAndQuadScalingCut::operator()(), PhoAnyPFIsoWithEACut::operator()(), GsfEleDeltaBetaIsoCut::operator()(), reco::operator<<(), edm::AssociationVector< KeyRefProd, CVal, KeyRef, SizeType, KeyReferenceHelper >::operator[](), ClusterClusterMapping::overlap(), pat::helper::RefHelper< T >::parentOrNull(), reco::PFRecoTauChargedHadron::print(), PFMuonUntagger::produce(), pat::PATTrackAndVertexUnpacker::produce(), pat::PATPackedCandidateProducer::produce(), pf2pat::TopProjectorAlgo< Top, Bottom >::ptrToAncestor(), pat::helper::RefHelper< T >::recursiveLookup(), reco::tau::RecoTauConstructor::reserveTauChargedHadron(), ConvertedPhotonProducer::solveAmbiguity(), metsig::SignPFSpecificAlgo::useOriginalPtrs(), PhoFull5x5SigmaIEtaIEtaValueMapCut::value(), PhoMVACut::value(), PhoAnyPFIsoWithEAAndExpoScalingEBCut::value(), PhoAnyPFIsoWithEAAndQuadScalingCut::value(), PhoAnyPFIsoWithEACut::value(), PhoAnyPFIsoWithEAAndExpoScalingCut::value(), GsfEleDeltaBetaIsoCut::value(), GsfEleMVACut::value(), and NoPileUpPFMEtDataProducer::~NoPileUpPFMEtDataProducer().

180 {return core_.id();}
RefCore core_
Definition: Ptr.h:223
ProductID id() const
Definition: RefCore.h:49
template<typename T >
bool edm::Ptr< T >::isAvailable ( ) const
inline
template<typename T>
bool edm::Ptr< T >::isNonnull ( ) const
inline

Checks for non-null.

Definition at line 168 of file Ptr.h.

Referenced by reco::tau::RecoTauConstructor::addTauChargedHadron(), heppy::IsolationComputer::addVetos(), B2GDoubleLeptonHLTValidation::analyze(), B2GHadronicHLTValidation::analyze(), B2GSingleLeptonHLTValidation::analyze(), ZCounting::analyzeElectrons(), HPSPFRecoTauAlgorithm::applyElectronRejection(), HPSPFRecoTauAlgorithm::applyMuonRejection(), reco::tau::RecoTauVertexAssociator::associatedVertex(), PFRecoTauAlgorithm::buildPFTau(), reco::FlavorHistoryEvent::cache(), ConversionProducer::checkTrackPair(), MVAJetPuId::computeIdVariables(), reco::tau::RecoTauConstructor::convertToPtr(), EGEnergyCorrector::CorrectedEnergyWithError(), DeepTauId::createInputsV1(), PFRecoTauDiscriminationByNProngs::discriminate(), PFRecoTauDiscriminationAgainstElectronMVA6::discriminate(), reco::CaloJet::getCaloConstituent(), ECFAdder::getECF(), reco::PFJet::getPFConstituent(), NjettinessAdder::getTau(), reco::tau::getTrackFromChargedHadron(), reco::FlavorHistory::hasMatchedJet(), reco::PFTau::hasMuonReference(), reco::FlavorHistory::hasParton(), reco::FlavorHistory::hasProgenitor(), reco::FlavorHistory::hasSister(), reco::FlavorHistory::hasSisterJet(), edm::FwdPtr< T >::id(), pat::helper::RefHelper< T >::isAncestorOf(), MuonPFIsolationWithConeVeto::isInIsolationCone(), ElectronPFIsolationWithConeVeto::isInIsolationCone(), PhotonPFIsolationWithConeVeto::isInIsolationCone(), PhotonPFIsolationWithMapBasedVeto::isInIsolationCone(), edm::FwdPtr< T >::isNonnull(), edm::Ptr< reco::Muon >::isNull(), heppy::IsolationComputer::isoSumNeutralsWeighted(), heppy::IsolationComputer::isoSumRaw(), edm::FwdPtr< T >::key(), reco::tau::lead_track_chi2(), AntiElectronIDMVA5::MVAValue(), AntiElectronIDMVA6::MVAValue(), reco::PFCandidateFwdPtrFactory::operator()(), reco::tau::RecoTauElectronRejectionPlugin::operator()(), reco::tau::RecoTauImpactParameterSignificancePlugin::operator()(), reco::tau::RecoTauBuilderConePlugin::operator()(), AntiElectronDeadECAL::operator()(), TopProjectorFwdPtrOverlap< Top, Bottom >::operator()(), reco::PFCandidate::overlap(), pat::helper::RefHelper< T >::parentOrSelf(), reco::PFClusterJet::pfCluster(), reco::PFRecoTauChargedHadron::print(), PFTauElecRejectionBenchmark::process(), PseudoTopProducer::produce(), LowPtGsfElectronSCProducer::produce(), L1THLTTauMatching::produce(), PFMuonUntagger::produce(), L1HLTTauMatching::produce(), PATMuonMerger::produce(), pat::PATJetUpdater::produce(), pat::PATTauProducer::produce(), pat::PATJetProducer::produce(), PFTauPrimaryVertexProducerBase::produce(), DeepDoubleXTagInfoProducer::produce(), pat::PATElectronProducer::produce(), DeepFlavourTagInfoProducer::produce(), JetFlavourClustering::produce(), pat::helper::RefHelper< T >::recursiveLookup(), edm::FwdPtr< T >::refCore(), reco::tau::setChargedHadronP4(), reco::PFTau::setisolationGammaCands(), reco::tau::RecoTauBuilderConePlugin::setTauQuantities(), and reco::TrackJet::track().

static const key_type value
Definition: traits.h:36
key_type key_
Definition: Ptr.h:224
template<typename T>
bool edm::Ptr< T >::isNull ( ) const
inline
template<typename T>
bool edm::Ptr< T >::isTransient ( ) const
inline

Checks if this Ptr is transient (i.e. not persistable).

Definition at line 177 of file Ptr.h.

Referenced by edm::FwdPtr< T >::isTransient().

177 {return core_.isTransient();}
RefCore core_
Definition: Ptr.h:223
bool isTransient() const
Definition: RefCore.h:106
template<typename T>
key_type edm::Ptr< T >::key ( ) const
inline

Definition at line 185 of file Ptr.h.

Referenced by reco::tau::RecoTauPiZeroStripPlugin2::addCandsToStrip(), reco::tau::RecoTauPiZeroStripPlugin3::addCandsToStrip(), PFEGammaAlgo::attachPSClusters(), reco::tau::RecoTauConstructor::convertToPtr(), DeepBoostedJetTagInfoProducer::fillParticleFeatures(), edm::PtrVector< T >::fillView(), reco::PFCandidate::flag(), reco::CaloJet::getCaloConstituent(), reco::PFJet::getPFConstituent(), edm::FwdPtr< T >::key(), PhoFull5x5SigmaIEtaIEtaValueMapCut::operator()(), PhoMVACut::operator()(), GsfEleMVACut::operator()(), PhoAnyPFIsoWithEAAndExpoScalingCut::operator()(), PhoAnyPFIsoWithEAAndExpoScalingEBCut::operator()(), PhoAnyPFIsoWithEAAndQuadScalingCut::operator()(), PhoAnyPFIsoWithEACut::operator()(), GsfEleDeltaBetaIsoCut::operator()(), TopProjectorFwdPtrOverlap< Top, Bottom >::operator()(), reco::FlavorHistory::operator<(), reco::operator<<(), operator<<(), reco::FlavorHistory::operator==(), reco::FlavorHistory::operator>(), edm::AssociationVector< KeyRefProd, CVal, KeyRef, SizeType, KeyReferenceHelper >::operator[](), ClusterClusterMapping::overlap(), reco::PFRecoTauChargedHadron::print(), PFMuonUntagger::produce(), pat::PATTrackAndVertexUnpacker::produce(), pat::PATPackedCandidateProducer::produce(), NoPileUpPFMEtDataProducer::produce(), TriggerMatcherToHLTDebug::produce(), edm::PtrVector< reco::reco::PFCluster >::push_back(), reco::tau::RecoTauConstructor::reserveTauChargedHadron(), ConvertedPhotonProducer::solveAmbiguity(), PhoFull5x5SigmaIEtaIEtaValueMapCut::value(), PhoMVACut::value(), PhoAnyPFIsoWithEAAndExpoScalingEBCut::value(), PhoAnyPFIsoWithEAAndQuadScalingCut::value(), PhoAnyPFIsoWithEAAndExpoScalingCut::value(), PhoAnyPFIsoWithEACut::value(), GsfEleDeltaBetaIsoCut::value(), GsfEleMVACut::value(), and NoPileUpPFMEtDataProducer::~NoPileUpPFMEtDataProducer().

185 {return key_;}
key_type key_
Definition: Ptr.h:224
template<typename T>
bool edm::Ptr< T >::operator! ( ) const
inline

Checks for null.

Definition at line 170 of file Ptr.h.

170 {return isNull();}
bool isNull() const
Checks for null.
Definition: Ptr.h:164
template<typename T >
T const & edm::Ptr< T >::operator* ( ) const
inline

Dereference operator.

Definition at line 241 of file Ptr.h.

References edm::Ptr< T >::core_, edm::Ptr< T >::getData_(), and edm::RefCore::productPtr().

Referenced by edm::Ptr< reco::Muon >::~Ptr().

241  {
242  getData_();
243  return *reinterpret_cast<T const*>(core_.productPtr());
244  }
void getData_(bool throwIfNotFound=true) const
Definition: Ptr.h:202
void const * productPtr() const
Definition: RefCore.h:52
RefCore core_
Definition: Ptr.h:223
long double T
template<typename T >
T const * edm::Ptr< T >::operator-> ( ) const
inline

Member dereference operator.

Definition at line 250 of file Ptr.h.

References edm::Ptr< T >::core_, edm::Ptr< T >::getData_(), and edm::RefCore::productPtr().

Referenced by edm::Ptr< reco::Muon >::get(), and edm::Ptr< reco::Muon >::~Ptr().

250  {
251  getData_();
252  return reinterpret_cast<T const*>(core_.productPtr());
253  }
void getData_(bool throwIfNotFound=true) const
Definition: Ptr.h:202
void const * productPtr() const
Definition: RefCore.h:52
RefCore core_
Definition: Ptr.h:223
long double T
template<typename T>
void const* edm::Ptr< T >::product ( ) const
inline

Definition at line 192 of file Ptr.h.

192 {return nullptr;}
template<typename T>
EDProductGetter const* edm::Ptr< T >::productGetter ( ) const
inline

Accessor for product getter.

Definition at line 183 of file Ptr.h.

Referenced by edm::Ptr< reco::Muon >::getData_(), and edm::FwdPtr< T >::productGetter().

183 {return core_.productGetter();}
RefCore core_
Definition: Ptr.h:223
EDProductGetter const * productGetter() const
Definition: RefCore.h:84
template<typename T>
RefCore const& edm::Ptr< T >::refCore ( ) const
inline

Friends And Related Function Documentation

template<typename T>
friend class PtrVectorBase
friend

Definition at line 41 of file Ptr.h.

Member Data Documentation

template<typename T>
RefCore edm::Ptr< T >::core_
private
template<typename T>
key_type edm::Ptr< T >::key_
private