BOSS 7.0.2
BESIII Offline Software System
Loading...
Searching...
No Matches
HepMcParticleLink Class Reference

a link optimized in size for a GenParticle in a McEventCollection More...

#include <HepMcParticleLink.h>

Public Types

typedef unsigned int index_type
 
typedef unsigned int index_type
 

Public Member Functions

structors
 HepMcParticleLink ()
 
 HepMcParticleLink (index_type barCode, index_type eventIndex=0)
 
 HepMcParticleLink (const HepMC::GenParticle *p, index_type eventIndex=0)
 
 HepMcParticleLink (const HepMcParticleLink &rhs)
 
 HepMcParticleLink (const HepMC::GenParticle *part, const HepMC::GenEvent *pevt)
 
 HepMcParticleLink ()
 
 HepMcParticleLink (index_type barCode, index_type eventIndex=0)
 
 HepMcParticleLink (const HepMC::GenParticle *p, index_type eventIndex=0)
 
 HepMcParticleLink (const HepMcParticleLink &rhs)
 
 HepMcParticleLink (const HepMC::GenParticle *part, const HepMC::GenEvent *pevt)
 
pointer interface
const HepMC::GenParticle & operator* () const
 
const HepMC::GenParticle * operator-> () const
 
 operator const HepMC::GenParticle * () const
 
bool operator! () const
 
const HepMC::GenParticle & operator* () const
 
const HepMC::GenParticle * operator-> () const
 
 operator const HepMC::GenParticle * () const
 
bool operator! () const
 

indexing accessors (e.g. for writing)

int barcode () const
 
index_type eventIndex () const
 
bool isValid () const
 
const HepMC::GenParticle * cptr () const
 
int barcode () const
 
index_type eventIndex () const
 
bool isValid () const
 
const HepMC::GenParticle * cptr () const
 

Detailed Description

a link optimized in size for a GenParticle in a McEventCollection

See also
McEventCollection, GenEvent, ElementLink
Author
Paolo Calafiura
Id
HepMcParticleLink.h,v 1.1.1.1 2004/09/28 06:40:36 liwd Exp

Definition at line 17 of file Generator/GeneratorObject/GeneratorObject-00-01-05/GeneratorObject/HepMcParticleLink.h.

Member Typedef Documentation

◆ index_type [1/2]

◆ index_type [2/2]

Constructor & Destructor Documentation

◆ HepMcParticleLink() [1/10]

HepMcParticleLink::HepMcParticleLink ( )
inline

Definition at line 23 of file Generator/GeneratorObject/GeneratorObject-00-01-05/GeneratorObject/HepMcParticleLink.h.

23: m_particle(0), m_extBarcode() {}

◆ HepMcParticleLink() [2/10]

HepMcParticleLink::HepMcParticleLink ( index_type  barCode,
index_type  eventIndex = 0 
)
inline

◆ HepMcParticleLink() [3/10]

HepMcParticleLink::HepMcParticleLink ( const HepMC::GenParticle *  p,
index_type  eventIndex = 0 
)

Definition at line 8 of file HepMcParticleLink.cxx.

9 :
10 m_particle(const_cast<HepMC::GenParticle*>(part)),
11 m_extBarcode((0 != part) ? part->barcode() : 0, eventIndex) {
12 assert(part);
13}

◆ HepMcParticleLink() [4/10]

HepMcParticleLink::HepMcParticleLink ( const HepMcParticleLink rhs)
inline

Definition at line 27 of file Generator/GeneratorObject/GeneratorObject-00-01-05/GeneratorObject/HepMcParticleLink.h.

27 :
28 m_particle(rhs.m_particle),
29 m_extBarcode(rhs.m_extBarcode) {}

◆ HepMcParticleLink() [5/10]

HepMcParticleLink::HepMcParticleLink ( const HepMC::GenParticle *  part,
const HepMC::GenEvent *  pevt 
)

◆ HepMcParticleLink() [6/10]

HepMcParticleLink::HepMcParticleLink ( )
inline

Definition at line 23 of file InstallArea/include/GeneratorObject/GeneratorObject/HepMcParticleLink.h.

23: m_particle(0), m_extBarcode() {}

◆ HepMcParticleLink() [7/10]

HepMcParticleLink::HepMcParticleLink ( index_type  barCode,
index_type  eventIndex = 0 
)
inline

Definition at line 24 of file InstallArea/include/GeneratorObject/GeneratorObject/HepMcParticleLink.h.

24 :
25 m_particle(0), m_extBarcode(barCode, eventIndex) {}

◆ HepMcParticleLink() [8/10]

