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 ////////////////////////////////////////////// 27 // File: CCalSensitiveConfiguration.cc 28 // Description: CCalSensitiveConfiguration han 29 // sensitive detectors and visibi 30 ////////////////////////////////////////////// 31 #include "CCalSensitiveConfiguration.hh" 32 33 #include <fstream> 34 #include <stdlib.h> 35 36 37 //Comment/Uncomment next line to hide/show deb 38 //#define debug 39 40 41 CCalSensitiveConfiguration * CCalSensitiveConf 42 43 CCalSensitiveConfiguration* CCalSensitiveConfi 44 { 45 if (!instance) 46 instance = new CCalSensitiveConfiguration; 47 return instance; 48 } 49 50 51 G4int CCalSensitiveConfiguration::getSensitive 52 { 53 G4int flag = -1; 54 auto it = theConfiguration.find(n); 55 56 if (it != theConfiguration.cend()) 57 flag = (*it).second.SensitiveFlag; 58 else { 59 G4cerr << "ERROR: In CCalSensitiveConfigur 60 << "G4String& n)" << G4endl 61 << " " << n << " not found in 62 } 63 64 return flag; 65 } 66 67 G4String CCalSensitiveConfiguration::getFileNa 68 { 69 G4String fn; 70 auto it = theConfiguration.find(n); 71 72 if (it != theConfiguration.cend()) 73 fn = (*it).second.FileName; 74 else { 75 G4cerr << "ERROR: In CCalSensitiveConfigur 76 << "G4String& n)" << G4endl 77 << " " << n << " not found in 78 } 79 80 return fn; 81 } 82 83 CCalSensitiveConfiguration::CCalSensitiveConfi 84 { 85 //////////////////////////////////////////// 86 // Open the file 87 G4String pathName = std::getenv("CCAL_CONFPA 88 G4String fileenv = std::getenv("CCAL_SENSIT 89 if (!pathName || !fileenv) { 90 G4ExceptionDescription ed; 91 ed << "ERROR: CCAL_SENSITIVECONF and/or CC 92 << " Set them to the sensitive co 93 G4Exception("CCalSensitiveConfiguration::C 94 "ccal005", 95 FatalException,ed); 96 } 97 98 G4cout << " ==> Opening file " << fileenv << 99 std::ifstream is; 100 G4bool ok = openGeomFile(is, pathName, filee 101 if (!ok) 102 { 103 G4Exception("CCalSensitiveConfiguration: 104 "ccal006", 105 FatalException, 106 "Unable to open sensitive in 107 } 108 109 110 111 G4String name; 112 GCInfo gcinfo; 113 114 while (is) { 115 readName(is, name); 116 readName(is, gcinfo.FileName); 117 is >> gcinfo.SensitiveFlag >> jump; 118 #ifdef debug 119 G4cout << "CCalSensitiveConfiguration cons 120 << "\" \"" << gcinfo.FileName << "\ 121 << G4endl; 122 #endif 123 theConfiguration[name] = gcinfo; 124 } 125 126 127 //////////////////////////////////////////// 128 // Close the file 129 is.close(); 130 G4cout << " <== Closed file " << fileenv << 131 } 132