library: libGdml
#include "TGDMLParse.h"

TGDMLParse


class description - header file - source file
viewCVS header - viewCVS source

class TGDMLParse: public TObject

Inheritance Inherited Members Includes Libraries
Class Charts

Function Members (Methods)

Display options:
Show inherited
Show non-public
public:
TGDMLParse()
TGDMLParse(const TGDMLParse&)
virtual~TGDMLParse()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
virtual voidTObject::Copy(TObject& object) const
virtual voidTObject::Delete(Option_t* option = "")
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() const
virtual TObject*TObject::DrawClone(Option_t* option = "") const
virtual voidTObject::Dump() const
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
TGeoVolume*GDMLReadFile(const char* filename = "test.gdml")
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
virtual const char*TObject::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() const
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tTObject::Notify()
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
TObject&TObject::operator=(const TObject& rhs)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") const
virtual voidTObject::SavePrimitive(ostream& out, Option_t* option = "")
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")
static voidTObject::SetDtorOnly(void* obj)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector& insp, char* parent)
static TGeoVolume*StartGDML(const char* filename)
virtual voidStreamer(TBuffer& b)
voidStreamerNVirtual(TBuffer& b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = "0", Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = "0", Int_t option = 0, Int_t bufsize = 0) const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()
private:
XMLNodePointer_tArb8(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tAssProcess(TXMLEngine* gdml, XMLNodePointer_t node)
XMLNodePointer_tBooSolid(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr, int num)
XMLNodePointer_tBox(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tCone(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tConProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tCutTube(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tEleProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLNodePointer_t parentn)
XMLNodePointer_tElTube(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
doubleEvaluate(const char* evalline)
const char*FindConst(const char* retval)
const char*GetScale(const char* unit)
XMLNodePointer_tHype(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tMatProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr, int z)
const char*NameShort(const char* name)
const char*NameShortB(const char* name)
XMLNodePointer_tOrb(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tPara(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tParaboloid(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
const char*ParseGDML(TXMLEngine* gdml, XMLNodePointer_t node)
XMLNodePointer_tPolycone(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tPolyhedra(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tPosProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tReflection(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tRotProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
Int_tSetAxis(const char* axisString)
XMLNodePointer_tSphere(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tTopProcess(TXMLEngine* gdml, XMLNodePointer_t node)
XMLNodePointer_tTorus(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tTrap(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tTrd(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tTube(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tTwistTrap(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
XMLNodePointer_tVolProcess(TXMLEngine* gdml, XMLNodePointer_t node)
XMLNodePointer_tXtru(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)

Data Members

public:
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
public:
const char*fWorldNametop volume of geometry name
TGeoVolume*fWorldtop volume of geometry
intfVolIDvolume ID, incremented as assigned.
intfFILENOHolds which level of file the parser is at
TXMLEngine*fFileEngine[20]array of dom object pointers
const char*fStartFilename of originating file
const char*fCurrentFilecurrent file name being parsed
private:
TGDMMapHelper<TGeoTranslation>fposmap!Map containing position names and the TGeoTranslation for it
TGDMMapHelper<TGeoRotation>frotmap!Map containing rotation names and the TGeoRotation for it
TGDMMapHelper<TGeoElement>felemap!Map containing element names and the TGeoElement for it
TGDMMapHelper<TGeoMaterial>fmatmap!Map containing material names and the TGeoMaterial for it
TGDMMapHelper<TGeoMedium>fmedmap!Map containing medium names and the TGeoMedium for it
TGDMMapHelper<TGeoMixture>fmixmap!Map containing mixture names and the TGeoMixture for it
TGDMMapHelper<const char>fconmap!Map containing constant names and the constant's value
TGDMMapHelper<TGeoShape>fsolmap!Map containing solid names and the TGeoShape for it
TGDMMapHelper<TGeoVolume>fvolmap!Map containing volume names and the TGeoVolume for it
map<string,string,less<string>,allocator<pair<const string,string> > >freflectmap!Map containing reflection names and the Solid name ir references to
TGDMMapHelper<TGDMLRefl>freflsolidmap!Map containing reflection names and the TGDMLRefl for it - containing refl matrix
map<string,string,less<string>,allocator<pair<const string,string> > >freflvolmap!Map containing reflected volume names and the solid ref for it
TGDMMapHelper<const char>ffilemap!Map containing files parsed during entire parsing, with their world volume name

Class Description

TGeoVolume* GDMLReadFile(const char* filename)
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 funtion to translate it. 
const char* ParseGDML(TXMLEngine* gdml, XMLNodePointer_t node)
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.
double Evaluate(const char* evalline)
takes in a string containing a mathematical expression and
returns the result of the expression as a double.
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.
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.   It does this recursively until the end of the 
string is reached, returning a string without any hex addresses.
const char* NameShortB(const char* name)
this function is passed a string, and removes the first hex address
it finds.   This function is called recursively by NameShort to
fully strip a string of all hex addresses within it.
const char* FindConst(const char* retval)
If a value is given within the GDML file, this function checks
the constant map set up when all constants are declared.   If a matching
constant name is found, the corresponding value is returned, if not,
the original is returned.
XMLNodePointer_t ConProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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 fconmap map using the 
constant name as its key.
const char* GetScale(const char* unit)
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.
XMLNodePointer_t PosProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t RotProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t EleProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLNodePointer_t parentn)
In the materials section of the GDML file, elements can be declared.
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 MatProcess(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr, int z)
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.
XMLNodePointer_t VolProcess(TXMLEngine* gdml, XMLNodePointer_t node)
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.
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. 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.

1 = SUBTRACTION
2 = INTERSECTION
3 = UNION
XMLNodePointer_t AssProcess(TXMLEngine* gdml, XMLNodePointer_t node)
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.
XMLNodePointer_t TopProcess(TXMLEngine* gdml, XMLNodePointer_t node)
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
XMLNodePointer_t Box(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Paraboloid(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Arb8(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Tube(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
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. 
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.
XMLNodePointer_t Cone(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Trap(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Trd(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Polycone(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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 dimenstions at that point along z.
XMLNodePointer_t Polyhedra(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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 dimenstions at that point along z.
XMLNodePointer_t Sphere(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Torus(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Hype(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Para(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t TwistTrap(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t ElTube(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Orb(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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.
XMLNodePointer_t Xtru(TXMLEngine* gdml, XMLNodePointer_t node, XMLAttrPointer_t attr)
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. 
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. 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.
TGDMLParse()
virtual ~TGDMLParse()
{}
TGeoVolume* StartGDML(const char* filename)

Author: Ben Lloyd 09/11/06
Last update: Tue Dec 12 10:58:59 2006
Copyright (C) 1995-2006, Rene Brun and Fons Rademakers. *


ROOT page - Class index - Class Hierarchy - Top of the page

This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.