Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/persistency/ascii/src/G4tgrLineProcessor.cc

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /persistency/ascii/src/G4tgrLineProcessor.cc (Version 11.3.0) and /persistency/ascii/src/G4tgrLineProcessor.cc (Version 11.1.3)


  1 //                                                  1 //
  2 // *******************************************      2 // ********************************************************************
  3 // * License and Disclaimer                         3 // * License and Disclaimer                                           *
  4 // *                                                4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of th      5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  6 // * the Geant4 Collaboration.  It is provided      6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  7 // * conditions of the Geant4 Software License      7 // * conditions of the Geant4 Software License,  included in the file *
  8 // * LICENSE and available at  http://cern.ch/      8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  9 // * include a list of copyright holders.           9 // * include a list of copyright holders.                             *
 10 // *                                               10 // *                                                                  *
 11 // * Neither the authors of this software syst     11 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing fin     12 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warran     13 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assum     14 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file      15 // * use.  Please see the license in the file  LICENSE  and URL above *
 16 // * for the full disclaimer and the limitatio     16 // * for the full disclaimer and the limitation of liability.         *
 17 // *                                               17 // *                                                                  *
 18 // * This  code  implementation is the result      18 // * This  code  implementation is the result of  the  scientific and *
 19 // * technical work of the GEANT4 collaboratio     19 // * technical work of the GEANT4 collaboration.                      *
 20 // * By using,  copying,  modifying or  distri     20 // * By using,  copying,  modifying or  distributing the software (or *
 21 // * any work based  on the software)  you  ag     21 // * any work based  on the software)  you  agree  to acknowledge its *
 22 // * use  in  resulting  scientific  publicati     22 // * use  in  resulting  scientific  publications,  and indicate your *
 23 // * acceptance of all terms of the Geant4 Sof     23 // * acceptance of all terms of the Geant4 Software license.          *
 24 // *******************************************     24 // ********************************************************************
 25 //                                                 25 //
 26 // G4tgrLineProcessor                              26 // G4tgrLineProcessor
 27 //                                                 27 //
 28 // Author: P.Arce, CIEMAT (November 2007)          28 // Author: P.Arce, CIEMAT (November 2007)
 29 // -------------------------------------------     29 // --------------------------------------------------------------------
 30                                                    30 
 31 #include "G4tgrLineProcessor.hh"                   31 #include "G4tgrLineProcessor.hh"
 32                                                    32 
 33 #include "G4SystemOfUnits.hh"                      33 #include "G4SystemOfUnits.hh"
 34 #include "G4tgrParameterMgr.hh"                    34 #include "G4tgrParameterMgr.hh"
 35 #include "G4tgrFileIn.hh"                          35 #include "G4tgrFileIn.hh"
 36 #include "G4tgrElementSimple.hh"                   36 #include "G4tgrElementSimple.hh"
 37 #include "G4tgrElementFromIsotopes.hh"             37 #include "G4tgrElementFromIsotopes.hh"
 38 #include "G4tgrVolume.hh"                          38 #include "G4tgrVolume.hh"
 39 #include "G4tgrVolumeDivision.hh"                  39 #include "G4tgrVolumeDivision.hh"
 40 #include "G4tgrVolumeAssembly.hh"                  40 #include "G4tgrVolumeAssembly.hh"
 41 #include "G4tgrPlaceDivRep.hh"                     41 #include "G4tgrPlaceDivRep.hh"
 42 #include "G4tgrPlaceParameterisation.hh"           42 #include "G4tgrPlaceParameterisation.hh"
 43 #include "G4tgrVolumeMgr.hh"                       43 #include "G4tgrVolumeMgr.hh"
 44 #include "G4tgrUtils.hh"                           44 #include "G4tgrUtils.hh"
 45 #include "G4tgrMaterialFactory.hh"                 45 #include "G4tgrMaterialFactory.hh"
 46 #include "G4tgrRotationMatrixFactory.hh"           46 #include "G4tgrRotationMatrixFactory.hh"
 47 #include "G4tgrMessenger.hh"                       47 #include "G4tgrMessenger.hh"
 48                                                    48 
 49 // -------------------------------------------     49 // --------------------------------------------------------------------
 50 G4tgrLineProcessor::G4tgrLineProcessor()           50 G4tgrLineProcessor::G4tgrLineProcessor()
 51 {                                                  51 {
 52   volmgr = G4tgrVolumeMgr::GetInstance();          52   volmgr = G4tgrVolumeMgr::GetInstance();
 53 }                                                  53 }
 54                                                    54 
 55 // -------------------------------------------     55 // --------------------------------------------------------------------
 56 G4tgrLineProcessor::~G4tgrLineProcessor()          56 G4tgrLineProcessor::~G4tgrLineProcessor()
 57 {                                                  57 {
 58 }                                                  58 }
 59                                                    59 
 60 // -------------------------------------------     60 // --------------------------------------------------------------------
 61 G4bool G4tgrLineProcessor::ProcessLine(const s     61 G4bool G4tgrLineProcessor::ProcessLine(const std::vector<G4String>& wl)
 62 {                                                  62 {
 63 #ifdef G4VERBOSE                                   63 #ifdef G4VERBOSE
 64   if(G4tgrMessenger::GetVerboseLevel() >= 1)       64   if(G4tgrMessenger::GetVerboseLevel() >= 1)
 65   {                                                65   {
 66     G4tgrUtils::DumpVS(wl, "@@@ Processing inp     66     G4tgrUtils::DumpVS(wl, "@@@ Processing input line");
 67   }                                                67   }
 68 #endif                                             68 #endif
 69                                                    69 
 70   G4String wl0 = wl[0];                            70   G4String wl0 = wl[0];
 71   for(G4int ii = 0; ii < (G4int)wl0.length();      71   for(G4int ii = 0; ii < (G4int)wl0.length(); ++ii)
 72   {                                                72   {
 73     wl0[ii] = (char)std::toupper(wl0[ii]);         73     wl0[ii] = (char)std::toupper(wl0[ii]);
 74   }                                                74   }
 75                                                    75 
 76   //------------------------------- parameter      76   //------------------------------- parameter number
 77   if(wl0 == ":P")                                  77   if(wl0 == ":P")
 78   {                                                78   {
 79     G4tgrParameterMgr::GetInstance()->AddParam     79     G4tgrParameterMgr::GetInstance()->AddParameterNumber(wl);
 80                                                    80 
 81     //------------------------------- paramete     81     //------------------------------- parameter string
 82   }                                                82   }
 83   else if(wl0 == ":PS")                            83   else if(wl0 == ":PS")
 84   {                                                84   {
 85     G4tgrParameterMgr::GetInstance()->AddParam     85     G4tgrParameterMgr::GetInstance()->AddParameterString(wl);
 86                                                    86 
 87     //------------------------------- isotope      87     //------------------------------- isotope
 88   }                                                88   }
 89   else if(wl0 == ":ISOT")                          89   else if(wl0 == ":ISOT")
 90   {                                                90   {
 91     G4tgrIsotope* isot = G4tgrMaterialFactory:     91     G4tgrIsotope* isot = G4tgrMaterialFactory::GetInstance()->AddIsotope(wl);
 92     volmgr->RegisterMe(isot);                      92     volmgr->RegisterMe(isot);
 93                                                    93 
 94     //------------------------------- element      94     //------------------------------- element
 95   }                                                95   }
 96   else if(wl0 == ":ELEM")                          96   else if(wl0 == ":ELEM")
 97   {                                                97   {
 98     G4tgrElementSimple* elem =                     98     G4tgrElementSimple* elem =
 99       G4tgrMaterialFactory::GetInstance()->Add     99       G4tgrMaterialFactory::GetInstance()->AddElementSimple(wl);
100     volmgr->RegisterMe(elem);                     100     volmgr->RegisterMe(elem);
101                                                   101 
102     //------------------------------- element     102     //------------------------------- element from isotopes
103   }                                               103   }
104   else if(wl0 == ":ELEM_FROM_ISOT")               104   else if(wl0 == ":ELEM_FROM_ISOT")
105   {                                               105   {
106     //:ELEM_FROM_ISOT NAME SYMBOL N_ISOT (ISOT    106     //:ELEM_FROM_ISOT NAME SYMBOL N_ISOT (ISOT_NAME ISOT_ABUNDANCE)
107     G4tgrElementFromIsotopes* elem =              107     G4tgrElementFromIsotopes* elem =
108       G4tgrMaterialFactory::GetInstance()->Add    108       G4tgrMaterialFactory::GetInstance()->AddElementFromIsotopes(wl);
109     volmgr->RegisterMe(elem);                     109     volmgr->RegisterMe(elem);
110                                                   110 
111     //------------------------------- material    111     //------------------------------- material
112   }                                               112   }
113   else if(wl0 == ":MATE")                         113   else if(wl0 == ":MATE")
114   {                                               114   {
115     G4tgrMaterialSimple* mate =                   115     G4tgrMaterialSimple* mate =
116       G4tgrMaterialFactory::GetInstance()->Add    116       G4tgrMaterialFactory::GetInstance()->AddMaterialSimple(wl);
117     volmgr->RegisterMe(mate);                     117     volmgr->RegisterMe(mate);
118                                                   118 
119     //------------------------------- material    119     //------------------------------- material mixtures & by weight
120   }                                               120   }
121   else if((wl0 == ":MIXT") || (wl0 == ":MIXT_B    121   else if((wl0 == ":MIXT") || (wl0 == ":MIXT_BY_WEIGHT"))
122   {                                               122   {
123     G4tgrMaterialMixture* mate =                  123     G4tgrMaterialMixture* mate =
124       G4tgrMaterialFactory::GetInstance()->Add    124       G4tgrMaterialFactory::GetInstance()->AddMaterialMixture(
125         wl, "MaterialMixtureByWeight");           125         wl, "MaterialMixtureByWeight");
126     volmgr->RegisterMe(mate);                     126     volmgr->RegisterMe(mate);
127                                                   127 
128     //------------------------------- material    128     //------------------------------- material mixture by number of atoms
129   }                                               129   }
130   else if(wl0 == ":MIXT_BY_NATOMS")               130   else if(wl0 == ":MIXT_BY_NATOMS")
131   {                                               131   {
132     G4tgrMaterialMixture* mate =                  132     G4tgrMaterialMixture* mate =
133       G4tgrMaterialFactory::GetInstance()->Add    133       G4tgrMaterialFactory::GetInstance()->AddMaterialMixture(
134         wl, "MaterialMixtureByNoAtoms");          134         wl, "MaterialMixtureByNoAtoms");
135     volmgr->RegisterMe(mate);                     135     volmgr->RegisterMe(mate);
136                                                   136 
137     //------------------------------- material    137     //------------------------------- material mixture by volume
138   }                                               138   }
139   else if(wl0 == ":MIXT_BY_VOLUME")               139   else if(wl0 == ":MIXT_BY_VOLUME")
140   {                                               140   {
141     G4tgrMaterialMixture* mate =                  141     G4tgrMaterialMixture* mate =
142       G4tgrMaterialFactory::GetInstance()->Add    142       G4tgrMaterialFactory::GetInstance()->AddMaterialMixture(
143         wl, "MaterialMixtureByVolume");           143         wl, "MaterialMixtureByVolume");
144     volmgr->RegisterMe(mate);                     144     volmgr->RegisterMe(mate);
145                                                   145 
146     //------------------------------- material    146     //------------------------------- material Mean Excitation Energy of
147     //                                Ionisati    147     //                                Ionisation Potential
148   }                                               148   }
149   else if(wl0 == ":MATE_MEE")                     149   else if(wl0 == ":MATE_MEE")
150   {                                               150   {
151     G4tgrMaterial* mate = G4tgrMaterialFactory    151     G4tgrMaterial* mate = G4tgrMaterialFactory::GetInstance()->FindMaterial(
152       G4tgrUtils::GetString(wl[1]));              152       G4tgrUtils::GetString(wl[1]));
153     if(mate == 0)                                 153     if(mate == 0)
154     {                                             154     {
155       G4Exception("G4tgrLineProcessor::Process    155       G4Exception("G4tgrLineProcessor::ProcessLine()", "Material not found",
156                   FatalException, G4tgrUtils::    156                   FatalException, G4tgrUtils::GetString(wl[1]));
157       return false;                               157       return false;
158     }                                             158     }
159     mate->SetIonisationMeanExcitationEnergy(G4    159     mate->SetIonisationMeanExcitationEnergy(G4tgrUtils::GetDouble(wl[2]));
160                                                   160 
161     //------------------------------- material    161     //------------------------------- material
162   }                                               162   }
163   else if(wl0 == ":MATE_STATE")                   163   else if(wl0 == ":MATE_STATE")
164   {                                               164   {
165     G4tgrMaterial* mate = G4tgrMaterialFactory    165     G4tgrMaterial* mate = G4tgrMaterialFactory::GetInstance()->FindMaterial(
166       G4tgrUtils::GetString(wl[1]));              166       G4tgrUtils::GetString(wl[1]));
167     if(mate == 0)                                 167     if(mate == 0)
168     {                                             168     {
169       G4Exception("G4tgrLineProcessor::Process    169       G4Exception("G4tgrLineProcessor::ProcessLine()", "Material not found",
170                   FatalException, wl[1]);         170                   FatalException, wl[1]);
171     }                                             171     }
172     mate->SetState(wl[2]);                        172     mate->SetState(wl[2]);
173                                                   173 
174     //------------------------------- material    174     //------------------------------- material
175   }                                               175   }
176   else if(wl0 == ":MATE_TEMPERATURE")             176   else if(wl0 == ":MATE_TEMPERATURE")
177   {                                               177   {
178     G4tgrMaterial* mate = G4tgrMaterialFactory    178     G4tgrMaterial* mate = G4tgrMaterialFactory::GetInstance()->FindMaterial(
179       G4tgrUtils::GetString(wl[1]));              179       G4tgrUtils::GetString(wl[1]));
180     if(mate == 0)                                 180     if(mate == 0)
181     {                                             181     {
182       G4Exception("G4tgrLineProcessor::Process    182       G4Exception("G4tgrLineProcessor::ProcessLine()", "Material not found",
183                   FatalException, wl[1]);         183                   FatalException, wl[1]);
184     }                                             184     }
185     mate->SetTemperature(G4tgrUtils::GetDouble    185     mate->SetTemperature(G4tgrUtils::GetDouble(wl[2], kelvin));
186                                                   186 
187     //------------------------------- material    187     //------------------------------- material
188   }                                               188   }
189   else if(wl0 == ":MATE_PRESSURE")                189   else if(wl0 == ":MATE_PRESSURE")
190   {                                               190   {
191     G4tgrMaterial* mate = G4tgrMaterialFactory    191     G4tgrMaterial* mate = G4tgrMaterialFactory::GetInstance()->FindMaterial(
192       G4tgrUtils::GetString(wl[1]));              192       G4tgrUtils::GetString(wl[1]));
193     if(mate == 0)                                 193     if(mate == 0)
194     {                                             194     {
195       G4Exception("G4tgrLineProcessor::Process    195       G4Exception("G4tgrLineProcessor::ProcessLine()", "Material not found",
196                   FatalException, wl[1]);         196                   FatalException, wl[1]);
197     }                                             197     }
198     mate->SetPressure(G4tgrUtils::GetDouble(wl    198     mate->SetPressure(G4tgrUtils::GetDouble(wl[2], atmosphere));
199                                                   199 
200     //------------------------------- solid       200     //------------------------------- solid
201   }                                               201   }
202   else if(wl0 == ":SOLID")                        202   else if(wl0 == ":SOLID")
203   {  // called from here or from G4tgrVolume::    203   {  // called from here or from G4tgrVolume::G4tgrVolume
204     volmgr->CreateSolid(wl, 0);                   204     volmgr->CreateSolid(wl, 0);
205                                                   205 
206     //------------------------------- volume      206     //------------------------------- volume
207   }                                               207   }
208   else if(wl0 == ":VOLU")                         208   else if(wl0 == ":VOLU")
209   {                                               209   {
210     G4tgrVolume* vol = new G4tgrVolume(wl);       210     G4tgrVolume* vol = new G4tgrVolume(wl);
211     volmgr->RegisterMe(vol);                      211     volmgr->RegisterMe(vol);
212                                                   212 
213     //--------------------------------- single    213     //--------------------------------- single placement
214   }                                               214   }
215   else if(wl0 == ":PLACE")                        215   else if(wl0 == ":PLACE")
216   {                                               216   {
217     G4tgrVolume* vol = FindVolume(G4tgrUtils::    217     G4tgrVolume* vol = FindVolume(G4tgrUtils::GetString(wl[1]));
218     G4tgrPlace* vpl  = vol->AddPlace(wl);         218     G4tgrPlace* vpl  = vol->AddPlace(wl);
219     volmgr->RegisterMe(vpl);                      219     volmgr->RegisterMe(vpl);
220                                                   220 
221     //--------------------------------- parame    221     //--------------------------------- parameterisation
222   }                                               222   }
223   else if(wl0 == ":PLACE_PARAM")                  223   else if(wl0 == ":PLACE_PARAM")
224   {                                               224   {
225     G4tgrVolume* vol                = FindVolu    225     G4tgrVolume* vol                = FindVolume(G4tgrUtils::GetString(wl[1]));
226     G4tgrPlaceParameterisation* vpl = vol->Add    226     G4tgrPlaceParameterisation* vpl = vol->AddPlaceParam(wl);
227     volmgr->RegisterMe(vpl);                      227     volmgr->RegisterMe(vpl);
228                                                   228 
229     //--------------------------------- divisi    229     //--------------------------------- division
230   }                                               230   }
231   else if((wl0 == ":DIV_NDIV") || (wl0 == ":DI    231   else if((wl0 == ":DIV_NDIV") || (wl0 == ":DIV_WIDTH") ||
232           (wl0 == ":DIV_NDIV_WIDTH"))             232           (wl0 == ":DIV_NDIV_WIDTH"))
233   {                                               233   {
234     //---------- Create G4tgrVolumeDivision an    234     //---------- Create G4tgrVolumeDivision and fill the volume params
235     G4tgrVolumeDivision* vol = new G4tgrVolume    235     G4tgrVolumeDivision* vol = new G4tgrVolumeDivision(wl);
236     volmgr->RegisterMe(vol);                      236     volmgr->RegisterMe(vol);
237                                                   237 
238     //--------------------------------- replic    238     //--------------------------------- replica
239   }                                               239   }
240   else if(wl0 == ":REPL")                         240   else if(wl0 == ":REPL")
241   {                                               241   {
242     G4tgrVolume* vol      = FindVolume(G4tgrUt    242     G4tgrVolume* vol      = FindVolume(G4tgrUtils::GetString(wl[1]));
243     G4tgrPlaceDivRep* vpl = vol->AddPlaceRepli    243     G4tgrPlaceDivRep* vpl = vol->AddPlaceReplica(wl);
244     volmgr->RegisterMe(vpl);                      244     volmgr->RegisterMe(vpl);
245                                                   245 
246     //----------------------------- assembly v    246     //----------------------------- assembly volume: definition of components
247   }                                               247   }
248   else if(wl0 == ":VOLU_ASSEMBLY")                248   else if(wl0 == ":VOLU_ASSEMBLY")
249   {                                               249   {
250     G4tgrVolumeAssembly* vol = new G4tgrVolume    250     G4tgrVolumeAssembly* vol = new G4tgrVolumeAssembly(wl);
251     volmgr->RegisterMe(vol);                      251     volmgr->RegisterMe(vol);
252                                                   252 
253     //----------------------------- assembly v    253     //----------------------------- assembly volume: definition of components
254   }                                               254   }
255   else if(wl0 == ":PLACE_ASSEMBLY")               255   else if(wl0 == ":PLACE_ASSEMBLY")
256   {                                               256   {
257     G4tgrVolume* vol = FindVolume(G4tgrUtils::    257     G4tgrVolume* vol = FindVolume(G4tgrUtils::GetString(wl[1]));
258     G4tgrPlace* vpl  = vol->AddPlace(wl);         258     G4tgrPlace* vpl  = vol->AddPlace(wl);
259     volmgr->RegisterMe(vpl);                      259     volmgr->RegisterMe(vpl);
260                                                   260 
261     //---------------------------------  rotat    261     //---------------------------------  rotation matrix
262   }                                               262   }
263   else if(wl0 == ":ROTM")                         263   else if(wl0 == ":ROTM")
264   {                                               264   {
265     //---------- When second word is ':NEXT/:M    265     //---------- When second word is ':NEXT/:MNXT' it is used for defining a
266     //           rotation matrix that will be     266     //           rotation matrix that will be used for the next placement/s
267     G4tgrRotationMatrix* rm =                     267     G4tgrRotationMatrix* rm =
268       G4tgrRotationMatrixFactory::GetInstance(    268       G4tgrRotationMatrixFactory::GetInstance()->AddRotMatrix(wl);
269     volmgr->RegisterMe(rm);                       269     volmgr->RegisterMe(rm);
270                                                   270 
271     //------------------------------- visualis    271     //------------------------------- visualisation
272   }                                               272   }
273   else if(wl0 == ":VIS")                          273   else if(wl0 == ":VIS")
274   {                                               274   {
275     std::vector<G4tgrVolume*> vols =              275     std::vector<G4tgrVolume*> vols =
276       volmgr->FindVolumes(G4tgrUtils::GetStrin    276       volmgr->FindVolumes(G4tgrUtils::GetString(wl[1]), 1);
277     for(std::size_t ii = 0; ii < vols.size();     277     for(std::size_t ii = 0; ii < vols.size(); ++ii)
278     {                                             278     {
279       vols[ii]->AddVisibility(wl);                279       vols[ii]->AddVisibility(wl);
280     }                                             280     }
281                                                   281 
282     //--------------------------------- colour    282     //--------------------------------- colour
283   }                                               283   }
284   else if((wl0 == ":COLOUR") || (wl0 == ":COLO    284   else if((wl0 == ":COLOUR") || (wl0 == ":COLOR"))
285   {                                               285   {
286     std::vector<G4tgrVolume*> vols =              286     std::vector<G4tgrVolume*> vols =
287       volmgr->FindVolumes(G4tgrUtils::GetStrin    287       volmgr->FindVolumes(G4tgrUtils::GetString(wl[1]), 1);
288     for(std::size_t ii = 0; ii < vols.size();     288     for(std::size_t ii = 0; ii < vols.size(); ++ii)
289     {                                             289     {
290       vols[ii]->AddRGBColour(wl);                 290       vols[ii]->AddRGBColour(wl);
291     }                                             291     }
292                                                   292 
293     //--------------------------------- check     293     //--------------------------------- check overlaps
294   }                                               294   }
295   else if(wl0 == ":CHECK_OVERLAPS")               295   else if(wl0 == ":CHECK_OVERLAPS")
296   {                                               296   {
297     std::vector<G4tgrVolume*> vols =              297     std::vector<G4tgrVolume*> vols =
298       volmgr->FindVolumes(G4tgrUtils::GetStrin    298       volmgr->FindVolumes(G4tgrUtils::GetString(wl[1]), 1);
299     for(std::size_t ii = 0; ii < vols.size();     299     for(std::size_t ii = 0; ii < vols.size(); ++ii)
300     {                                             300     {
301       vols[ii]->AddCheckOverlaps(wl);             301       vols[ii]->AddCheckOverlaps(wl);
302     }                                             302     }
303     //--------------------------------- ERROR     303     //--------------------------------- ERROR
304   }                                               304   }
305   else                                            305   else
306   {                                               306   {
307     return false;                                 307     return false;
308   }                                               308   }
309                                                   309 
310   return true;                                    310   return true;
311 }                                                 311 }
312                                                   312 
313 // -------------------------------------------    313 // --------------------------------------------------------------------
314 G4tgrVolume* G4tgrLineProcessor::FindVolume(co    314 G4tgrVolume* G4tgrLineProcessor::FindVolume(const G4String& volname)
315 {                                                 315 {
316   G4tgrVolume* vol = volmgr->FindVolume(volnam    316   G4tgrVolume* vol = volmgr->FindVolume(volname, 1);
317                                                   317 
318   if(vol->GetType() == "VOLDivision")             318   if(vol->GetType() == "VOLDivision")
319   {                                               319   {
320     G4Exception("G4tgrLineProcessor::FindVolum    320     G4Exception("G4tgrLineProcessor::FindVolume()", "InvalidSetup",
321                 FatalException,                   321                 FatalException,
322                 "Using 'PLACE' for a volume cr    322                 "Using 'PLACE' for a volume created by a division !");
323   }                                               323   }
324                                                   324 
325   return vol;                                     325   return vol;
326 }                                                 326 }
327                                                   327