Geant4-11
Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Member Functions | Private Attributes | Static Private Attributes
G4SDManager Class Reference

#include <G4SDManager.hh>

Public Member Functions

void Activate (G4String dName, G4bool activeFlag)
 
void AddNewCollection (G4String SDname, G4String DCname)
 
void AddNewDetector (G4VSensitiveDetector *aSD)
 
void DeRegisterSDFilter (G4VSDFilter *filter)
 
G4VSensitiveDetectorFindSensitiveDetector (G4String dName, G4bool warning=true)
 
G4int GetCollectionCapacity () const
 
G4int GetCollectionID (G4String colName)
 
G4int GetCollectionID (G4VHitsCollection *aHC)
 
G4HCtableGetHCtable () const
 
G4SDStructureGetTreeTop () const
 
void ListTree () const
 
G4HCofThisEventPrepareNewEvent ()
 
void RegisterSDFilter (G4VSDFilter *filter)
 
void SetVerboseLevel (G4int vl)
 
void TerminateCurrentEvent (G4HCofThisEvent *HCE)
 
 ~G4SDManager ()
 

Static Public Member Functions

static G4SDManagerGetSDMpointer ()
 
static G4SDManagerGetSDMpointerIfExist ()
 

Protected Member Functions

 G4SDManager ()
 

Private Member Functions

void DestroyFilters ()
 
 G4SDManager (const G4SDManager &)
 
G4SDManageroperator= (const G4SDManager &)
 

Private Attributes

std::vector< G4VSDFilter * > FilterList
 
G4HCtableHCtable
 
G4SDmessengertheMessenger
 
G4SDStructuretreeTop
 
G4int verboseLevel
 

Static Private Attributes

static G4ThreadLocal G4SDManagerfSDManager = nullptr
 

Detailed Description

Definition at line 52 of file G4SDManager.hh.

Constructor & Destructor Documentation

◆ G4SDManager() [1/2]

G4SDManager::G4SDManager ( )
protected

Definition at line 49 of file G4SDManager.cc.

50 : verboseLevel(0)
51{
52 G4String topName = "/";
53 treeTop = new G4SDStructure(topName);
54 theMessenger = new G4SDmessenger(this);
55 HCtable = new G4HCtable;
56}
G4int verboseLevel
Definition: G4SDManager.hh:88
G4SDStructure * treeTop
Definition: G4SDManager.hh:87
G4HCtable * HCtable
Definition: G4SDManager.hh:89
G4SDmessenger * theMessenger
Definition: G4SDManager.hh:90

References HCtable, theMessenger, and treeTop.

Referenced by GetSDMpointer().

◆ ~G4SDManager()

G4SDManager::~G4SDManager ( )

Definition at line 58 of file G4SDManager.cc.

59{
60 delete theMessenger;
61 delete HCtable;
62 delete treeTop;
64 theMessenger = nullptr;
65 HCtable = nullptr;
66 treeTop = nullptr;
67 fSDManager = nullptr;
68}
static G4ThreadLocal G4SDManager * fSDManager
Definition: G4SDManager.hh:86
void DestroyFilters()
Definition: G4SDManager.cc:181

References DestroyFilters(), fSDManager, HCtable, theMessenger, and treeTop.

◆ G4SDManager() [2/2]

G4SDManager::G4SDManager ( const G4SDManager )
private

Member Function Documentation

◆ Activate()

void G4SDManager::Activate ( G4String  dName,
G4bool  activeFlag 
)

Definition at line 125 of file G4SDManager.cc.

126{
127 G4String pathName = dName;
128 if(pathName[0] != '/')
129 pathName.insert(0, "/");
130 treeTop->Activate(pathName, activeFlag);
131}
void Activate(const G4String &aName, G4bool sensitiveFlag)

References G4SDStructure::Activate(), and treeTop.

Referenced by G4RTRunAction::BeginOfRunAction(), G4RTRunAction::EndOfRunAction(), G4MaterialScanner::RestoreUserActions(), G4TheRayTracer::RestoreUserActions(), G4SDmessenger::SetNewValue(), G4MaterialScanner::StoreUserActions(), and G4TheRayTracer::StoreUserActions().

◆ AddNewCollection()

void G4SDManager::AddNewCollection ( G4String  SDname,
G4String  DCname 
)

Definition at line 94 of file G4SDManager.cc.

