5 #include <TGeoManager.h>
24 #include <sys/types.h>
41 PHGeomTGeo *dst_geom = GetGeomTGeoNode(topNode,
true);
44 cout << __PRETTY_FUNCTION__
45 <<
" - Error - Can NOT construct geometry node." << endl;
53 dst_geom = LoadFromIONode(topNode);
56 UpdateIONode(topNode);
63 const std::string & geometry_file)
65 TGeoManager * tgeo = GetTGeoManager(topNode);
69 tgeo->Export(geometry_file.c_str());
74 const std::string & geometry_file)
76 PHGeomTGeo *dst_geom = GetGeomTGeoNode(topNode);
81 TGeoManager::SetVerboseLevel(GetVerbosity());
82 dst_geom->
SetGeometry(TGeoManager::Import(geometry_file.c_str()));
86 cout << __PRETTY_FUNCTION__ <<
"failed to import " << geometry_file
91 UpdateIONode(topNode);
99 PHGeomTGeo *dst_geom = GetGeomTGeoNode(topNode);
105 assert(not dst_geom->
isValid());
107 TGeoManager::SetVerboseLevel(GetVerbosity());
120 "PHCompositeNode",
"PAR"));
124 serr << __PRETTY_FUNCTION__ <<
": PAR Node missing, request aborting.";
125 cout << serr.str() << endl;
127 throw runtime_error(serr.str());
132 PHGeomTGeo *dst_geom = findNode::getClass<PHGeomTGeo>(parNode,
134 if (!dst_geom and build_new)
138 GetDSTNodeName(),
"PHObject");
153 "PHCompositeNode",
"RUN"));
157 serr << __PRETTY_FUNCTION__ <<
": RUN Node missing, request aborting.";
158 cout << serr.str() << endl;
160 throw runtime_error(serr.str());
165 PHGeomIOTGeo *dst_geom = findNode::getClass<PHGeomIOTGeo>(runNode,
167 if (!dst_geom and build_new)
171 GetDSTIONodeName(),
"PHObject");
182 file <<
"/tmp/" <<
"PHGeomUtility_geom_file_" << ::getpid() <<
"."
183 << filename_extension ;
192 fstream ifile(file_name, ios_base::in);
197 if (remove(file_name.c_str()) != 0)
199 cout << __PRETTY_FUNCTION__ <<
" - Error - can not remove file "
200 << file_name << endl;
216 PHGeomTGeo *dst_geom = GetGeomTGeoNode(topNode,
false);
220 cout << __PRETTY_FUNCTION__
221 <<
" - ERROR - failed to update PHGeomIOTGeo node RUN/GEOMETRY_IO due to missing PHGeomTGeo node at RUN/GEOMETRY"
227 cout << __PRETTY_FUNCTION__
228 <<
" - ERROR - failed to update PHGeomIOTGeo node RUN/GEOMETRY_IO due to invalid PHGeomTGeo node at RUN/GEOMETRY"
233 PHGeomIOTGeo *dst_geom_io = GetGeomIOTGeoNode(topNode,
true);
246 PHGeomIOTGeo *dst_geom_io = GetGeomIOTGeoNode(topNode,
false);
250 cout << __PRETTY_FUNCTION__
251 <<
" - ERROR - failed to update PHGeomTGeo node RUN/GEOMETRY due to missing PHGeomIOTGeo node at RUN/GEOMETRY_IO"
255 if (not dst_geom_io->
isValid())
257 cout << __PRETTY_FUNCTION__
258 <<
" - ERROR - failed to update PHGeomTGeo node RUN/GEOMETRY due to invalid PHGeomIOTGeo node at RUN/GEOMETRY_IO"
265 TGeoManager::SetVerboseLevel(GetVerbosity());
267 tgeo->CloseGeometry();
269 PHGeomTGeo *dst_geom = GetGeomTGeoNode(topNode,
true);
290 if (rc->
FlagExist(
"PHGEOMETRY_VERBOSITY"))
PHBoolean addNode(PHNode *)
virtual int FlagExist(const std::string &name) const
virtual void set_IntFlag(const std::string &name, const int flag)
virtual int get_IntFlag(const std::string &name) const
PHGeomIOTGeo store geometry information to DST files in the format of binary streamed TGeoVolume....
TGeoManager * ConstructTGeoManager()
Construct TGeoManager. The result TGeoManager is not yet closed and open for further editing.
virtual int isValid() const
isValid returns non zero if object contains vailid data
void SetGeometry(const TGeoVolume *g)
PHGeomIOTGeo do NOT own this TGeoVolume * g. Internally, it will use g to make a copy which PHGeomIOT...
PHGeomTGeo provide run-time access to TGeoManger. It is transient object and it shall NOT be saved to...
TGeoManager * GetGeometry()
virtual int isValid() const
isValid returns non zero if object contains vailid data
void SetGeometry(TGeoManager *g)
virtual void Reset()
Clear Event.
static PHGeomIOTGeo * UpdateIONode(PHCompositeNode *topNode)
static std::string GenerateGeometryFileName(const std::string &filename_extension="gdml")
static int ImportGeomFile(PHCompositeNode *topNode, const std::string &geometry_file)
TGeo ROOT/GDML/Macro file -> DST node with automatic file type discrimination based on file names.
static PHGeomIOTGeo * GetGeomIOTGeoNode(PHCompositeNode *topNode, bool build_new=true)
Get persistent PHGeomIOTGeo from DST nodes. If not found, make a new one.
static int GetVerbosity()
Verbosity for geometry IO like, TGeoMangers.
static PHGeomTGeo * GetGeomTGeoNode(PHCompositeNode *topNode, bool build_new=true)
Get non-persistent PHGeomTGeo from DST nodes. If not found, make a new one.
static TGeoManager * GetTGeoManager(PHCompositeNode *topNode)
Main user interface: DST node -> TGeoManager for downstream use.
static void ExportGeomtry(PHCompositeNode *topNode, const std::string &geometry_file)
DST node -> TGeoManager -> export files, like gdml, .root or .C formats.
static void SetVerbosity(int v)
Verbosity for geometry IO like, TGeoMangers.
static int ImportCurrentTGeoManager(PHCompositeNode *topNode)
gGeoManager -> DST node
static PHGeomTGeo * LoadFromIONode(PHCompositeNode *topNode)
static bool RemoveGeometryFile(const std::string &file_name)
delete the geometry file after use
PHNode * findFirst(const std::string &, const std::string &)
static recoConsts * instance()