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 | 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
 
RefToBase const & operator= (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 (boost::shared_ptr< reftobase::RefHolderBase > p)
 
void swap (RefToBase &other)
 
 ~RefToBase ()
 

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 50 of file AssociativeIterator.h.

Member Typedef Documentation

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

Definition at line 67 of file RefToBase.h.

Constructor & Destructor Documentation

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

Definition at line 125 of file RefToBase.h.

125  :
126  holder_(0)
127  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
RefToBase::RefToBase ( RefToBase< T > const &  other)
inline

Definition at line 131 of file RefToBase.h.

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

Definition at line 138 of file RefToBase.h.

138  :
139  holder_(new reftobase::Holder<T,Ref<C1, T1, F1> >(iRef))
140  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
template<typename C >
RefToBase::RefToBase ( RefProd< C > const &  r)
inlineexplicit

Definition at line 145 of file RefToBase.h.

145  :
146  holder_(new reftobase::Holder<T,RefProd<C> >(iRef))
147  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T>
RefToBase::RefToBase ( RefToBaseProd< T > const &  r,
size_t  i 
)
inline

Definition at line 362 of file RefToBase.h.

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

Definition at line 368 of file RefToBase.h.

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

Definition at line 152 of file RefToBase.h.

References relativeConstraints::value.

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

Definition at line 167 of file RefToBase.h.

167  :
168  holder_(new reftobase::IndirectHolder<T>(p))
169  { }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
RefToBase::~RefToBase ( )
inline

Definition at line 173 of file RefToBase.h.

174  {
175  delete holder_;
176  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113

Member Function Documentation

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

cast to a concrete type

Definition at line 236 of file RefToBase.h.

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

Referenced by ElectronMcFakeValidator::analyze(), ElectronMcSignalValidator::analyze(), ElectronSeedAnalyzer::analyze(), ZMuMuAnalyzer::analyze(), GsfElectronDataAnalyzer::analyze(), GsfElectronFakeAnalyzer::analyze(), GsfElectronMCFakeAnalyzer::analyze(), GsfElectronMCAnalyzer::analyze(), ZMuMuAnalyzer_cynematics::analyze(), TrackerOnlyConversionProducer::buildCollection(), MuonTrajectoryCleaner::clean(), reco::JetSignalVertexCompatibilityAlgo::convert(), ZToMuMuFilter::filter(), HLTElectronPixelMatchFilter::filter(), reco::GsfElectronCore::GsfElectronCore(), HLTEgamma::MakeL1IsolatedElectrons(), HLTEgamma::MakeL1NonIsolatedElectrons(), pat::TriggerObject::origL1EmRef(), pat::TriggerObject::origL1EtMissRef(), pat::TriggerObject::origL1JetRef(), pat::TriggerObject::origL1MuonRef(), reco::PFTauDecayMode::pfMasterClones(), GsfElectronCoreEcalDrivenProducer::produce(), ElectronSeedProducer::produce(), NuclearTrackCorrector::produce(), GsfElectronAlgo::setCutBasedPreselectionFlag(), and reco::CaloTauTagInfo::setJetRef().

237  {
238  if (!holder_)
239  {
241  "attempting to cast a null RefToBase;\n"
242  "You should check for nullity before casting.");
243  }
244 
245  reftobase::RefHolder<REF> concrete_holder;
246  std::string hidden_ref_type;
247  if (!holder_->fillRefIfMyTypeMatches(concrete_holder,
248  hidden_ref_type))
249  {
251  "cast to type: ",
252  typeid(REF).name(),
253  "\nfrom type: ",
254  hidden_ref_type.c_str(),
255  " failed. Catch this exception in case you need to check"
256  " the concrete reference type.");
257  }
258  return concrete_holder.getRef();
259  }
static void throwThis(Code category, char const *message0="", char const *message1="", char const *message2="", char const *message3="", char const *message4="")
Definition: EDMException.cc:81
virtual bool fillRefIfMyTypeMatches(RefHolderBase &fillme, std::string &msg) const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
T const * RefToBase::get ( void  ) const
inline
template<class T >
T const * RefToBase::getPtrImpl ( ) const
inlineprivate

