22 #include <Geant4/G4VPhysicalVolume.hh>
34 PHG4GDMLUtility::PHG4GDMLUtility()
41 if (topNode ==
nullptr)
50 GetOrMakeConfigNode(topNode);
55 assert(vol->GetLogicalVolume());
57 xercesc::XMLPlatformUtils::Initialize();
58 gdml_parser.
Write(filename, vol->GetLogicalVolume(),get_PHG4GDML_Schema(), 0,
true);
59 xercesc::XMLPlatformUtils::Terminate();
69 "PHCompositeNode",
"PAR"));
73 serr << __PRETTY_FUNCTION__ <<
": PAR Node missing, request aborting.";
74 cout << serr.str() << endl;
76 throw runtime_error(serr.str());
81 PHG4GDMLConfig *config = findNode::getClass<PHG4GDMLConfig>(parNode,
83 if (!config and build_new)
87 getDSTNodeName(),
"PHObject");
static Fun4AllServer * instance()
PHCompositeNode * topNode() const
PHBoolean addNode(PHNode *)
static PHG4GDMLConfig * GetOrMakeConfigNode(PHCompositeNode *topNode, bool build_new=true)
Get or make the parameter node PHG4GDMLConfig from DST nodes. If not found, make a new one.
static void Dump_GDML(const std::string &filename, G4VPhysicalVolume *vol, PHCompositeNode *topNode=nullptr)
save the current Geant4 geometry to GDML file. Reading PHG4GDMLConfig from topNode
virtual ~PHG4GDMLUtility()
G4Transform3D Write(const G4String &filename, const G4LogicalVolume *const topLog, const G4String &schemaPath, const G4int depth, G4bool storeReferences=true)
PHNode * findFirst(const std::string &, const std::string &)