CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Types | Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes | Friends
edm::RefToBase< T > Class Template Reference

#include <AssociativeIterator.h>

Public Types

typedef T value_type
 

Public Member Functions

template<class REF >
REF castTo () const
 
value_type const * get () const
 
std::auto_ptr
< reftobase::RefHolderBase
holder () const
 
ProductID id () const
 
bool isAvailable () const
 
bool isNonnull () const
 Checks for non-null. More...
 
bool isNull () const
 Checks for null. More...
 
bool isTransient () const
 
size_t key () const
 
bool operator! () const
 Checks for null. More...
 
bool operator!= (RefToBase const &rhs) const
 
value_type const & operator* () const
 
value_type const * operator-> () const
 
RefToBaseoperator= (RefToBase &&other)
 
RefToBaseoperator= (RefToBase const &rhs)
 
bool operator== (RefToBase const &rhs) const
 
EDProductGetter const * productGetter () const
 
 RefToBase ()
 
 RefToBase (RefToBase const &other)
 
 RefToBase (RefToBase &&other)
 
template<typename C1 , typename T1 , typename F1 >
 RefToBase (Ref< C1, T1, F1 > const &r)
 
template<typename C >
 RefToBase (RefProd< C > const &r)
 
 RefToBase (RefToBaseProd< T > const &r, size_t i)
 
 RefToBase (Handle< View< T > > const &handle, size_t i)
 
template<typename T1 >
 RefToBase (RefToBase< T1 > const &r)
 
 RefToBase (std::unique_ptr< reftobase::BaseHolder< value_type >>)
 
 RefToBase (std::shared_ptr< reftobase::RefHolderBase > p)
 
void swap (RefToBase &other)
 
 ~RefToBase ()
 

Static Public Member Functions

static short Class_Version ()
 

Private Member Functions

value_type const * getPtrImpl () const
 

Private Attributes

reftobase::BaseHolder
< value_type > * 
holder_
 

Friends

template<typename B >
class RefToBase
 
class RefToBaseProd< T >
 
class RefToBaseVector< T >
 

Detailed Description

template<class T>
class edm::RefToBase< T >

Definition at line 49 of file AssociativeIterator.h.

Member Typedef Documentation

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

Definition at line 68 of file RefToBase.h.

Constructor & Destructor Documentation

template<class T >
RefToBase::RefToBase ( )
inline

Definition at line 134 of file RefToBase.h.

134  :
135  holder_(nullptr)
136  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
RefToBase::RefToBase ( RefToBase< T > const &  other)
inline

Definition at line 140 of file RefToBase.h.

140  :
141  holder_(other.holder_ ? other.holder_->clone() : nullptr)
142  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
RefToBase::RefToBase ( RefToBase< T > &&  other)
inline

Definition at line 146 of file RefToBase.h.

146  :
147  holder_(other.holder_) { other.holder_=nullptr;}
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
template<typename C1 , typename T1 , typename F1 >
RefToBase::RefToBase ( Ref< C1, T1, F1 > const &  r)
inlineexplicit

Definition at line 159 of file RefToBase.h.

159  :
160  holder_(new reftobase::Holder<T,Ref<C1, T1, F1> >(iRef))
161  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
long double T
template<class T >
template<typename C >
RefToBase::RefToBase ( RefProd< C > const &  r)
inlineexplicit

Definition at line 166 of file RefToBase.h.

166  :
167  holder_(new reftobase::Holder<T,RefProd<C> >(iRef))
168  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
long double T
template<class T>
RefToBase::RefToBase ( RefToBaseProd< T > const &  r,
size_t  i 
)
inline

Definition at line 413 of file RefToBase.h.

413  :
414  holder_( r.operator->()->refAt( i ).holder_->clone() ) {
415  }
int i
Definition: DBlmapReader.cc:9
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<typename T>
RefToBase::RefToBase ( Handle< View< T > > const &  handle,
size_t  i 
)
inline

Definition at line 419 of file RefToBase.h.

419  :
420  holder_( handle.operator->()->refAt( i ).holder_->clone() ) {
421  }
int i
Definition: DBlmapReader.cc:9
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
template<typename T1 >
RefToBase::RefToBase ( RefToBase< T1 > const &  r)
inlineexplicit

Definition at line 173 of file RefToBase.h.

References relativeConstraints::value.

