41 if (fSDManager ==
nullptr) {
63 theMessenger =
nullptr;
73 if (pathName[0] !=
'/') pathName.insert(0,
"/");
74 if (pathName.back() !=
'/') pathName +=
"/";
75 treeTop->AddNewDetector(aSD, pathName);
76 if (numberOfCollections < 1)
return;
77 for (
G4int i = 0; i < numberOfCollections; i++) {
82 if (verboseLevel > 0) {
83 G4cout <<
"New sensitive detector <" << aSD->
GetName() <<
"> is registered at " << pathName
90 G4int i = HCtable->Registor(SDname, DCname);
91 if (verboseLevel > 0) {
94 G4cout <<
"G4SDManager::AddNewCollection : the collection <" << SDname <<
"/" << DCname
95 <<
"> has already been reginstered." <<
G4endl;
98 G4cout <<
"G4SDManager::AddNewCollection : the collection <" << SDname <<
"/" << DCname
99 <<
"> is registered at " << i <<
G4endl;
107 treeTop->Initialize(HCE);
116 if (pathName[0] !=
'/') pathName.insert(0,
"/");
117 treeTop->Activate(pathName, activeFlag);
123 if (pathName[0] !=
'/') pathName.insert(0,
"/");
124 return treeTop->FindSensitiveDetector(pathName, warning);
129 G4int id = HCtable->GetCollectionID(colName);
131 G4cout <<
"<" << colName <<
"> is not found." <<
G4endl;
134 G4cout <<
"<" << colName <<
"> is ambiguous." <<
G4endl;
151 for (
auto f = FilterList.begin(); f != FilterList.end(); f++) {
159void G4SDManager::DestroyFilters()
161 auto f = FilterList.begin();
162 while (f != FilterList.end()) {
163 if (verboseLevel > 0)
G4cout <<
"### deleting " << (*f)->GetName() <<
" " << (*f) <<
G4endl;
165 f = FilterList.begin();
G4GLOB_DLL std::ostream G4cout
void RegisterSDFilter(G4VSDFilter *filter)
static G4SDManager * GetSDMpointer()
void TerminateCurrentEvent(G4HCofThisEvent *HCE)
G4SDManager(const G4SDManager &)=delete
G4HCofThisEvent * PrepareNewEvent()
G4VSensitiveDetector * FindSensitiveDetector(const G4String &dName, G4bool warning=true)
G4int GetCollectionID(const G4String &colName)
void AddNewDetector(G4VSensitiveDetector *aSD)
void DeRegisterSDFilter(G4VSDFilter *filter)
void AddNewCollection(const G4String &SDname, const G4String &DCname)
static G4SDManager * GetSDMpointerIfExist()
void Activate(const G4String &dName, G4bool activeFlag)
const G4String & GetSDname() const
const G4String & GetName() const
const G4String & GetCollectionName(G4int id) const
G4int GetNumberOfCollections() const
const G4String & GetName() const
const G4String & GetPathName() const