CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
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<class 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 31 of file AssociationVector.h.

Member Typedef Documentation

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

Definition at line 44 of file Ptr.h.

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

Definition at line 45 of file Ptr.h.

Constructor & Destructor Documentation

template<class 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.

50  : core_(handle.id(), getItem_(handle.product(), itemKey), nullptr, false), key_(itemKey) {}
T const * getItem_(C const *product, key_type iKey)
Definition: Ptr.h:207
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class 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.

55  : core_(handle.id(), getItem_(handle.product(), itemKey), nullptr, false), key_(itemKey) {}
T const * getItem_(C const *product, key_type iKey)
Definition: Ptr.h:207
key_type key_
Definition: Ptr.h:202
tuple handle
Definition: patZpeak.py:23
RefCore core_
Definition: Ptr.h:201
template<class 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.

71  : core_(ProductID(), iProduct != nullptr ? getItem_(iProduct, iItemKey) : nullptr, nullptr, true),
72  key_(iProduct != nullptr ? iItemKey : key_traits<key_type>::value) {}
T const * getItem_(C const *product, key_type iKey)
Definition: Ptr.h:207
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class T>
edm::Ptr< T >::Ptr ( T const *  item,
key_type  iItemKey 
)
inline

Definition at line 74 of file Ptr.h.

75  : core_(ProductID(), item, nullptr, true), key_(item != nullptr ? iItemKey : key_traits<key_type>::value) {}
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class T>
template<typename C >
edm::Ptr< T >::Ptr ( TestHandle< C > const &  handle,
key_type  itemKey,
bool  = true 
)
inline

Definition at line 81 of file Ptr.h.

82  : core_(handle.id(), getItem_(handle.product(), itemKey), nullptr, true), key_(itemKey) {}
T const * getItem_(C const *product, key_type iKey)
Definition: Ptr.h:207
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class 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 87 of file Ptr.h.

88  : core_(productID, nullptr, mustBeNonZero(prodGetter, "Ptr", productID), false), key_(itemKey) {}
EDProductGetter const * mustBeNonZero(EDProductGetter const *prodGetter, std::string refType, ProductID const &productID)
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class 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 97 of file Ptr.h.

98  : core_(productID, item, nullptr, false), key_(item_key) {}
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class T>
edm::Ptr< T >::Ptr ( ProductID const &  productID,
T const *  item,
key_type  item_key,
bool  transient 
)
inline

Definition at line 100 of file Ptr.h.

101  : core_(productID, item, nullptr, transient), key_(item_key) {}
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class 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 107 of file Ptr.h.

107 : core_(iId, nullptr, nullptr, false), key_(key_traits<key_type>::value) {}
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class T>
edm::Ptr< T >::Ptr ( )
inline

Definition at line 109 of file Ptr.h.

key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
template<class 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 112 of file Ptr.h.

113  : core_(iOther.id(),
114  (iOther.hasProductCache() ? static_cast<T const*>(iOther.get()) : static_cast<T const*>(nullptr)),
115  iOther.productGetter(),
116  iOther.isTransient()),
117  key_(iOther.key()) {
118  //make sure a race condition didn't happen where between the call to hasProductCache() and
119  // productGetter() the object was gotten
120  if (iOther.hasProductCache() and not hasProductCache()) {
121  core_.setProductPtr(static_cast<T const*>(iOther.get()));
122  }
123  }
void setProductPtr(void const *prodPtr) const
Definition: RefCore.h:57
key_type key_
Definition: Ptr.h:202
bool hasProductCache() const
Definition: Ptr.h:165
RefCore core_
Definition: Ptr.h:201
long double T
template<class 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 126 of file Ptr.h.

127  : core_(iOther.id(), dynamic_cast<T const*>(iOther.get()), nullptr, iOther.isTransient()), key_(iOther.key()) {}
key_type key_
Definition: Ptr.h:202
RefCore core_
Definition: Ptr.h:201
long double T
template<class T>
edm::Ptr< T >::~Ptr ( )
inline

Destructor.

Definition at line 130 of file Ptr.h.

130 {}

Member Function Documentation

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

Definition at line 173 of file Ptr.h.

175 :
176  template <typename C>
template<class T>
T const* edm::Ptr< T >::get ( ) const
inline