173  :
174  holder_(new reftobase::IndirectHolder<T> (
175  std::shared_ptr< edm::reftobase::RefHolderBase>(iRef.holder().release())
176  ) )
177  {
178  // OUT: holder_( new reftobase::Holder<T,RefToBase<T1> >(iRef ) ) {
179  // Forcing the conversion through IndirectHolder,
180  // as Holder<T,RefToBase<T1>> would need dictionaries we will never have.
181  // In this way we only need the IndirectHolder<T> and the RefHolder of the real type of the item
182  // This might cause a small performance penalty.
183  static_assert( std::is_base_of<T, T1>::value, "RefToBase::RefToBase T not base of T1" );
184  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T>
RefToBase::RefToBase ( std::unique_ptr< reftobase::BaseHolder< value_type >>  p)
inline

Definition at line 188 of file RefToBase.h.

188  :
189  holder_(p.release())
190  {}
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T>
RefToBase::RefToBase ( std::shared_ptr< reftobase::RefHolderBase p)
inline

Definition at line 194 of file RefToBase.h.

194  :
195  holder_(new reftobase::IndirectHolder<T>(p))
196  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
RefToBase::~RefToBase ( )
inline

Definition at line 200 of file RefToBase.h.

201  {
202  delete holder_;
203  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122

Member Function Documentation

template<class T >
template<class REF >
REF RefToBase::castTo ( ) const

Definition at line 286 of file RefToBase.h.

References edm::errors::InvalidReference, relval_steps::key, mergeVDriftHistosByStation::name, edm::refcoreimpl::productGetter(), edm::Exception::throwThis(), and relativeConstraints::value.

Referenced by egPM::AbsEtaNrClus::AbsEtaNrClus(), egPM::AbsEtaNrClusEt::AbsEtaNrClusEt(), egPM::AbsEtaNrClusPhi::AbsEtaNrClusPhi(), ElectronMcSignalValidator::analyze(), ElectronSeedAnalyzer::analyze(), ElectronMcFakeValidator::analyze(), ZMuMuAnalyzer::analyze(), GsfElectronMCFakeAnalyzer::analyze(), GsfElectronDataAnalyzer::analyze(), GsfElectronFakeAnalyzer::analyze(), GsfElectronMCAnalyzer::analyze(), ZMuMuAnalyzer_cynematics::analyze(), ConversionProducer::buildCollection(), MuonTrajectoryCleaner::clean(), reco::JetSignalVertexCompatibilityAlgo::convert(), ZToMuMuFilter::filter(), HLTElectronPixelMatchFilter::getNrOfMatches(), reco::GsfElectronCore::GsfElectronCore(), HLTEgamma::MakeL1IsolatedElectrons(), HLTEgamma::MakeL1NonIsolatedElectrons(), reco::PFTauDecayMode::pfMasterClones(), L1TMuon::InternalTrack::print(), EgammaHLTPixelMatchVarProducer::produce(), pat::PATJetUpdater::produce(), ElectronSeedProducer::produce(), HLTScoutingEgammaProducer::produce(), EgammaHLTGsfTrackVarProducer::produce(), NuclearTrackCorrector::produce(), GsfElectronCoreEcalDrivenProducer::produceEcalDrivenCore(), GsfElectronAlgo::setCutBasedPreselectionFlag(), reco::CaloTauTagInfo::setJetRef(), and GsfElectronAlgo::setPixelMatchInfomation().

286  {
287 
288  if (!holder_) {
290  "attempting to cast a null RefToBase;\n"
291  "You should check for nullity before casting.");
292  }
293 
294  checkTypeCompatibility<T, typename REF::value_type>();
295 
296  // If REF is type edm::Ref<C,T,F>, then it is impossible to
297  // check the container type C here. We just have to assume
298  // that the caller provided the correct type.
299 
300  EDProductGetter const* getter = productGetter();
301  if(getter) {
302  return REF(id(), key(), getter);
303  }
304 
305  T const* value = get();
306  if(value == nullptr) {
307  return REF(id());
308  }
309  typename REF::value_type const* newValue = convertTo<T, typename REF::value_type>(value);
310  if(newValue) {
311  return REF(id(), newValue, key(), isTransient());
312  }
313 
315  "RefToBase<T>::castTo Error attempting to cast mismatched types\n"
316  "casting from RefToBase with T: ",
317  typeid(T).name(),
318  "\ncasting to: ",
319  typeid(REF).name()
320  );
321  return REF();
322  }
static void throwThis(Code category, char const *message0="", char const *message1="", char const *message2="", char const *message3="", char const *message4="")
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
size_t key() const
Definition: RefToBase.h:250
EDProductGetter const * productGetter() const
Definition: RefToBase.h:379
bool isTransient() const
Definition: RefToBase.h:116
long double T
template<class T>
static short edm::RefToBase< T >::Class_Version ( )
inlinestatic

