Geant4-11
G4HadronicInteractionRegistry.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// 23-Jan-2009 V.Ivanchenko make the class to be a singleton
28// 17-Aug-2012 V.Ivanchenko added methods
29
32
35
37{
38 if(nullptr == instance) {
40 instance = inst.Instance();
41 }
42 return instance;
43}
44
46{}
47
49{
50 Clean();
51}
52
54{
55 size_t nModels = allModels.size();
56 //G4cout << "G4HadronicInteractionRegistry::Clean() start " << nModels
57 // << " " << this << G4endl;
58 for (size_t i=0; i<nModels; ++i) {
59 if( allModels[i] ) {
60 //const char* xxx = (allModels[i]->GetModelName()).c_str();
61 //G4int len = (allModels[i]->GetModelName()).length();
62 //len = std::min(len, 9);
63 //const G4String mname = G4String(xxx, len);
64 //G4cout << "G4HadronicInteractionRegistry: delete " << i << " "
65 // << allModels[i] << " " << mname
66 // << " " << this << G4endl;
67 //if(mname != "NeutronHP" && mname != "ParticleH")
68 delete allModels[i];
69 // G4cout << "done " << this << G4endl;
70 }
71 }
72 allModels.clear();
73 //G4cout <<"G4HadronicInteractionRegistry::Clean() is done "<<G4endl;
74}
75
77{
78 for (auto & mod : allModels) {
79 if( mod ) { mod->InitialiseModel(); }
80 }
81}
82
83void
85{
86 if(!aModel) { return; }
87 for (auto & mod : allModels) {
88 if( aModel == mod ) { return; }
89 }
90 //G4cout << "Register model <" << aModel->GetModelName()
91 // << "> " << nModels+1 << " " << aModel << G4endl;
92 allModels.push_back(aModel);
93}
94
95void
97{
98 if(!aModel) { return; }
99 for (size_t i=0; i<allModels.size(); ++i) {
100 if( aModel == allModels[i] ) {
101 //G4cout << "DeRegister model <" << aModel
102 // << "> " << i << G4endl;
103 allModels[i] = nullptr;
104 return;
105 }
106 }
107}
108
111{
112 G4HadronicInteraction* model = nullptr;
113 for (auto & mod : allModels) {
114 if(mod && mod->GetModelName() == name) {
115 model = mod;
116 break;
117 }
118 }
119 return model;
120}
121
122std::vector<G4HadronicInteraction*>
124{
125 std::vector<G4HadronicInteraction*> models;
126 for (auto & mod : allModels) {
127 if(mod && mod->GetModelName() == name) {
128 models.push_back(mod);
129 }
130 }
131 return models;
132}
void RegisterMe(G4HadronicInteraction *aModel)
std::vector< G4HadronicInteraction * > FindAllModels(const G4String &name)
std::vector< G4HadronicInteraction * > allModels
void RemoveMe(G4HadronicInteraction *aModel)
G4HadronicInteraction * FindModel(const G4String &name)
static G4HadronicInteractionRegistry * Instance()
static G4ThreadLocal G4HadronicInteractionRegistry * instance
const char * name(G4int ptype)
#define G4ThreadLocal
Definition: tls.hh:77