Returns C++ pointer to the item.

Definition at line 139 of file Ptr.h.

Referenced by Options.Options::__getitem__(), betterConfigParser.BetterConfigParser::__updateDict(), submitPVValidationJobs.BetterConfigParser::__updateDict(), TransientTrackBuilder::build(), PFEGammaAlgo::buildRefinedSuperCluster(), PFECALSuperClusterAlgo::buildSuperCluster(), util.rrapi.RRApi::columns(), rrapi.RRApi::columns(), PileupJetIdAlgo::computeIdVariables(), util.rrapi.RRApi::count(), rrapi.RRApi::count(), util.rrapi.RRApi::data(), rrapi.RRApi::data(), TauDiscriminationAgainstElectronMVA6< TauType, TauDiscriminator, ElectronType >::discriminate(), l1tVertexFinder::TP::fillUse(), l1tVertexFinder::TP::fillUseForEff(), l1tVertexFinder::TP::fillUseForVertexReco(), 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(), submitPVValidationJobs.BetterConfigParser::getResultingSection(), NjettinessAdder::getTau(), AntiElectronIDMVA6< TauType, ElectronType >::getTauVarsTypeSpecific(), 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(), GsfEleCalPFClusterIsoCut::operator()(), AntiElectronDeadECAL::operator()(), reco::PFClusterJet::pfCluster(), reco::RecoTauPiZero::print(), EcalDigiSelector::produce(), NoPileUpPFMEtDataProducer::produce(), pat::PATTauProducer::produce(), SoftPFMuonTagInfoProducer::produce(), rrapi.RRApi::report(), util.rrapi.RRApi::report(), rrapi.RRApi::reports(), util.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(), rrapi.RRApi::workspaces(), and util.rrapi.RRApi::workspaces().

139 { return isNull() ? nullptr : this->operator->(); }
T const * operator->() const
Member dereference operator.
Definition: Ptr.h:224
bool isNull() const
Checks for null.
Definition: Ptr.h:142
template<class T>
void edm::Ptr< T >::getData_ ( bool  throwIfNotFound = true) const
inlineprivate

Definition at line 179 of file Ptr.h.

179  {
180  EDProductGetter const* getter = productGetter();
181  if (getter != nullptr) {
182  WrapperBase const* prod = getter->getIt(core_.id());
183  unsigned int iKey = key_;
184  if (prod == nullptr) {
185  auto optionalProd = getter->getThinnedProduct(core_.id(), key_);
186  if (not optionalProd.has_value()) {
187  if (throwIfNotFound) {
189  } else {
190  return;
191  }
192  }
193  std::tie(prod, iKey) = *optionalProd;
194  }
195  void const* ad = nullptr;
196  prod->setPtr(typeid(T), iKey, ad);
197  core_.setProductPtr(ad);
198  }
199  }
void setProductPtr(void const *prodPtr) const
Definition: RefCore.h:57
EDProductGetter const * productGetter() const
Accessor for product getter.
Definition: Ptr.h:161
key_type key_
Definition: Ptr.h:202
void productNotFoundException(std::type_info const &type) const
Definition: RefCore.cc:125
RefCore core_
Definition: Ptr.h:201
ProductID id() const
Definition: RefCore.h:48
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 207 of file Ptr.h.

References edm::detail::GetProduct< COLLECTION >::address(), and cms::cuda::assert().

207  {
208  assert(iProduct != nullptr);
209  typename C::const_iterator it = iProduct->begin();
210  std::advance(it, iKey);
211  T const* address = detail::GetProduct<C>::address(it);
212  return address;
213  }
static const element_type * address(const iter &i)
Definition: GetProduct.h:36
assert(be >=bs)
long double T
template<class T>
bool edm::Ptr< T >::hasProductCache ( ) const
inline

Definition at line 165 of file Ptr.h.

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

165 { return nullptr != core_.productPtr(); }
void const * productPtr() const
Definition: RefCore.h:51
RefCore core_
Definition: Ptr.h:201
template<class T>
ProductID edm::Ptr< T >::id ( ) const
inline

Accessor for product ID.

Definition at line 158 of file Ptr.h.

