Geant4 11.2.2
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4HCtable.cc
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26//
27//
28
29#include "G4HCtable.hh"
30
32
34{
35 for (std::size_t i = 0; i < HClist.size(); ++i) {
36 if (HClist[i] == HCname && SDlist[i] == SDname) return -1;
37 }
38 HClist.push_back(HCname);
39 SDlist.push_back(SDname);
40 return (G4int)HClist.size();
41}
42
44{
45 G4int i = -1;
46 if (HCname.find('/') == std::string::npos) // HCname only
47 {
48 for (std::size_t j = 0; j < HClist.size(); ++j) {
49 if (HClist[j] == HCname) {
50 if (i >= 0) return -2;
51 i = (G4int)j;
52 }
53 }
54 }
55 else {
56 for (std::size_t j = 0; j < HClist.size(); ++j) {
57 G4String tgt = SDlist[j];
58 tgt += "/";
59 tgt += HClist[j];
60 if (tgt == HCname) {
61 if (i >= 0) return -2;
62 i = (G4int)j;
63 }
64 }
65 }
66 return i;
67}
68
70{
71 if (aSD->GetNumberOfCollections() < 1) {
72 G4cerr << "Sensitive detector <" << aSD->GetName()
73 << "> does not have a registered hits collection." << G4endl;
74 return -1;
75 }
76 if (aSD->GetNumberOfCollections() > 1) {
77 G4cerr << "Sensitive detector <" << aSD->GetName()
78 << "> has more than one registered hits collections." << G4endl;
79 G4cerr << "Candidates are : ";
80 for (G4int j = 0; j < aSD->GetNumberOfCollections(); ++j) {
81 G4cerr << aSD->GetCollectionName(j) << " ";
82 }
83 G4cerr << G4endl;
84 return -1;
85 }
86 for (std::size_t k = 0; k < SDlist.size(); ++k) {
87 if (SDlist[k] == aSD->GetName()) return (G4int)k;
88 }
89 return -1;
90}
int G4int
Definition G4Types.hh:85
G4GLOB_DLL std::ostream G4cerr
#define G4endl
Definition G4ios.hh:67
G4int Registor(G4String SDname, G4String HCname)
Definition G4HCtable.cc:33
G4int GetCollectionID(G4String HCname) const
Definition G4HCtable.cc:43
G4String GetCollectionName(G4int id) const