95{
96 G4int i = HCtable->Registor(SDname, DCname);
97 if(verboseLevel > 0)
98 {
99 if(i < 0)
100 {
101 if(verboseLevel > 1)
102 G4cout << "G4SDManager::AddNewCollection : the collection <" << SDname
103 << "/" << DCname << "> has already been reginstered." << G4endl;
104 }
105 else
106 {
107 G4cout << "G4SDManager::AddNewCollection : the collection <" << SDname
108 << "/" << DCname << "> is registered at " << i << G4endl;
109 }
110 }
111}
int G4int
Definition: G4Types.hh:85
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
G4int Registor(G4String SDname, G4String HCname)
Definition: G4HCtable.cc:36

References G4cout, G4endl, HCtable, G4HCtable::Registor(), and verboseLevel.

Referenced by AddNewDetector(), and G4MultiFunctionalDetector::RegisterPrimitive().

◆ AddNewDetector()

void G4SDManager::AddNewDetector ( G4VSensitiveDetector aSD)

Definition at line 70 of file G4SDManager.cc.

71{
72 G4int numberOfCollections = aSD->GetNumberOfCollections();
73 G4String pathName = aSD->GetPathName();
74 if(pathName[0] != '/')
75 pathName.insert(0, "/");
76 if(pathName.back() != '/')
77 pathName += "/";
78 treeTop->AddNewDetector(aSD, pathName);
79 if(numberOfCollections < 1)
80 return;
81 for(G4int i = 0; i < numberOfCollections; i++)
82 {
83 G4String SDname = aSD->GetName();
84 G4String DCname = aSD->GetCollectionName(i);
85 AddNewCollection(SDname, DCname);
86 }
87 if(verboseLevel > 0)
88 {
89 G4cout << "New sensitive detector <" << aSD->GetName()
90 << "> is registered at " << pathName << G4endl;
91 }
92}
void AddNewCollection(G4String SDname, G4String DCname)
Definition: G4SDManager.cc:94
void AddNewDetector(G4VSensitiveDetector *aSD, const G4String &treeStructure)
G4int GetNumberOfCollections() const
G4String GetCollectionName(G4int id) const
G4String GetPathName() const

References AddNewCollection(), G4SDStructure::AddNewDetector(), G4cout, G4endl, G4VSensitiveDetector::GetCollectionName(), G4VSensitiveDetector::GetName(), G4VSensitiveDetector::GetNumberOfCollections(), G4VSensitiveDetector::GetPathName(), treeTop, and verboseLevel.

Referenced by G4VScoringMesh::G4VScoringMesh(), G4VUserDetectorConstruction::SetSensitiveDetector(), and G4VUserParallelWorld::SetSensitiveDetector().

◆ DeRegisterSDFilter()

void G4SDManager::DeRegisterSDFilter ( G4VSDFilter filter)

Definition at line 169 of file G4SDManager.cc.

170{
171 for(auto f = FilterList.begin(); f != FilterList.end(); f++)
172 {
173 if(*f == filter)
174 {
175 FilterList.erase(f);
176 break;
177 }
178 }
179}
std::vector< G4VSDFilter * > FilterList
Definition: G4SDManager.hh:114

References FilterList.

Referenced by G4VSDFilter::~G4VSDFilter().

◆ DestroyFilters()

void G4SDManager::DestroyFilters ( )
private

Definition at line 181 of file G4SDManager.cc.

182{
183 auto f = FilterList.begin();
184 while(f != FilterList.end())
185 {
186 if(verboseLevel > 0)
187 G4cout << "### deleting " << (*f)->GetName() << " " << (*f) << G4endl;
188 delete *f;
189 f = FilterList.begin();
190 }
191 FilterList.clear();
192}

References FilterList, G4cout, G4endl, and verboseLevel.

Referenced by ~G4SDManager().

◆ FindSensitiveDetector()

G4VSensitiveDetector * G4SDManager::FindSensitiveDetector ( G4String  dName,
G4bool  warning = true 
)

Definition at line 133 of file G4SDManager.cc.

135{
136 G4String pathName = dName;
137 if(pathName[0] != '/')
138 pathName.insert(0, "/");
139 return treeTop->FindSensitiveDetector(pathName, warning);
140}
G4VSensitiveDetector * FindSensitiveDetector(const G4String &aName, G4bool warning=true)

References G4SDStructure::FindSensitiveDetector(), and treeTop.

◆ GetCollectionCapacity()

G4int G4SDManager::GetCollectionCapacity ( ) const
inline

Definition at line 100 of file G4SDManager.hh.

100{ return HCtable->entries(); }
G4int entries() const
Definition: G4HCtable.hh:65

References G4HCtable::entries(), and HCtable.

◆ GetCollectionID() [1/2]

G4int G4SDManager::GetCollectionID ( G4String  colName)