Referenced by reco::tau::RecoTauPiZeroStripPlugin2::addCandsToStrip(), reco::tau::RecoTauPiZeroStripPlugin3::addCandsToStrip(), MuonTrajectoryCleaner::clean(), pat::PATElectronProducer::fillElectron2(), edm::PtrVector< T >::fillView(), reco::CaloJet::getCaloConstituent(), reco::PFJet::getPFConstituent(), edm::FwdPtr< T >::id(), PhoFull5x5SigmaIEtaIEtaValueMapCut::operator()(), PhoMVACut::operator()(), PhoAnyPFIsoWithEAAndExpoScalingCut::operator()(), PhoAnyPFIsoWithEAAndExpoScalingEBCut::operator()(), PhoAnyPFIsoWithEAAndQuadScalingCut::operator()(), PhoAnyPFIsoWithEACut::operator()(), GsfEleMVACut::operator()(), reco::operator<<(), edm::AssociationVector< KeyRefProd, CVal, KeyRef, SizeType, KeyReferenceHelper >::operator[](), ClusterClusterMapping::overlap(), reco::PFRecoTauChargedHadron::print(), PFMuonUntagger::produce(), pat::PATTrackAndVertexUnpacker::produce(), ShiftedParticleMETcorrInputProducer::produce(), ShiftedParticleProducer::produce(), pat::PATPackedCandidateProducer::produce(), metsig::SignPFSpecificAlgo::useOriginalPtrs(), PhoMVACut::value(), PhoFull5x5SigmaIEtaIEtaValueMapCut::value(), PhoAnyPFIsoWithEACut::value(), PhoAnyPFIsoWithEAAndExpoScalingCut::value(), PhoAnyPFIsoWithEAAndExpoScalingEBCut::value(), PhoAnyPFIsoWithEAAndQuadScalingCut::value(), and GsfEleMVACut::value().

158 { return core_.id(); }
RefCore core_
Definition: Ptr.h:201
ProductID id() const
Definition: RefCore.h:48
template<typename T >
bool edm::Ptr< T >::isAvailable ( ) const
inline
template<class T>
bool edm::Ptr< T >::isNonnull ( ) const
inline

Checks for non-null.

Definition at line 146 of file Ptr.h.

Referenced by reco::tau::RecoTauConstructor::addTauChargedHadron(), heppy::IsolationComputer::addVetos(), B2GDoubleLeptonHLTValidation::analyze(), B2GSingleLeptonHLTValidation::analyze(), B2GHadronicHLTValidation::analyze(), ZCounting::analyzeElectrons(), reco::tau::RecoTauVertexAssociator::associatedVertex(), reco::FlavorHistoryEvent::cache(), BoostedDoubleSVProducer::calcNsubjettiness(), ConversionProducer::checkTrackPair(), MVAJetPuId::computeIdVariables(), reco::tau::RecoTauConstructor::convertToPtr(), EGEnergyCorrector::CorrectedEnergyWithError(), ElectronIdentifier::dEtaInSeed(), PFRecoTauDiscriminationByNProngs::discriminate(), TauDiscriminationAgainstElectronMVA6< TauType, TauDiscriminator, ElectronType >::discriminate(), PFRecoTauDiscriminationAgainstMuon2Helper::eval(), reco::tau::fillIsoMVARun2Inputs(), reco::CaloJet::getCaloConstituent(), ECFAdder::getECF(), reco::PFJet::getPFConstituent(), NjettinessAdder::getTau(), AntiElectronIDMVA6< TauType, ElectronType >::getTauVarsTypeSpecific(), 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(), 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(), pat::Muon::numberOfSourceCandidatePtrs(), MuonMomQualityCut::operator()(), reco::PFCandidateFwdPtrFactory::operator()(), reco::tau::RecoTauElectronRejectionPlugin::operator()(), reco::tau::RecoTauImpactParameterSignificancePlugin::operator()(), reco::tau::PFRecoTauEnergyAlgorithmPlugin::operator()(), AntiElectronDeadECAL::operator()(), TopProjectorFwdPtrOverlap< Top, Bottom >::operator()(), reco::PFCandidate::overlap(), reco::PFClusterJet::pfCluster(), reco::PFRecoTauChargedHadron::print(), PFTauElecRejectionBenchmark::process(), PseudoTopProducer::produce(), L1THLTTauMatching::produce(), L1HLTTauMatching::produce(), reco::ParticleFlowForChargedMETProducer::produce(), PFMuonUntagger::produce(), PATMuonMerger::produce(), LowPtGsfElectronSCProducer::produce(), LowPtGsfElectronIDProducer::produce(), pat::PATJetUpdater::produce(), DeepDoubleXTagInfoProducer::produce(), PFTauPrimaryVertexProducerBase::produce(), pat::PATJetProducer::produce(), pat::PATTauProducer::produce(), pat::PATElectronProducer::produce(), DeepFlavourTagInfoProducer::produce(), JetFlavourClustering::produce(), edm::FwdPtr< T >::refCore(), reco::tau::setChargedHadronP4(), reco::tau::RecoTauBuilderConePlugin::setTauQuantities(), and reco::TrackJet::track().