Definition at line 119 of file RefToBase.h.

120 :
121  value_type const* getPtrImpl() const;
value_type const * getPtrImpl() const
Definition: RefToBase.h:386
template<class T >
T const * RefToBase::get ( ) const
inline

Definition at line 234 of file RefToBase.h.

Referenced by Options.Options::__getitem__(), betterConfigParser.BetterConfigParser::__updateDict(), DimuonStatistics::analyze(), GlbMuQualityCutsAnalysis::analyze(), PFCheckHitPattern::analyze(), TkConvValidator::analyze(), TestOutliers::analyze(), PhotonValidator::analyze(), IsolatedTracksNxN::analyze(), ConversionProducer::buildCollection(), util.rrapi.RRApi::columns(), rrapi.RRApi::columns(), edm::helper::RefConverter< RefToBase< T >, Ptr< T > >::convert(), rrapi.RRApi::count(), util.rrapi.RRApi::count(), rrapi.RRApi::data(), util.rrapi.RRApi::data(), PFCandCommonVertexFitterBase::fill(), reco::GenJet::genParticle(), reco::Candidate::get(), reco::LeafCandidate::get(), MultiTrackSelector::getBestVertex(), L6SLBCorrector::getBTagInfoIndex(), L6SLBCorrectorImpl::getBTagInfoIndex(), betterConfigParser.BetterConfigParser::getCompares(), betterConfigParser.BetterConfigParser::getGeneral(), SelectReplacementCandidates::getRawIDsAdvanced(), betterConfigParser.BetterConfigParser::getResultingSection(), PFElecTkProducer::isSameEgSC(), PFElecTkProducer::isSharingEcalEnergyWithEgSC(), reco::makeSpecific(), TemplatedSecondaryVertexProducer< IPTI, VTX >::matchSubjets(), pat::MET::MET(), pat::TriggerObject::origObjCand(), PFCheckHitPattern::print(), DimuonMCMatcher::produce(), pat::PATJetProducer::produce(), rrapi.RRApi::report(), util.rrapi.RRApi::report(), rrapi.RRApi::reports(), util.rrapi.RRApi::reports(), reco::CaloTauTagInfo::setJetRef(), util.rrapi.RRApi::tables(), rrapi.RRApi::tables(), util.rrapi.RRApi::tags(), rrapi.RRApi::tags(), rrapi.RRApi::templates(), util.rrapi.RRApi::templates(), reco::ConversionTrack::track(), pat::VertexAssociation::track(), rrapi.RRApi::workspaces(), and util.rrapi.RRApi::workspaces().

235  {
236  return getPtrImpl();
237  }
value_type const * getPtrImpl() const
Definition: RefToBase.h:386
template<class T >
T const * RefToBase::getPtrImpl ( ) const
inlineprivate

Definition at line 386 of file RefToBase.h.

387  {
388  return holder_ ? holder_->getPtr() : nullptr;
389  }
virtual T const * getPtr() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
std::auto_ptr< reftobase::RefHolderBase > RefToBase::holder ( ) const

Definition at line 392 of file RefToBase.h.

