]> git.uio.no Git - u/mrichter/AliRoot.git/blob - TGeant4/TG4VXMLConvertor.h
several corrections (see details in doc/history/g4mc_geometry_History)
[u/mrichter/AliRoot.git] / TGeant4 / TG4VXMLConvertor.h
1 // $Id$
2 // Category: geometry
3 // by I. Hrivnacova, 27.07.2000 
4 //
5 // The interface for XML convertor that
6 // converts G4 basic geometry objects to XML. 
7
8 #ifndef TG4_V_XML_CONVERTOR_H
9 #define TG4_V_XML_CONVERTOR_H
10
11 #include <G4ThreeVector.hh>
12 #include <G4RotationMatrix.hh>
13
14 class G4Material;
15 class G4VSolid;
16 class G4LogicalVolume;
17
18 class TG4VXMLConvertor
19 {
20   public:
21     TG4VXMLConvertor();
22     virtual ~TG4VXMLConvertor();
23
24     // methods
25     virtual void OpenMaterials(const G4String& version, const G4String& date, 
26             const G4String& author, const G4String dtdVersion) = 0; 
27     virtual void OpenSection(const G4String& name, const G4String& version,
28             const G4String& date, const G4String& author,
29             const G4String& topVolume) = 0;
30     virtual void OpenComposition(const G4String& name) = 0;
31     virtual void CloseMaterials() = 0;
32     virtual void CloseSection() = 0;
33     virtual void CloseComposition() = 0;
34
35     virtual void WriteMaterial(const G4Material* material) = 0; 
36     virtual void WriteSolid(G4String lvName, const G4VSolid* solid, 
37                             G4String materialName) = 0; 
38     virtual void WriteRotation(const G4RotationMatrix* rotation) = 0; 
39     virtual void WritePosition(G4String lvName, G4ThreeVector position) = 0; 
40     virtual void WritePositionWithRotation(
41                                G4String lvName, G4ThreeVector position,
42                                const G4RotationMatrix* rotation) = 0; 
43     virtual void WriteEmptyLine() = 0;
44     virtual void IncreaseIndention() = 0;
45     virtual void DecreaseIndention() = 0;
46 };
47
48 #endif //TG4_V_XML_CONVERTOR_H
49