146 { return key_traits<key_type>::value != key_; }
key_type key_
Definition: Ptr.h:202
template<class T>
bool edm::Ptr< T >::isNull ( ) const
inline
template<class T>
bool edm::Ptr< T >::isTransient ( ) const
inline

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

Definition at line 155 of file Ptr.h.

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

155 { return core_.isTransient(); }
RefCore core_
Definition: Ptr.h:201
bool isTransient() const
Definition: RefCore.h:105
template<class T>
key_type edm::Ptr< T >::key ( ) const
inline

Definition at line 163 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::CaloJet::getCaloConstituent(), reco::PFJet::getPFConstituent(), edm::FwdPtr< T >::key(), PhoFull5x5SigmaIEtaIEtaValueMapCut::operator()(), PhoMVACut::operator()(), GsfEleMVACut::operator()(), PhoAnyPFIsoWithEAAndExpoScalingCut::operator()(), PhoAnyPFIsoWithEAAndExpoScalingEBCut::operator()(), PhoAnyPFIsoWithEAAndQuadScalingCut::operator()(), PhoAnyPFIsoWithEACut::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::CaloCluster >::push_back(), PhoFull5x5SigmaIEtaIEtaValueMapCut::value(), PhoMVACut::value(), PhoAnyPFIsoWithEAAndQuadScalingCut::value(), PhoAnyPFIsoWithEACut::value(), PhoAnyPFIsoWithEAAndExpoScalingCut::value(), PhoAnyPFIsoWithEAAndExpoScalingEBCut::value(), and GsfEleMVACut::value().

163 { return key_; }
key_type key_
Definition: Ptr.h:202
template<class T>
bool edm::Ptr< T >::operator! ( ) const
inline

Checks for null.

Definition at line 148 of file Ptr.h.

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

Dereference operator.

Definition at line 217 of file Ptr.h.

References runTheMatrix::const.

217  {
218  getData_();
219  return *reinterpret_cast<T const*>(core_.productPtr());
220  }
void getData_(bool throwIfNotFound=true) const
Definition: Ptr.h:179
void const * productPtr() const
Definition: RefCore.h:51
RefCore core_
Definition: Ptr.h:201
long double T
template<typename T >
T const * edm::Ptr< T >::operator-> ( ) const
inline

Member dereference operator.

Definition at line 224 of file Ptr.h.

References runTheMatrix::const.

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

224  {
225  getData_();
226  return reinterpret_cast<T const*>(core_.productPtr());
227  }
void getData_(bool throwIfNotFound=true) const
Definition: Ptr.h:179
void const * productPtr() const
Definition: RefCore.h:51
RefCore core_
Definition: Ptr.h:201
long double T
template<class T>
void const* edm::Ptr< T >::product ( ) const
inline

Definition at line 170 of file Ptr.h.

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

Accessor for product getter.

Definition at line 161 of file Ptr.h.

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

161 { return core_.productGetter(); }
RefCore core_
Definition: Ptr.h:201
EDProductGetter const * productGetter() const
Definition: RefCore.h:81
template<class T>
RefCore const& edm::Ptr< T >::refCore ( ) const
inline

Friends And Related Function Documentation

template<class T>
friend class PtrVectorBase
friend

Definition at line 41 of file Ptr.h.

Member Data Documentation

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