Definition at line 335 of file RefToBase.h.

336  {
337  return holder_ ? holder_->getPtr() : 0;
338  }
virtual T const * getPtr() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
bool RefToBase::hasProductCache ( ) const
inline

Definition at line 322 of file RefToBase.h.

322  {
323  return holder_->hasProductCache();
324  }
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
virtual bool hasProductCache() const =0
template<class T >
std::auto_ptr< reftobase::RefHolderBase > RefToBase::holder ( ) const

Definition at line 341 of file RefToBase.h.

341  {
342  return holder_->holder();
343  }
virtual std::auto_ptr< RefHolderBase > holder() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
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 110 of file RefToBase.h.

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

110 { return holder_->isAvailable(); }
virtual bool isAvailable() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
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 223 of file RefToBase.h.

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

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

224  {
225  if ( holder_ == 0 )
227  "attempting get key from null RefToBase;\n"
228  "You should check for nullity before calling key().");
229  return holder_->key();
230  }
static void throwThis(Code category, char const *message0="", char const *message1="", char const *message2="", char const *message3="", char const *message4="")
Definition: EDMException.cc:81
virtual size_t key() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
bool RefToBase::operator! ( ) const
inline

Checks for null.

Definition at line 283 of file RefToBase.h.

284  {
285  return isNull();
286  }
bool isNull() const
Checks for null.
Definition: RefToBase.h:265
template<class T >
bool RefToBase::operator!= ( RefToBase< T > const &  rhs) const
inline

Definition at line 301 of file RefToBase.h.

302  {
303  return !(*this == rhs);
304  }
template<class T >
T const & RefToBase::operator* ( ) const
inline

Definition at line 191 of file RefToBase.h.

192  {
193  return *getPtrImpl();
194  }
value_type const * getPtrImpl() const
Definition: RefToBase.h:335
template<class T >
T const * RefToBase::operator-> ( ) const
inline

Definition at line 199 of file RefToBase.h.

200  {
201  return getPtrImpl();
202  }
value_type const * getPtrImpl() const
Definition: RefToBase.h:335
template<class T >
RefToBase< T > const & RefToBase::operator= ( RefToBase< T > const &  rhs)
inline

Definition at line 181 of file RefToBase.h.

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

182  {
183  RefToBase<T> temp( iRHS);
184  temp.swap(*this);
185  return *this;
186  }
template<class T >
bool RefToBase::operator== ( RefToBase< T > const &  rhs) const
inline

Definition at line 291 of file RefToBase.h.

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

292  {
293  return holder_
294  ? holder_->isEqualTo(*rhs.holder_)
295  : holder_ == rhs.holder_;
296  }
virtual bool isEqualTo(BaseHolder< T > const &rhs) const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
void const * RefToBase::product ( ) const
inline

Definition at line 328 of file RefToBase.h.

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

328  {
329  return holder_->product();
330  }
virtual void const * product() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
EDProductGetter const * RefToBase::productGetter ( ) const
inline

Definition at line 316 of file RefToBase.h.

316  {
317  return holder_->productGetter();
318  }
virtual EDProductGetter const * productGetter() const =0
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113
template<class T >
void RefToBase::swap ( RefToBase< T > &  other)
inline

Definition at line 309 of file RefToBase.h.

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

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

310  {
311  std::swap(holder_, other.holder_);
312  }
void swap(edm::DataFrameContainer &lhs, edm::DataFrameContainer &rhs)
reftobase::BaseHolder< value_type > * holder_
Definition: RefToBase.h:113

Friends And Related Function Documentation

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

Definition at line 116 of file RefToBase.h.

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

Definition at line 115 of file RefToBase.h.

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

Definition at line 114 of file RefToBase.h.

Member Data Documentation

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