Geant4 Cross Reference |
1 // 1 2 // ******************************************* 3 // * License and Disclaimer 4 // * 5 // * The Geant4 software is copyright of th 6 // * the Geant4 Collaboration. It is provided 7 // * conditions of the Geant4 Software License 8 // * LICENSE and available at http://cern.ch/ 9 // * include a list of copyright holders. 10 // * 11 // * Neither the authors of this software syst 12 // * institutes,nor the agencies providing fin 13 // * work make any representation or warran 14 // * regarding this software system or assum 15 // * use. Please see the license in the file 16 // * for the full disclaimer and the limitatio 17 // * 18 // * This code implementation is the result 19 // * technical work of the GEANT4 collaboratio 20 // * By using, copying, modifying or distri 21 // * any work based on the software) you ag 22 // * use in resulting scientific publicati 23 // * acceptance of all terms of the Geant4 Sof 24 // ******************************************* 25 // 26 // G4CrossSectionFactoryRegistry class 27 // 28 // History: 29 // 1-Apr-2013: A. Dotti, first implementation 30 #include "G4CrossSectionFactoryRegistry.hh" 31 #include "G4CrossSectionFactory.hh" 32 #include "G4AutoLock.hh" 33 #include "globals.hh" 34 35 //This is used to lock on shared resource 36 // G4TypeMutex<G4CrossSectionFactoryRegistry>( 37 38 G4CrossSectionFactoryRegistry* G4CrossSectionF 39 G4CrossSectionFactoryRegistry* G4CrossSectionF 40 { 41 G4AutoLock l(G4TypeMutex<G4CrossSectionFacto 42 if (!instance) 43 new G4CrossSectionFactoryRegistry(); 44 return instance; 45 } 46 47 G4CrossSectionFactoryRegistry::G4CrossSectionF 48 { 49 instance = this; 50 } 51 52 G4CrossSectionFactoryRegistry::G4CrossSectionF 53 { 54 G4Exception("G4CrossSectionFactoryRegistry 55 "CrossSection004",FatalExcepti 56 } 57 G4CrossSectionFactoryRegistry& G4CrossSectionF 58 { 59 G4Exception("G4CrossSectionFactoryRegistry 60 "CrossSection004",FatalExcepti 61 return *this; 62 } 63 64 void G4CrossSectionFactoryRegistry::Register( 65 { 66 G4AutoLock l(G4TypeMutex<G4CrossSectionFacto 67 if ( factories.find(name) != factories.end 68 { 69 G4ExceptionDescription msg; 70 msg <<"Cross section factory with name 71 <<" already existing, old factory 72 G4Exception("G4CrossSectionFactoryRegi 73 "CrossSection002",JustWarn 74 } 75 factories[name] = factory; 76 } 77 78 G4VBaseXSFactory* G4CrossSectionFactoryRegistr 79 { 80 G4AutoLock l(G4TypeMutex<G4CrossSectionFacto 81 std::map<G4String,G4VBaseXSFactory*>::cons 82 if ( it != factories.end() ) return it->se 83 else 84 { 85 if ( abortIfNotFound ) 86 { 87 G4ExceptionDescription msg; 88 msg <<"Cross section factory with 89 <<" not found."; 90 G4Exception("G4CrossSectionFactory 91 "CrossSection003",Fata 92 } 93 } 94 return static_cast<G4VBaseXSFactory*>(0); 95 } 96 97 98 std::ostream& operator<<(std::ostream& msg, c 99 msg<<"Factory Registry "<<&rhs<<" has fact 100 for ( std::map<G4String,G4VBaseXSFactory*> 101 it != rhs.factories.end() ; ++it ) 102 { 103 msg<<(*it).first<<":"<<(*it).second<<" 104 } 105 msg<<"]"; 106 return msg; 107 } 108