Definition at line 142 of file G4SDManager.cc.

143{
144 G4int id = HCtable->GetCollectionID(colName);
145 if(id == -1)
146 {
147 G4cout << "<" << colName << "> is not found." << G4endl;
148 }
149 else if(id == -2)
150 {
151 G4cout << "<" << colName << "> is ambiguous." << G4endl;
152 }
153 return id;
154}
G4int GetCollectionID(G4String HCname) const
Definition: G4HCtable.cc:48

References G4cout, G4endl, G4HCtable::GetCollectionID(), and HCtable.

Referenced by G4VSensitiveDetector::GetCollectionID(), G4VPrimitiveScorer::GetCollectionID(), GetCollectionID(), and G4DigiManager::GetHitsCollectionID().

◆ GetCollectionID() [2/2]

G4int G4SDManager::GetCollectionID ( G4VHitsCollection aHC)

Definition at line 156 of file G4SDManager.cc.

157{
158 G4String HCname = aHC->GetSDname();
159 HCname += "/";
160 HCname += aHC->GetName();
161 return GetCollectionID(HCname);
162}
G4int GetCollectionID(G4String colName)
Definition: G4SDManager.cc:142
const G4String & GetSDname() const
const G4String & GetName() const

References GetCollectionID(), G4VHitsCollection::GetName(), and G4VHitsCollection::GetSDname().

◆ GetHCtable()

G4HCtable * G4SDManager::GetHCtable ( ) const
inline

◆ GetSDMpointer()

G4SDManager * G4SDManager::GetSDMpointer ( )
static

◆ GetSDMpointerIfExist()

G4SDManager * G4SDManager::GetSDMpointerIfExist ( )
static

◆ GetTreeTop()

G4SDStructure * G4SDManager::GetTreeTop ( ) const
inline

Definition at line 98 of file G4SDManager.hh.

98{ return treeTop; }

References treeTop.

◆ ListTree()

void G4SDManager::ListTree ( ) const
inline

Definition at line 99 of file G4SDManager.hh.

99{ treeTop->ListTree(); }

References G4SDStructure::ListTree(), and treeTop.

Referenced by G4SDmessenger::SetNewValue().

◆ operator=()

G4SDManager & G4SDManager::operator= ( const G4SDManager )
private

◆ PrepareNewEvent()

G4HCofThisEvent * G4SDManager::PrepareNewEvent ( )

◆ RegisterSDFilter()

void G4SDManager::RegisterSDFilter ( G4VSDFilter filter)

Definition at line 164 of file G4SDManager.cc.

165{
166 FilterList.push_back(filter);
167}

References FilterList.

Referenced by G4VSDFilter::G4VSDFilter().

◆ SetVerboseLevel()

void G4SDManager::SetVerboseLevel ( G4int  vl)
inline

Definition at line 93 of file G4SDManager.hh.

94 {
95 verboseLevel = vl;
97 }
void SetVerboseLevel(G4int vl)

References G4SDStructure::SetVerboseLevel(), treeTop, and verboseLevel.

Referenced by G4SDmessenger::SetNewValue().

◆ TerminateCurrentEvent()

void G4SDManager::TerminateCurrentEvent ( G4HCofThisEvent HCE)

Definition at line 120 of file G4SDManager.cc.

121{
122 treeTop->Terminate(HCE);
123}
void Terminate(G4HCofThisEvent *HCE)

References G4SDStructure::Terminate(), and treeTop.

Referenced by G4EventManager::DoProcessing().

Field Documentation

◆ FilterList

std::vector<G4VSDFilter*> G4SDManager::FilterList
private

Definition at line 114 of file G4SDManager.hh.

Referenced by DeRegisterSDFilter(), DestroyFilters(), and RegisterSDFilter().

◆ fSDManager

G4ThreadLocal G4SDManager * G4SDManager::fSDManager = nullptr
staticprivate

Definition at line 86 of file G4SDManager.hh.

Referenced by GetSDMpointer(), GetSDMpointerIfExist(), and ~G4SDManager().

◆ HCtable

G4HCtable* G4SDManager::HCtable
private

◆ theMessenger

G4SDmessenger* G4SDManager::theMessenger
private

Definition at line 90 of file G4SDManager.hh.

Referenced by G4SDManager(), and ~G4SDManager().

◆ treeTop

G4SDStructure* G4SDManager::treeTop
private

◆ verboseLevel

G4int G4SDManager::verboseLevel
private

Definition at line 88 of file G4SDManager.hh.

Referenced by AddNewCollection(), AddNewDetector(), DestroyFilters(), and SetVerboseLevel().


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