Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4tgrFileReader.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// G4tgrFileReader implementation
27//
28// Author: P.Arce, CIEMAT (November 2007)
29// --------------------------------------------------------------------
30
31#include "G4tgrFileReader.hh"
32#include "G4tgrParameterMgr.hh"
33#include "G4tgrFileIn.hh"
34#include "G4tgrElementSimple.hh"
36#include "G4tgrVolume.hh"
37#include "G4tgrPlaceDivRep.hh"
40#include "G4tgrVolumeMgr.hh"
41#include "G4tgrUtils.hh"
44#include "G4tgrLineProcessor.hh"
45#include "G4tgrMessenger.hh"
46
47G4ThreadLocal G4tgrFileReader* G4tgrFileReader::theInstance = nullptr;
48
49// --------------------------------------------------------------------
51{
52 theLineProcessor = new G4tgrLineProcessor;
53}
54
55// --------------------------------------------------------------------
57{
58 delete theLineProcessor;
59 delete theInstance;
60}
61
62// --------------------------------------------------------------------
64{
65 if(theInstance == nullptr)
66 {
67 theInstance = new G4tgrFileReader;
68 }
69 return theInstance;
70}
71
72// --------------------------------------------------------------------
74{
75 std::vector<G4String> wl, wlnew;
76
77#ifdef G4VERBOSE
79 {
80 G4cout << " Number of geometry data files = " << theTextFiles.size()
81 << G4endl;
82 }
83#endif
84
85 if(theTextFiles.size() == 0)
86 {
87 G4Exception("G4tgrFileReader::ReadFiles()", "InvalidInput", FatalException,
88 "No files to read ...");
89 }
90
91 for(std::size_t ii = 0; ii < theTextFiles.size(); ++ii)
92 {
93#ifdef G4VERBOSE
95 {
96 G4cout << " Reading data file " << theTextFiles[ii] << G4endl;
97 }
98#endif
99
100 G4tgrFileIn fin = G4tgrFileIn::GetInstance(theTextFiles[ii]);
101
102 G4int nlines = 0;
103 for(;;)
104 {
105 ++nlines;
106 if(!fin.GetWordsInLine(wlnew))
107 {
108 break;
109 }
110 // Check if it is continuation line or first line
111 if(wlnew[0].c_str()[0] != ':')
112 {
113 wl.insert(wl.end(), wlnew.begin(), wlnew.end());
114#ifdef G4VERBOSE
116 {
117 G4tgrUtils::DumpVS(wl, "!!!! adding line");
118 }
119#endif
120 continue;
121 }
122 else
123 {
124 //----- Process previous tag
125#ifdef G4VERBOSE
127 {
128 G4tgrUtils::DumpVS(wl, "!!!! line read");
129 }
130#endif
131 if(nlines != 1) // first line has no previous tag
132 {
133 if(!theLineProcessor->ProcessLine(wl))
134 {
135 fin.DumpException("Tag not found: " + wl[0]);
136 }
137 }
138 wl = wlnew;
139 }
140 }
141
142 if(wl.size() != 0)
143 {
144 if(!theLineProcessor->ProcessLine(wl))
145 {
146 fin.DumpException("Tag not found: " + wl[0]);
147 }
148 }
149 }
150 return true;
151}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
Definition: G4Exception.cc:59
bool G4bool
Definition: G4Types.hh:86
int G4int
Definition: G4Types.hh:85
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
G4int GetWordsInLine(std::vector< G4String > &wl)
Definition: G4tgrFileIn.cc:137
static G4tgrFileIn & GetInstance(const G4String &name)
Definition: G4tgrFileIn.cc:68
void DumpException(const G4String &sent)
Definition: G4tgrFileIn.cc:434
virtual ~G4tgrFileReader()
static G4tgrFileReader * GetInstance()
virtual G4bool ProcessLine(const std::vector< G4String > &wl)
static G4int GetVerboseLevel()
static void DumpVS(const std::vector< G4String > &wl, const char *msg)
Definition: G4tgrUtils.cc:153
#define G4ThreadLocal
Definition: tls.hh:77