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
 cast to a concrete type More...
 
value_type const * get () const
 
bool hasProductCache () 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...
 
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 const &rhs)
 
bool operator== (RefToBase const &rhs) const
 
void const * product () const
 
EDProductGetter const * productGetter () const
 
 RefToBase ()
 
 RefToBase (RefToBase const &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::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 70 of file RefToBase.h.

Constructor & Destructor Documentation

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

Definition at line 131 of file RefToBase.h.

131  :
132  holder_(0)
133  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
template<class T >
RefToBase::RefToBase ( RefToBase< T > const &  other)
inline

Definition at line 137 of file RefToBase.h.

137  :
138  holder_(other.holder_ ? other.holder_->clone() : 0)
139  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
template<class T >
template<typename C1 , typename T1 , typename F1 >
RefToBase::RefToBase ( Ref< C1, T1, F1 > const &  r)
inlineexplicit

Definition at line 144 of file RefToBase.h.

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

Definition at line 151 of file RefToBase.h.

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

Definition at line 368 of file RefToBase.h.

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

Definition at line 374 of file RefToBase.h.

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

Definition at line 158 of file RefToBase.h.

References relativeConstraints::value.

158  :
159  holder_(new reftobase::IndirectHolder<T> (
160  std::shared_ptr< edm::reftobase::RefHolderBase>(iRef.holder().release())
161  ) )
162  {
163  // OUT: holder_( new reftobase::Holder<T,RefToBase<T1> >(iRef ) ) {
164  // Forcing the conversion through IndirectHolder,
165  // as Holder<T,RefToBase<T1>> would need dictionaries we will never have.
166  // In this way we only need the IndirectHolder<T> and the RefHolder of the real type of the item
167  // This might cause a small performance penalty.
168  BOOST_STATIC_ASSERT( ( boost::is_base_of<T, T1>::value ) );
169  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
template<class T>
RefToBase::RefToBase ( std::shared_ptr< reftobase::RefHolderBase p)
inline

Definition at line 173 of file RefToBase.h.

173  :
174  holder_(new reftobase::IndirectHolder<T>(p))
175  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
template<class T >
RefToBase::~RefToBase ( )
inline

Definition at line 179 of file RefToBase.h.

180  {
181  delete holder_;
182  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119

Member Function Documentation

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

cast to a concrete type

Definition at line 242 of file RefToBase.h.

References edm::reftobase::RefHolder< REF >::getRef(), edm::errors::InvalidReference, mergeVDriftHistosByStation::name, AlCaHLTBitMon_QueryRunRegistry::string, and edm::Exception::throwThis().

Referenced by ElectronMcSignalValidator::analyze(), ElectronMcFakeValidator::analyze(), ElectronSeedAnalyzer::analyze(), ZMuMuAnalyzer::analyze(), GsfElectronDataAnalyzer::analyze(), GsfElectronMCFakeAnalyzer::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(), ElectronSeedProducer::produce(), EgammaHLTGsfTrackVarProducer::produce(), NuclearTrackCorrector::produce(), GsfElectronCoreEcalDrivenProducer::produceEcalDrivenCore(), GsfElectronAlgo::setCutBasedPreselectionFlag(), reco::CaloTauTagInfo::setJetRef(), and GsfElectronAlgo::setPixelMatchInfomation().

243  {
244  if (!holder_)
245  {
247  "attempting to cast a null RefToBase;\n"
248  "You should check for nullity before casting.");
249  }
250 
251  reftobase::RefHolder<REF> concrete_holder;
252  std::string hidden_ref_type;
253  if (!holder_->fillRefIfMyTypeMatches(concrete_holder,
254  hidden_ref_type))
255  {
257  "cast to type: ",
258  typeid(REF).name(),
259  "\nfrom type: ",
260  hidden_ref_type.c_str(),
261  " failed. Catch this exception in case you need to check"
262  " the concrete reference type.");
263  }
264  return concrete_holder.getRef();
265  }
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:119
virtual bool fillRefIfMyTypeMatches(RefHolderBase &fillme, std::string &msg) const =0
template<class T>
static short edm::RefToBase< T >::Class_Version ( )
inlinestatic

Definition at line 116 of file RefToBase.h.

117 :
118  value_type const* getPtrImpl() const;
value_type const * getPtrImpl() const
Definition: RefToBase.h:341
template<class T >
T const * RefToBase::get ( void  ) const
inline

Definition at line 213 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(), rrapi.RRApi::columns(), edm::helper::RefConverter< RefToBase< T >, Ptr< T > >::convert(), rrapi.RRApi::count(), rrapi.RRApi::data(), PFCandCommonVertexFitterBase::fill(), reco::GenJet::genParticle(), reco::Candidate::get(), reco::LeafCandidate::get(), L6SLBCorrector::getBTagInfoIndex(), L6SLBCorrectorImpl::getBTagInfoIndex(), betterConfigParser.BetterConfigParser::getCompares(), betterConfigParser.BetterConfigParser::getGeneral(), SelectReplacementCandidates::getRawIDsAdvanced(), betterConfigParser.BetterConfigParser::getResultingSection(), PrimaryVertexAnalyzer4PU::getSimEvents(), reco::makeSpecific(), TemplatedSecondaryVertexProducer< IPTI, VTX >::matchSubjets(), pat::MET::MET(), pat::TriggerObject::origObjCand(), PFCheckHitPattern::print(), DimuonMCMatcher::produce(), pat::PATJetProducer::produce(), rrapi.RRApi::report(), rrapi.RRApi::reports(), reco::CaloTauTagInfo::setJetRef(), rrapi.RRApi::tables(), rrapi.RRApi::tags(), rrapi.RRApi::templates(), reco::ConversionTrack::track(), pat::VertexAssociation::track(), and rrapi.RRApi::workspaces().

214  {
215  return getPtrImpl();
216  }
value_type const * getPtrImpl() const
Definition: RefToBase.h:341
template<class T >
T const * RefToBase::getPtrImpl ( ) const
inlineprivate

Definition at line 341 of file RefToBase.h.

342  {
343  return holder_ ? holder_->getPtr() : 0;
344  }
virtual T const * getPtr() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
template<class T >
bool RefToBase::hasProductCache ( ) const
inline

Definition at line 328 of file RefToBase.h.

328  {
329  return holder_?holder_->hasProductCache():false;
330  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
virtual bool hasProductCache() const =0
template<class T >
std::auto_ptr< reftobase::RefHolderBase > RefToBase::holder ( ) const

Definition at line 347 of file RefToBase.h.

347  {
348  return holder_? holder_->holder() : std::auto_ptr<reftobase::RefHolderBase>();
349  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
virtual std::auto_ptr< RefHolderBase > holder() const =0
template<class T >
ProductID RefToBase::id ( void  ) 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 113 of file RefToBase.h.

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

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

Definition at line 229 of file RefToBase.h.

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

Referenced by HLTMonBTagMuSource::analyze(), MuonTrackValidator::analyze(), VertexAssociatorByTracks::associateSimToReco(), PFDisplacedVertexFinder::commonTracks(), edm::helper::RefConverter< RefToBase< T >, Ptr< T > >::convert(), PFDisplacedVertexCandidateFinder::link(), ConversionTools::matchesConversion(), TemplatedSecondaryVertexProducer< IPTI, VTX >::matchSubjets(), BTagPerformanceAnalyzerOnData::JetRefCompare::operator()(), reco::JetSignalVertexCompatibilityAlgo::RefToBaseLess< T >::operator()(), BTagPerformanceAnalyzerMC::JetRefCompare::operator()(), reco::PFDisplacedVertexSeed::Compare::operator()(), HLTBTagPerformanceAnalyzer::JetRefCompare::operator()(), SoftLepton::TrackCompare::operator()(), MuonAssociatorByHits::RefToBaseSort::operator()(), DistortedPFCandProducer::produce(), PFDisplacedTrackerVertexProducer::produce(), IPProducerHelpers::FromJetAndCands::tracks(), and pat::helper::TriggerMatchHelper::triggerMatchObject().

230  {
231  if ( holder_ == 0 )
233  "attempting get key from null RefToBase;\n"
234  "You should check for nullity before calling key().");
235  return holder_->key();
236  }
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:119
virtual size_t key() const =0
template<class T >
bool RefToBase::operator! ( ) const
inline

Checks for null.

Definition at line 289 of file RefToBase.h.

290  {
291  return isNull();
292  }
bool isNull() const
Checks for null.
Definition: RefToBase.h:271
template<class T>
bool RefToBase::operator!= ( RefToBase< T > const &  rhs) const
inline

Definition at line 307 of file RefToBase.h.

308  {
309  return !(*this == rhs);
310  }
template<class T >
T const & RefToBase::operator* ( ) const
inline

Definition at line 197 of file RefToBase.h.

198  {
199  return *getPtrImpl();
200  }
value_type const * getPtrImpl() const
Definition: RefToBase.h:341
template<class T >
T const * RefToBase::operator-> ( ) const
inline

Definition at line 205 of file RefToBase.h.

206  {
207  return getPtrImpl();
208  }
value_type const * getPtrImpl() const
Definition: RefToBase.h:341
template<class T>
RefToBase< T > & RefToBase::operator= ( RefToBase< T > const &  rhs)
inline

Definition at line 187 of file RefToBase.h.

References edm::RefToBase< T >::swap(), and groupFilesInBlocks::temp.

188  {
189  RefToBase<T> temp( iRHS);
190  temp.swap(*this);
191  return *this;
192  }
template<class T>
bool RefToBase::operator== ( RefToBase< T > const &  rhs) const
inline

Definition at line 297 of file RefToBase.h.

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

298  {
299  return holder_
300  ? holder_->isEqualTo(*rhs.holder_)
301  : holder_ == rhs.holder_;
302  }
virtual bool isEqualTo(BaseHolder< T > const &rhs) const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
template<class T >
void const * RefToBase::product ( ) const
inline

Definition at line 334 of file RefToBase.h.

Referenced by edm::RefToBaseProd< T >::RefToBaseProd().

334  {
335  return holder_?holder_->product():nullptr;
336  }
virtual void const * product() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
template<class T >
EDProductGetter const * RefToBase::productGetter ( ) const
inline

Definition at line 322 of file RefToBase.h.

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

Definition at line 315 of file RefToBase.h.

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

Referenced by edm::RefToBase< T >::operator=(), and edm::swap().

316  {
317  std::swap(holder_, other.holder_);
318  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:119
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 122 of file RefToBase.h.

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

Definition at line 121 of file RefToBase.h.

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

Definition at line 120 of file RefToBase.h.

Member Data Documentation

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