392  {
393  return holder_? holder_->holder() : std::auto_ptr<reftobase::RefHolderBase>();
394  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
virtual std::auto_ptr< RefHolderBase > holder() const =0
template<class T >
ProductID RefToBase::id ( ) const
inline
template<class T>
bool edm::RefToBase< T >::isAvailable ( ) const
inline

Checks if collection is in memory or available in the Event. No type checking is done.

Definition at line 114 of file RefToBase.h.

Referenced by edm::helper::RefConverter< RefToBase< T >, Ptr< T > >::convert().

114 { return holder_? holder_->isAvailable(): false; }
virtual bool isAvailable() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
bool RefToBase::isNonnull ( ) const
inline
template<class T >
bool RefToBase::isNull ( ) const
inline
template<class T>
bool edm::RefToBase< T >::isTransient ( ) const
inline

Definition at line 116 of file RefToBase.h.

116 { return holder_ ? holder_->isTransient() : false; }
virtual bool isTransient() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
size_t RefToBase::key ( ) const
inline

Definition at line 250 of file RefToBase.h.

References edm::errors::InvalidReference, and edm::Exception::throwThis().

Referenced by MuonTrackValidator::analyze(), VertexAssociatorByTracks::associateSimToReco(), PFDisplacedVertexFinder::commonTracks(), edm::helper::RefConverter< RefToBase< T >, Ptr< T > >::convert(), equals(), edm::RefToBaseVector< T >::fillView(), PFDisplacedVertexCandidateFinder::link(), ConversionTools::matchesConversion(), TemplatedSecondaryVertexProducer< IPTI, VTX >::matchSubjets(), MuonToSimAssociatorBase::RefToBaseSort::operator()(), reco::RefToBaseSort::operator()(), reco::JetSignalVertexCompatibilityAlgo::RefToBaseLess< T >::operator()(), BTagPerformanceAnalyzerOnData::JetRefCompare::operator()(), BTagPerformanceAnalyzerMC::JetRefCompare::operator()(), reco::PFDisplacedVertexSeed::Compare::operator()(), HLTBTagPerformanceAnalyzer::JetRefCompare::operator()(), SoftLepton::TrackCompare::operator()(), edm::AssociationVector< KeyRefProd, CVal, KeyRef, SizeType, KeyReferenceHelper >::operator[](), DistortedPFCandProducer::produce(), PFDisplacedTrackerVertexProducer::produce(), ProbeMulteplicityProducer::produce(), cms::CkfTrackCandidateMakerBase::produceBase(), IPProducerHelpers::FromJetAndCands::tracks(), and pat::helper::TriggerMatchHelper::triggerMatchObject().

251  {
252  if ( holder_ == nullptr )
254  "attempting get key from null RefToBase;\n"
255  "You should check for nullity before calling key().");
256  return holder_->key();
257  }
static void throwThis(Code category, char const *message0="", char const *message1="", char const *message2="", char const *message3="", char const *message4="")
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
virtual size_t key() const =0
template<class T >
bool RefToBase::operator! ( ) const
inline

Checks for null.

Definition at line 346 of file RefToBase.h.

347  {
348  return isNull();
349  }
bool isNull() const
Checks for null.
Definition: RefToBase.h:328
template<class T>
bool RefToBase::operator!= ( RefToBase< T > const &  rhs) const
inline

Definition at line 364 of file RefToBase.h.

365  {
366  return !(*this == rhs);
367  }
template<class T >
T const & RefToBase::operator* ( ) const
inline

Definition at line 218 of file RefToBase.h.

219  {
220  return *getPtrImpl();
221  }
value_type const * getPtrImpl() const
Definition: RefToBase.h:386
template<class T >
T const * RefToBase::operator-> ( ) const
inline

Definition at line 226 of file RefToBase.h.

227  {
228  return getPtrImpl();
229  }
value_type const * getPtrImpl() const
Definition: RefToBase.h:386
template<class T >
RefToBase< T > & RefToBase::operator= ( RefToBase< T > &&  other)
inline

Definition at line 151 of file RefToBase.h.

151  {
152  delete holder_; holder_=other.holder_; other.holder_=nullptr; return *this;
153  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T>
RefToBase& edm::RefToBase< T >::operator= ( RefToBase< T > const &  rhs)
template<class T>
bool RefToBase::operator== ( RefToBase< T > const &  rhs) const
inline

Definition at line 354 of file RefToBase.h.

References edm::RefToBase< T >::holder_.

355  {
356  return holder_
357  ? holder_->isEqualTo(*rhs.holder_)
358  : holder_ == rhs.holder_;
359  }
virtual bool isEqualTo(BaseHolder< T > const &rhs) const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
template<class T >
EDProductGetter const * RefToBase::productGetter ( ) const
inline

Definition at line 379 of file RefToBase.h.

379  {
380  return holder_? holder_->productGetter():nullptr;
381  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
virtual EDProductGetter const * productGetter() const =0
template<class T>
void RefToBase::swap ( RefToBase< T > &  other)
inline

Definition at line 372 of file RefToBase.h.

References edm::RefToBase< T >::holder_, and std::swap().

Referenced by edm::swap().

373  {
374  std::swap(holder_, other.holder_);
375  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:122
void swap(edm::DataFrameContainer &lhs, edm::DataFrameContainer &rhs)

Friends And Related Function Documentation

template<class T>
template<typename B >
friend class RefToBase
friend

Definition at line 125 of file RefToBase.h.

template<class T>
friend class RefToBaseProd< T >
friend

Definition at line 124 of file RefToBase.h.

template<class T>
friend class RefToBaseVector< T >
friend

Definition at line 123 of file RefToBase.h.

Member Data Documentation

template<class T>
reftobase::BaseHolder<value_type>* edm::RefToBase< T >::holder_
private