173{
174
175
176
180 if((volMat == nullptr) && fInMassGeometry)
181 {
182 std::ostringstream message;
183 message <<
"Logical volume <" << lv->
GetName() <<
">" <<
G4endl
184 <<
"does not have a valid material pointer." <<
G4endl
185 << "A logical volume belonging to the (tracking) world volume "
186 << "must have a valid material.";
187 G4Exception(
"G4Region::ScanVolumeTree()",
"GeomMgt0002",
189 }
190 if (region)
191 {
192 currentRegion = this;
193 if (volMat != nullptr)
194 {
195 AddMaterial(volMat);
197 if (baseMat != nullptr) { AddMaterial(baseMat); }
198 }
199 }
200
201
202
203
205
206
207
208 if(noDaughters==0) return;
209
210 G4VPhysicalVolume* daughterPVol = lv->
GetDaughter(0);
212 {
213
214
215
217
219 {
221 for (std::size_t mat=0; mat<matNo; ++mat)
222 {
224 if((volMat == nullptr) && fInMassGeometry)
225 {
226 std::ostringstream message;
227 message << "The parameterisation for the physical volume <"
229 <<
"does not return a valid material pointer." <<
G4endl
230 << "A volume belonging to the (tracking) world volume must "
231 << "have a valid material.";
232 G4Exception(
"G4Region::ScanVolumeTree()",
"GeomMgt0002",
234 }
235 if (volMat != nullptr)
236 {
237 AddMaterial(volMat);
239 if (baseMat != nullptr) { AddMaterial(baseMat); }
240 }
241 }
242 }
243 else
244 {
246 for (std::size_t rep=0; rep<repNo; ++rep)
247 {
249 if((volMat == nullptr) && fInMassGeometry)
250 {
251 std::ostringstream message;
252 message << "The parameterisation for the physical volume <"
254 <<
"does not return a valid material pointer." <<
G4endl
255 << "A volume belonging to the (tracking) world volume must "
256 << "have a valid material.";
257 G4Exception(
"G4Region::ScanVolumeTree()",
"GeomMgt0002",
259 }
260 if(volMat != nullptr)
261 {
262 AddMaterial(volMat);
264 if (baseMat != nullptr) { AddMaterial(baseMat); }
265 }
266 }
267 }
270 }
271 else
272 {
273 for (std::size_t i=0; i<noDaughters; ++i)
274 {
277 {
278
279
280
282 }
283 }
284 }
285}
void SetRegion(G4Region *reg)
G4Material * GetMaterial() const
const G4Material * GetBaseMaterial() const
virtual G4VVolumeMaterialScanner * GetMaterialScanner()
virtual G4Material * ComputeMaterial(const G4int repNo, G4VPhysicalVolume *currentVol, const G4VTouchable *parentTouch=nullptr)
virtual G4int GetMultiplicity() const
const G4String & GetName() const
virtual G4VPVParameterisation * GetParameterisation() const =0
virtual G4bool IsParameterised() const =0
virtual G4Material * GetMaterial(G4int idx) const =0
virtual G4int GetNumberOfMaterials() const =0