HepMcParticleLink::HepMcParticleLink ( const HepMC::GenParticle *  p,
index_type  eventIndex = 0 
)

◆ HepMcParticleLink() [9/10]

HepMcParticleLink::HepMcParticleLink ( const HepMcParticleLink rhs)
inline

Definition at line 27 of file InstallArea/include/GeneratorObject/GeneratorObject/HepMcParticleLink.h.

27 :
28 m_particle(rhs.m_particle),
29 m_extBarcode(rhs.m_extBarcode) {}

◆ HepMcParticleLink() [10/10]

HepMcParticleLink::HepMcParticleLink ( const HepMC::GenParticle *  part,
const HepMC::GenEvent *  pevt 
)

Member Function Documentation

◆ barcode() [1/2]

int HepMcParticleLink::barcode ( ) const
inline

Definition at line 45 of file Generator/GeneratorObject/GeneratorObject-00-01-05/GeneratorObject/HepMcParticleLink.h.

45{ return m_extBarcode.barcode(); }

Referenced by cptr().

◆ barcode() [2/2]

int HepMcParticleLink::barcode ( ) const
inline

Definition at line 45 of file InstallArea/include/GeneratorObject/GeneratorObject/HepMcParticleLink.h.

45{ return m_extBarcode.barcode(); }

◆ cptr() [1/2]

const HepMC::GenParticle * HepMcParticleLink::cptr ( ) const

Definition at line 15 of file HepMcParticleLink.cxx.

15 {
16 if (!m_particle) {
17 const McEventCollection* pEvtColl;
18 if ((StoreGate::instance().retrieve(pEvtColl)).isSuccess()) { //FIXME SLOW
19 m_particle = pEvtColl->at(eventIndex())->barcode_to_particle(barcode());
20 }
21 }
22 return m_particle;
23}

Referenced by isValid(), operator const HepMC::GenParticle *(), operator*(), and operator->().

◆ cptr() [2/2]

const HepMC::GenParticle * HepMcParticleLink::cptr ( ) const

◆ eventIndex() [1/2]

index_type HepMcParticleLink::eventIndex ( ) const
inline

Definition at line 46 of file Generator/GeneratorObject/GeneratorObject-00-01-05/GeneratorObject/HepMcParticleLink.h.

46{ return m_extBarcode.eventIndex(); }

Referenced by cptr().

◆ eventIndex() [2/2]

index_type HepMcParticleLink::eventIndex ( ) const
inline

Definition at line 46 of file InstallArea/include/GeneratorObject/GeneratorObject/HepMcParticleLink.h.

46{ return m_extBarcode.eventIndex(); }

◆ isValid() [1/2]

bool HepMcParticleLink::isValid ( ) const
inline

Definition at line 49 of file Generator/GeneratorObject/GeneratorObject-00-01-05/GeneratorObject/HepMcParticleLink.h.

49{ return (0 != cptr()); }

Referenced by operator!().

◆ isValid() [2/2]

bool HepMcParticleLink::isValid ( ) const
inline

Definition at line 49 of file InstallArea/include/GeneratorObject/GeneratorObject/HepMcParticleLink.h.

49{ return (0 != cptr()); }

◆ operator const HepMC::GenParticle *() [1/2]

HepMcParticleLink::operator const HepMC::GenParticle * ( ) const
inline

◆ operator const HepMC::GenParticle *() [2/2]

HepMcParticleLink::operator const HepMC::GenParticle * ( ) const
inline

◆ operator!() [1/2]

◆ operator!() [2/2]

bool HepMcParticleLink::operator! ( ) const
inline

◆ operator*() [1/2]

const HepMC::GenParticle & HepMcParticleLink::operator* ( ) const
inline
Exceptions
std::runtime_errorwhen the element is not found

Definition at line 37 of file Generator/GeneratorObject/GeneratorObject-00-01-05/GeneratorObject/HepMcParticleLink.h.

37{ return *cptr(); }//FIXME

◆ operator*() [2/2]

const HepMC::GenParticle & HepMcParticleLink::operator* ( ) const
inline
Exceptions
std::runtime_errorwhen the element is not found

Definition at line 37 of file InstallArea/include/GeneratorObject/GeneratorObject/HepMcParticleLink.h.

37{ return *cptr(); }//FIXME

◆ operator->() [1/2]

const HepMC::GenParticle * HepMcParticleLink::operator-> ( ) const
inline

◆ operator->() [2/2]

const HepMC::GenParticle * HepMcParticleLink::operator-> ( ) const
inline

The documentation for this class was generated from the following files: