This class contains the implementation of the GDML parser associated to all the supported GDML elements.
User should never need to explicitly instaciate this class. It is internally used by the TGeoManager.
Each element process has a 'Binding' to ROOT. The 'binding' is specific mapping of GDML elements (materials, solids, etc) to specific objects which should be instanciated by the converted. In the present case (ROOT) the binding is implemented at the near the end of each process function. Most bindings follow similar format, dependent on what is being added to the geometry.
This file also contains the implementation of the TGDMLRefl class. This is just a small helper class used internally by the 'reflection' method (for reflected solids).
The presently supported list of TGeo classes is the following:
When most solids or volumes are added to the geometry they
Whenever a new element is added to GDML schema, this class needs to be extended. The appropriate method (process) needs to be implemented, as well as the new element process then needs to be linked thru the function TGDMLParse
For any question or remarks concerning this code, please send an email to ben.l.nosp@m.loyd.nosp@m.@cern.nosp@m..ch
Definition at line 95 of file TGDMLParse.h.
Public Member Functions | |
TGDMLParse () | |
Constructor. | |
virtual | ~TGDMLParse () |
TGeoVolume * | GDMLReadFile (const char *filename="test.gdml") |
Creates the new instance of the XMLEngine called 'gdml', using the filename >> then parses the file and creates the DOM tree. | |
Public Member Functions inherited from TObject | |
TObject () | |
TObject constructor. | |
TObject (const TObject &object) | |
TObject copy ctor. | |
virtual | ~TObject () |
TObject destructor. | |
void | AbstractMethod (const char *method) const |
Use this method to implement an "abstract" method that you don't want to leave purely abstract. | |
virtual void | AppendPad (Option_t *option="") |
Append graphics object to current pad. | |
virtual void | Browse (TBrowser *b) |
Browse object. May be overridden for another default action. | |
ULong_t | CheckedHash () |
Check and record whether this class has a consistent Hash/RecursiveRemove setup (*) and then return the regular Hash value for this object. | |
virtual const char * | ClassName () const |
Returns name of class to which the object belongs. | |
virtual void | Clear (Option_t *="") |
virtual TObject * | Clone (const char *newname="") const |
Make a clone of an object using the Streamer facility. | |
virtual Int_t | Compare (const TObject *obj) const |
Compare abstract method. | |
virtual void | Copy (TObject &object) const |
Copy this to obj. | |
virtual void | Delete (Option_t *option="") |
Delete this object. | |
virtual Int_t | DistancetoPrimitive (Int_t px, Int_t py) |
Computes distance from point (px,py) to the object. | |
virtual void | Draw (Option_t *option="") |
Default Draw method for all objects. | |
virtual void | DrawClass () const |
Draw class inheritance tree of the class to which this object belongs. | |
virtual TObject * | DrawClone (Option_t *option="") const |
Draw a clone of this object in the current selected pad for instance with: gROOT->SetSelectedPad(gPad) . | |
virtual void | Dump () const |
Dump contents of object on stdout. | |
virtual void | Error (const char *method, const char *msgfmt,...) const |
Issue error message. | |
virtual void | Execute (const char *method, const char *params, Int_t *error=0) |
Execute method on this object with the given parameter string, e.g. | |
virtual void | Execute (TMethod *method, TObjArray *params, Int_t *error=0) |
Execute method on this object with parameters stored in the TObjArray. | |
virtual void | ExecuteEvent (Int_t event, Int_t px, Int_t py) |
Execute action corresponding to an event at (px,py). | |
virtual void | Fatal (const char *method, const char *msgfmt,...) const |
Issue fatal error message. | |
virtual TObject * | FindObject (const char *name) const |
Must be redefined in derived classes. | |
virtual TObject * | FindObject (const TObject *obj) const |
Must be redefined in derived classes. | |
virtual Option_t * | GetDrawOption () const |
Get option used by the graphics system to draw this object. | |
virtual const char * | GetIconName () const |
Returns mime type name of object. | |
virtual const char * | GetName () const |
Returns name of object. | |
virtual char * | GetObjectInfo (Int_t px, Int_t py) const |
Returns string containing info about the object at position (px,py). | |
virtual Option_t * | GetOption () const |
virtual const char * | GetTitle () const |
Returns title of object. | |
virtual UInt_t | GetUniqueID () const |
Return the unique object id. | |
virtual Bool_t | HandleTimer (TTimer *timer) |
Execute action in response of a timer timing out. | |
virtual ULong_t | Hash () const |
Return hash value for this object. | |
Bool_t | HasInconsistentHash () const |
Return true is the type of this object is known to have an inconsistent setup for Hash and RecursiveRemove (i.e. | |
virtual void | Info (const char *method, const char *msgfmt,...) const |
Issue info message. | |
virtual Bool_t | InheritsFrom (const char *classname) const |
Returns kTRUE if object inherits from class "classname". | |
virtual Bool_t | InheritsFrom (const TClass *cl) const |
Returns kTRUE if object inherits from TClass cl. | |
virtual void | Inspect () const |
Dump contents of this object in a graphics canvas. | |
void | InvertBit (UInt_t f) |
Bool_t | IsDestructed () const |
IsDestructed. | |
virtual Bool_t | IsEqual (const TObject *obj) const |
Default equal comparison (objects are equal if they have the same address in memory). | |
virtual Bool_t | IsFolder () const |
Returns kTRUE in case object contains browsable objects (like containers or lists of other objects). | |
R__ALWAYS_INLINE Bool_t | IsOnHeap () const |
virtual Bool_t | IsSortable () const |
R__ALWAYS_INLINE Bool_t | IsZombie () const |
virtual void | ls (Option_t *option="") const |
The ls function lists the contents of a class on stdout. | |
void | MayNotUse (const char *method) const |
Use this method to signal that a method (defined in a base class) may not be called in a derived class (in principle against good design since a child class should not provide less functionality than its parent, however, sometimes it is necessary). | |
virtual Bool_t | Notify () |
This method must be overridden to handle object notification. | |
void | Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const |
Use this method to declare a method obsolete. | |
void | operator delete (void *ptr) |
Operator delete. | |
void | operator delete[] (void *ptr) |
Operator delete []. | |
void * | operator new (size_t sz) |
void * | operator new (size_t sz, void *vp) |
void * | operator new[] (size_t sz) |
void * | operator new[] (size_t sz, void *vp) |
TObject & | operator= (const TObject &rhs) |
TObject assignment operator. | |
virtual void | Paint (Option_t *option="") |
This method must be overridden if a class wants to paint itself. | |
virtual void | Pop () |
Pop on object drawn in a pad to the top of the display list. | |
virtual void | Print (Option_t *option="") const |
This method must be overridden when a class wants to print itself. | |
virtual Int_t | Read (const char *name) |
Read contents of object with specified name from the current directory. | |
virtual void | RecursiveRemove (TObject *obj) |
Recursively remove this object from a list. | |
void | ResetBit (UInt_t f) |
virtual void | SaveAs (const char *filename="", Option_t *option="") const |
Save this object in the file specified by filename. | |
virtual void | SavePrimitive (std::ostream &out, Option_t *option="") |
Save a primitive as a C++ statement(s) on output stream "out". | |
void | SetBit (UInt_t f) |
void | SetBit (UInt_t f, Bool_t set) |
Set or unset the user status bits as specified in f. | |
virtual void | SetDrawOption (Option_t *option="") |
Set drawing option for object. | |
virtual void | SetUniqueID (UInt_t uid) |
Set the unique object id. | |
virtual void | SysError (const char *method, const char *msgfmt,...) const |
Issue system error message. | |
R__ALWAYS_INLINE Bool_t | TestBit (UInt_t f) const |
Int_t | TestBits (UInt_t f) const |
virtual void | UseCurrentStyle () |
Set current style settings in this object This function is called when either TCanvas::UseCurrentStyle or TROOT::ForceStyle have been invoked. | |
virtual void | Warning (const char *method, const char *msgfmt,...) const |
Issue warning message. | |
virtual Int_t | Write (const char *name=0, Int_t option=0, Int_t bufsize=0) |
Write this object to the current directory. | |
virtual Int_t | Write (const char *name=0, Int_t option=0, Int_t bufsize=0) const |
Write this object to the current directory. | |
Static Public Member Functions | |
static TGeoVolume * | StartGDML (const char *filename) |
Static Public Member Functions inherited from TObject | |
static Longptr_t | GetDtorOnly () |
Return destructor only flag. | |
static Bool_t | GetObjectStat () |
Get status of object stat flag. | |
static void | SetDtorOnly (void *obj) |
Set destructor only flag. | |
static void | SetObjectStat (Bool_t stat) |
Turn on/off tracking of objects in the TObjectTable. | |
Public Attributes | |
const char * | fCurrentFile |
std::string | fDefault_aunit = "rad" |
std::string | fDefault_lunit = "mm" |
TXMLEngine * | fFileEngine [20] |
int | fFILENO |
const char * | fStartFile |
int | fVolID |
TGeoVolume * | fWorld |
TString | fWorldName |
Private Types | |
typedef std::map< std::string, double > | ConstMap |
typedef TGDMMapHelper< TGeoElement > | EleMap |
typedef TGDMMapHelper< const char > | FileMap |
typedef std::map< std::string, double > | FracMap |
typedef TGDMMapHelper< TGeoIsotope > | IsoMap |
typedef TGDMMapHelper< TGeoMaterial > | MatMap |
typedef TGDMMapHelper< TGDMLMatrix > | MatrixMap |
typedef TGDMMapHelper< TGeoMedium > | MedMap |
typedef TGDMMapHelper< TGeoMixture > | MixMap |
typedef TGDMMapHelper< TGeoTranslation > | PosMap |
typedef TGDMMapHelper< TGeoNode > | PvolMap |
typedef std::map< std::string, std::string > | ReflectionsMap |
typedef TGDMMapHelper< TGDMLRefl > | ReflSolidMap |
typedef std::map< std::string, std::string > | ReflVolMap |
typedef TGDMMapHelper< TGeoRotation > | RotMap |
typedef TGDMMapHelper< TGeoScale > | SclMap |
typedef TGDMMapHelper< TGeoShape > | SolMap |
typedef TGDMMapHelper< TGeoVolume > | VolMap |
Private Member Functions | |
XMLNodePointer_t | Arb8 (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, an Arb8 may be declared. | |
XMLNodePointer_t | AssProcess (TXMLEngine *gdml, XMLNodePointer_t node) |
In the structure section of the GDML file, assembly volumes can be declared. | |
XMLNodePointer_t | BooSolid (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr, int num) |
In the solid section of the GDML file, boolean solids can be declared. | |
XMLNodePointer_t | BorderSurfaceProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the structure section of the GDML file, border surfaces can be declared. | |
XMLNodePointer_t | Box (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a box may be declared. | |
XMLNodePointer_t | Cone (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a cone may be declared. | |
XMLNodePointer_t | ConProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the define section of the GDML file, constants can be declared. | |
XMLNodePointer_t | CutTube (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Cut Tube may be declared. | |
void | DefineConstants () |
Define constant expressions used. | |
XMLNodePointer_t | ElCone (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, an elliptical cone may be declared. | |
XMLNodePointer_t | EleProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLNodePointer_t parentn, Bool_t hasIsotopes, Bool_t hasIsotopesExtended) |
When the element keyword is found, this function is called, and the name and values of the element are converted into type TGeoElement and stored in felemap map using the name as its key. | |
XMLNodePointer_t | Ellipsoid (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, an ellipsoid may be declared. | |
XMLNodePointer_t | ElTube (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a ElTube may be declared. | |
double | Evaluate (const char *evalline) |
Takes a string containing a mathematical expression and returns the value of the expression. | |
TString | GetScale (const char *unit) |
Throughout the GDML file, a unit can de specified. | |
double | GetScaleVal (const char *unit) |
Throughout the GDML file, a unit can de specified. | |
XMLNodePointer_t | Hype (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Hype may be declared. | |
XMLNodePointer_t | IsoProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLNodePointer_t parentn) |
In the material section of the GDML file, an isotope may be declared. | |
XMLNodePointer_t | MatProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr, int z) |
In the materials section of the GDML file, materials can be declared. | |
XMLNodePointer_t | MatrixProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the define section of the GDML file, matrices These are referenced by other GDML tags, such as optical surfaces. | |
const char * | NameShort (const char *name) |
This function looks thru a string for the chars '0x' next to each other, when it finds this, it calls another function to strip the hex address. | |
XMLNodePointer_t | OpticalSurfaceProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, optical surfaces can be defined. | |
XMLNodePointer_t | Orb (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, an Orb may be declared. | |
XMLNodePointer_t | Para (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Para may be declared. | |
XMLNodePointer_t | Paraboloid (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Paraboloid may be declared. | |
const char * | ParseGDML (TXMLEngine *gdml, XMLNodePointer_t node) |
This function recursively moves thru the DOM tree of the GDML file. | |
XMLNodePointer_t | Polycone (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Polycone may be declared. | |
XMLNodePointer_t | Polyhedra (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Polyhedra may be declared. | |
XMLNodePointer_t | PosProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the define section of the GDML file, positions can be declared. | |
XMLNodePointer_t | QuantityProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the define section of the GDML file, quantities can be declared. | |
XMLNodePointer_t | Reflection (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Reflected Solid may be declared when the ReflectedSolid keyword is found, this function is called. | |
XMLNodePointer_t | RotProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the define section of the GDML file, rotations can be declared. | |
XMLNodePointer_t | SclProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the define section of the GDML file, rotations can be declared. | |
Int_t | SetAxis (const char *axisString) |
When using the 'divide' process in the geometry this function sets the variable 'axis' depending on what is specified. | |
XMLNodePointer_t | SkinSurfaceProcess (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the structure section of the GDML file, skin surfaces can be declared. | |
XMLNodePointer_t | Sphere (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Sphere may be declared. | |
XMLNodePointer_t | Tessellated (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a tessellated shape may be declared. | |
XMLNodePointer_t | TopProcess (TXMLEngine *gdml, XMLNodePointer_t node) |
In the setup section of the GDML file, the top volume need to be declared. | |
XMLNodePointer_t | Torus (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Torus may be declared. | |
XMLNodePointer_t | Trap (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Trap may be declared. | |
XMLNodePointer_t | Trd (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Trd may be declared. | |
XMLNodePointer_t | Tube (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a Tube may be declared. | |
XMLNodePointer_t | TwistTrap (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, a TwistTrap may be declared. | |
XMLNodePointer_t | UsrProcess (TXMLEngine *gdml, XMLNodePointer_t node) |
User data to be processed. | |
double | Value (const char *svalue) const |
Convert number in string format to double value. | |
XMLNodePointer_t | VolProcess (TXMLEngine *gdml, XMLNodePointer_t node) |
In the structure section of the GDML file, volumes can be declared. | |
XMLNodePointer_t | Xtru (TXMLEngine *gdml, XMLNodePointer_t node, XMLAttrPointer_t attr) |
In the solids section of the GDML file, an Xtru may be declared. | |
Private Attributes | |
ConstMap | fconsts |
Map containing files parsed during entire parsing, with their world volume name. | |
EleMap | felemap |
Map containing isotope names and the TGeoIsotope for it. | |
FileMap | ffilemap |
Map containing reflected volume names and the solid ref for it. | |
IsoMap | fisomap |
Map containing scale names and the TGeoScale for it. | |
MatMap | fmatmap |
Map containing element names and the TGeoElement for it. | |
MatrixMap | fmatrices |
Map containing values of constants declared in the file. | |
MedMap | fmedmap |
Map containing material names and the TGeoMaterial for it. | |
MixMap | fmixmap |
Map containing medium names and the TGeoMedium for it. | |
PosMap | fposmap |
PvolMap | fpvolmap |
Map containing volume names and the TGeoVolume for it. | |
ReflectionsMap | freflectmap |
Map containing placed volume names and the TGeoNode for it. | |
ReflSolidMap | freflsolidmap |
Map containing reflection names and the Solid name ir references to. | |
ReflVolMap | freflvolmap |
Map containing reflection names and the TGDMLRefl for it - containing refl matrix. | |
RotMap | frotmap |
Map containing position names and the TGeoTranslation for it. | |
SclMap | fsclmap |
Map containing rotation names and the TGeoRotation for it. | |
SolMap | fsolmap |
Map containing mixture names and the TGeoMixture for it. | |
VolMap | fvolmap |
Map containing solid names and the TGeoShape for it. | |
Additional Inherited Members | |
Public Types inherited from TObject | |
enum | { kIsOnHeap = 0x01000000 , kNotDeleted = 0x02000000 , kZombie = 0x04000000 , kInconsistent = 0x08000000 , kBitMask = 0x00ffffff } |
enum | { kSingleKey = BIT(0) , kOverwrite = BIT(1) , kWriteDelete = BIT(2) } |
enum | EDeprecatedStatusBits { kObjInCanvas = BIT(3) } |
enum | EStatusBits { kCanDelete = BIT(0) , kMustCleanup = BIT(3) , kIsReferenced = BIT(4) , kHasUUID = BIT(5) , kCannotPick = BIT(6) , kNoContextMenu = BIT(8) , kInvalidObject = BIT(13) } |
Protected Types inherited from TObject | |
enum | { kOnlyPrepStep = BIT(3) } |
Protected Member Functions inherited from TObject | |
virtual void | DoError (int level, const char *location, const char *fmt, va_list va) const |
Interface to ErrorHandler (protected). | |
void | MakeZombie () |
#include <TGDMLParse.h>
|
private |
Definition at line 197 of file TGDMLParse.h.
|
private |
Definition at line 182 of file TGDMLParse.h.
|
private |
Definition at line 193 of file TGDMLParse.h.
|
private |
Definition at line 196 of file TGDMLParse.h.
|
private |
Definition at line 183 of file TGDMLParse.h.
|
private |
Definition at line 184 of file TGDMLParse.h.
|
private |
Definition at line 191 of file TGDMLParse.h.
|
private |
Definition at line 185 of file TGDMLParse.h.
|
private |
Definition at line 186 of file TGDMLParse.h.
|
private |
Definition at line 179 of file TGDMLParse.h.
|
private |
Definition at line 190 of file TGDMLParse.h.
|
private |
Definition at line 194 of file TGDMLParse.h.
|
private |
Definition at line 192 of file TGDMLParse.h.
|
private |
Definition at line 195 of file TGDMLParse.h.
|
private |
Definition at line 180 of file TGDMLParse.h.
|
private |
Definition at line 181 of file TGDMLParse.h.
|
private |
Definition at line 188 of file TGDMLParse.h.
|
private |
Definition at line 189 of file TGDMLParse.h.
TGDMLParse::TGDMLParse | ( | ) |
Constructor.
Definition at line 127 of file TGDMLParse.cxx.
|
inlinevirtual |
Definition at line 109 of file TGDMLParse.h.
|
private |
In the solids section of the GDML file, an Arb8 may be declared.
when the arb8 keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoArb8 and stored in fsolmap map using the name as its key.
Definition at line 2782 of file TGDMLParse.cxx.
|
private |
In the structure section of the GDML file, assembly volumes can be declared.
when the assembly keyword is found, this function is called, and the name is converted into type TGeoVolumeAssembly and stored in fvolmap map using the name as its key. Some assembly volumes reference to other physical volumes to contain inside that assembly, declaring positions and rotations within that volume. When each 'physvol' is declared, a matrix for its rotation and translation is built and the 'physvol node' is added to the original assembly using TGeoVolume->AddNode.
Definition at line 2379 of file TGDMLParse.cxx.
|
private |
In the solid section of the GDML file, boolean solids can be declared.
when the subtraction, intersection or union keyword is found, this function is called, and the values (rotation and translation) of the solid are converted into type TGeoCompositeShape and stored in fsolmap map using the name as its key.
Definition at line 2181 of file TGDMLParse.cxx.
|
private |
In the structure section of the GDML file, border surfaces can be declared.
Definition at line 1621 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a box may be declared.
when the box keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoBBox and stored in fsolmap map using the name as its key.
Definition at line 2513 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a cone may be declared.
when the cone keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoConSeg and stored in fsolmap map using the name as its key.
Definition at line 3059 of file TGDMLParse.cxx.
|
private |
In the define section of the GDML file, constants can be declared.
when the constant keyword is found, this function is called, and the name and value of the constant is stored in the "fformvec" vector as a TFormula class, representing a constant function
Definition at line 451 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Cut Tube may be declared.
when the cutTube keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoCtub and stored in fsolmap map using the name as its key.
Definition at line 2969 of file TGDMLParse.cxx.
|
private |
Define constant expressions used.
Definition at line 483 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, an elliptical cone may be declared.
Unfortunately, the elliptical cone is not supported under ROOT so, when the elcone keyword is found, this function is called to convert it to a simple box with similar dimensions, and the dimensions required are taken and stored, these are then bound and converted to type TGeoBBox and stored in fsolmap map using the name as its key.
Definition at line 2653 of file TGDMLParse.cxx.
|
private |
When the element keyword is found, this function is called, and the name and values of the element are converted into type TGeoElement and stored in felemap map using the name as its key.
Definition at line 1061 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, an ellipsoid may be declared.
Unfortunately, the ellipsoid is not supported under ROOT so, when the ellipsoid keyword is found, this function is called to convert it to a simple box with similar dimensions, and the dimensions required are taken and stored, these are then bound and converted to type TGeoBBox and stored in fsolmap map using the name as its key.
Definition at line 2568 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a ElTube may be declared.
when the eltube keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoEltu and stored in fsolmap map using the name as its key.
Definition at line 3903 of file TGDMLParse.cxx.
|
private |
Takes a string containing a mathematical expression and returns the value of the expression.
Definition at line 400 of file TGDMLParse.cxx.
TGeoVolume * TGDMLParse::GDMLReadFile | ( | const char * | filename = "test.gdml" | ) |
Creates the new instance of the XMLEngine called 'gdml', using the filename >> then parses the file and creates the DOM tree.
Then passes the DOM to the next function to translate it.
Definition at line 158 of file TGDMLParse.cxx.
|
private |
Throughout the GDML file, a unit can de specified.
Whether it be angular or linear, values can be used as well as abbreviations such as 'mm' or 'deg'. This function is passed the specified unit and if it is found, replaces it with the appropriate value.
Definition at line 669 of file TGDMLParse.cxx.
|
private |
Throughout the GDML file, a unit can de specified.
Whether it be angular or linear, values can be used as well as abbreviations such as 'mm' or 'deg'. This function is passed the specified unit and if it is found, replaces it with the appropriate value.
Definition at line 714 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Hype may be declared.
when the hype keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoHype and stored in fsolmap map using the name as its key.
Definition at line 3675 of file TGDMLParse.cxx.
|
private |
In the material section of the GDML file, an isotope may be declared.
when the isotope keyword is found, this function is called, and the required parameters are taken and stored, these are then bound and converted to type TGeoIsotope and stored in fisomap map using the name as its key.
Definition at line 991 of file TGDMLParse.cxx.
|
private |
In the materials section of the GDML file, materials can be declared.
when the material keyword is found, this function is called, and the name and values of the material are converted into type TGeoMaterial and stored in fmatmap map using the name as its key. Mixtures can also be declared, and they are converted to TGeoMixture and stored in fmixmap. These mixtures and materials are then all converted into one common type - TGeoMedium. The map fmedmap is then built up of all the mixtures and materials.
Definition at line 1272 of file TGDMLParse.cxx.
|
private |
In the define section of the GDML file, matrices These are referenced by other GDML tags, such as optical surfaces.
Definition at line 555 of file TGDMLParse.cxx.
|
private |
This function looks thru a string for the chars '0x' next to each other, when it finds this, it calls another function to strip the hex address.
It does this recursively until the end of the string is reached, returning a string without any hex addresses.
Definition at line 435 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, optical surfaces can be defined.
Definition at line 604 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, an Orb may be declared.
when the orb keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoSphere and stored in fsolmap map using the name as its key.
Definition at line 3955 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Para may be declared.
when the para keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoPara and stored in fsolmap map using the name as its key.
Definition at line 3739 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Paraboloid may be declared.
when the paraboloid keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoParaboloid and stored in fsolmap map using the name as its key.
Definition at line 2729 of file TGDMLParse.cxx.
|
private |
This function recursively moves thru the DOM tree of the GDML file.
It checks for key words along the way and if a key word is found it calls the corresponding function to interpret the node.
Definition at line 193 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Polycone may be declared.
when the polycone keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoPCon and stored in fsolmap map using the name as its key. Polycone has Zplanes, planes along the z axis specifying the rmin, rmax dimensions at that point along z.
Definition at line 3289 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Polyhedra may be declared.
when the polyhedra keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoPgon and stored in fsolmap map using the name as its key. Polycone has Zplanes, planes along the z axis specifying the rmin, rmax dimensions at that point along z.
Definition at line 3413 of file TGDMLParse.cxx.
|
private |
In the define section of the GDML file, positions can be declared.
when the position keyword is found, this function is called, and the name and values of the position are converted into type TGeoPosition and stored in fposmap map using the name as its key. This function can also be called when declaring solids.
Definition at line 838 of file TGDMLParse.cxx.
|
private |
In the define section of the GDML file, quantities can be declared.
These are treated the same as constants, but the unit has to be multiplied
Definition at line 524 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Reflected Solid may be declared when the ReflectedSolid keyword is found, this function is called.
The rotation, position and scale for the reflection are applied to a matrix that is then stored in the class object TGDMLRefl. This is then stored in the map freflsolidmap, with the reflection name as a reference. also the name of the solid to be reflected is stored in a map called freflectmap with the reflection name as a reference.
Definition at line 4333 of file TGDMLParse.cxx.
|
private |
In the define section of the GDML file, rotations can be declared.
when the rotation keyword is found, this function is called, and the name and values of the rotation are converted into type TGeoRotation and stored in frotmap map using the name as its key. This function can also be called when declaring solids.
Definition at line 890 of file TGDMLParse.cxx.
|
private |
In the define section of the GDML file, rotations can be declared.
when the scale keyword is found, this function is called, and the name and values of the scale are converted into type TGeoScale and stored in fsclmap map using the name as its key. This function can also be called when declaring solids.
Definition at line 947 of file TGDMLParse.cxx.
|
private |
When using the 'divide' process in the geometry this function sets the variable 'axis' depending on what is specified.
Definition at line 410 of file TGDMLParse.cxx.
|
private |
In the structure section of the GDML file, skin surfaces can be declared.
Definition at line 1575 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Sphere may be declared.
when the sphere keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoSphere and stored in fsolmap map using the name as its key.
Definition at line 3541 of file TGDMLParse.cxx.
|
inlinestatic |
Definition at line 111 of file TGDMLParse.h.
|
private |
In the solids section of the GDML file, a tessellated shape may be declared.
When the tessellated keyword is found, this function is called, and the triangular/quadrangular facets are read, creating the corresponding TGeoTessellated object stored in fsolmap map using the name as its key.
Definition at line 4165 of file TGDMLParse.cxx.
|
private |
In the setup section of the GDML file, the top volume need to be declared.
when the setup keyword is found, this function is called, and the top volume ref is taken and 'world' is set
Definition at line 2481 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Torus may be declared.
when the torus keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoTorus and stored in fsolmap map using the name as its key.
Definition at line 3610 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Trap may be declared.
when the trap keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoTrap and stored in fsolmap map using the name as its key.
Definition at line 3137 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Trd may be declared.
when the trd keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoTrd2 and stored in fsolmap map using the name as its key.
Definition at line 3227 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a Tube may be declared.
when the tube keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoTubeSeg and stored in fsolmap map using the name as its key.
Definition at line 2900 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, a TwistTrap may be declared.
when the twistedtrap keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoGTra and stored in fsolmap map using the name as its key.
Definition at line 3808 of file TGDMLParse.cxx.
|
private |
User data to be processed.
Definition at line 2326 of file TGDMLParse.cxx.
|
private |
Convert number in string format to double value.
Definition at line 755 of file TGDMLParse.cxx.
|
private |
In the structure section of the GDML file, volumes can be declared.
when the volume keyword is found, this function is called, and the name and values of the volume are converted into type TGeoVolume and stored in fvolmap map using the name as its key. Volumes reference to a solid declared higher up in the solids section of the GDML file. Some volumes reference to other physical volumes to contain inside that volume, declaring positions and rotations within that volume. when each 'physvol' is declared, a matrix for its rotation and translation is built and the 'physvol node' is added to the original volume using TGeoVolume->AddNode. volume division is also declared within the volume node, and once the values for the division have been collected, using TGeoVolume->divide, the division can be applied.
Definition at line 1687 of file TGDMLParse.cxx.
|
private |
In the solids section of the GDML file, an Xtru may be declared.
when the xtru keyword is found, this function is called, and the dimensions required are taken and stored, these are then bound and converted to type TGeoXtru and stored in fsolmap map using the name as its key. The xtru has child nodes of either 'twoDimVertex'or 'section'. These two nodes define the real structure of the shape. The twoDimVertex's define the x,y sizes of a vertice. The section links the vertice to a position within the xtru.
Definition at line 4003 of file TGDMLParse.cxx.
|
private |
Map containing files parsed during entire parsing, with their world volume name.
Definition at line 214 of file TGDMLParse.h.
const char* TGDMLParse::fCurrentFile |
Definition at line 104 of file TGDMLParse.h.
std::string TGDMLParse::fDefault_aunit = "rad" |
Definition at line 106 of file TGDMLParse.h.
std::string TGDMLParse::fDefault_lunit = "mm" |
Definition at line 105 of file TGDMLParse.h.
|
private |
Map containing isotope names and the TGeoIsotope for it.
Definition at line 203 of file TGDMLParse.h.
TXMLEngine* TGDMLParse::fFileEngine[20] |
Definition at line 102 of file TGDMLParse.h.
|
private |
Map containing reflected volume names and the solid ref for it.
Definition at line 213 of file TGDMLParse.h.
int TGDMLParse::fFILENO |
Definition at line 101 of file TGDMLParse.h.
|
private |
Map containing scale names and the TGeoScale for it.
Definition at line 202 of file TGDMLParse.h.
|
private |
Map containing element names and the TGeoElement for it.
Definition at line 204 of file TGDMLParse.h.
|
private |
Map containing values of constants declared in the file.
Definition at line 215 of file TGDMLParse.h.
|
private |
Map containing material names and the TGeoMaterial for it.
Definition at line 205 of file TGDMLParse.h.
|
private |
Map containing medium names and the TGeoMedium for it.
Definition at line 206 of file TGDMLParse.h.
|
private |
Definition at line 199 of file TGDMLParse.h.
|
private |
Map containing volume names and the TGeoVolume for it.
Definition at line 209 of file TGDMLParse.h.
|
private |
Map containing placed volume names and the TGeoNode for it.
Definition at line 210 of file TGDMLParse.h.
|
private |
Map containing reflection names and the Solid name ir references to.
Definition at line 211 of file TGDMLParse.h.
|
private |
Map containing reflection names and the TGDMLRefl for it - containing refl matrix.
Definition at line 212 of file TGDMLParse.h.
|
private |
Map containing position names and the TGeoTranslation for it.
Definition at line 200 of file TGDMLParse.h.
|
private |
Map containing rotation names and the TGeoRotation for it.
Definition at line 201 of file TGDMLParse.h.
|
private |
Map containing mixture names and the TGeoMixture for it.
Definition at line 207 of file TGDMLParse.h.
const char* TGDMLParse::fStartFile |
Definition at line 103 of file TGDMLParse.h.
int TGDMLParse::fVolID |
Definition at line 100 of file TGDMLParse.h.
|
private |
Map containing solid names and the TGeoShape for it.
Definition at line 208 of file TGDMLParse.h.
TGeoVolume* TGDMLParse::fWorld |
Definition at line 99 of file TGDMLParse.h.
TString TGDMLParse::fWorldName |
Definition at line 98 of file TGDMLParse.h.