]> git.uio.no Git - u/mrichter/AliRoot.git/blob - PHOS/AliPHOSv0.h
Major upgrade of AliRoot code
[u/mrichter/AliRoot.git] / PHOS / AliPHOSv0.h
1 #ifndef ALIPHOSV0_H
2 #define ALIPHOSV0_H
3 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4  * See cxx source for full Copyright notice                               */
5
6 //_________________________________________________________________________
7 // Implementation version v0 of PHOS Manager class 
8 // Layout EMC + PPSD has name GPS2  
9 // Layout EMC + CPV  has name IHEP
10 //*--                  
11 //*-- Author: Yves Schutz (SUBATECH)
12
13 // --- ROOT system ---
14 #include "TClonesArray.h"
15
16 class TFile;
17
18 // --- AliRoot header files ---
19 #include "AliPHOS.h"
20 #include "AliPHOSGeometry.h"
21 #include "AliPHOSReconstructioner.h"
22 #include "AliPHOSTrackSegmentMaker.h"
23 #include "AliPHOSPID.h"
24
25 class AliPHOSv0 : public AliPHOS {
26
27  public:
28
29   AliPHOSv0() {
30     //ctor
31     fGeom=0;
32   }
33   AliPHOSv0(const char *name, const char *title="") ;
34   AliPHOSv0(const AliPHOSv0 & phos) {
35     // cpy ctor: no implementation yet
36     // requested by the Coding Convention
37     assert(0==1) ; 
38   } 
39   virtual ~AliPHOSv0(void){
40     // dtor
41   } 
42
43   virtual void   AddHit( Int_t shunt, Int_t primary, Int_t track, Int_t id, Float_t *hits ) {
44     // useless since there are no hits
45     assert(0==1) ; 
46   }
47   virtual void   BuildGeometry(void) ;             // creates the geometry for the ROOT display
48   void           BuildGeometryforPHOS(void) ;      // creates the PHOS geometry for the ROOT display
49   void           BuildGeometryforPPSD(void) ;      // creates the PPSD geometry for the ROOT display
50   void           BuildGeometryforCPV(void) ;       // creates the CPV  geometry for the ROOT display
51   virtual void   CreateGeometry(void) ;            // creates the geometry for GEANT
52   void           CreateGeometryforPHOS(void) ;     // creates the PHOS geometry for GEANT
53   void           CreateGeometryforPPSD(void) ;     // creates the PPSD geometry for GEANT
54   void           CreateGeometryforCPV(void) ;      // creates the CPV  geometry for GEANT
55   void           CreateGeometryforSupport(void) ;  // creates the Support geometry for GEANT
56   virtual Float_t ZMin() const;                    // overall dimension of the module (min)
57   virtual Float_t ZMax() const;                    // overall dimension of the module (max)
58
59   virtual AliPHOSGeometry * GetGeometry() {
60     // gets the pointer to the AliPHOSGeometry unique instance  
61     return fGeom ; 
62   }  
63   virtual void   Init(void) ;                                       // does nothing
64   virtual Int_t  IsVersion(void) const { 
65     // Gives the version number 
66     return 0 ; 
67   }
68   virtual TString Version(void){ 
69     // As above
70     return TString("v0") ; 
71   }
72   
73   AliPHOSv0 & operator = (const AliPHOSv0 & rvalue)  {
74     // assignement operator requested by coding convention but not needed
75     assert(0==1) ;
76     return *this ; 
77   }
78   
79  protected:
80   
81   AliPHOSGeometry * fGeom ;                       // Geometry definition
82   
83   ClassDef(AliPHOSv0,1)  // Implementation of PHOS manager class for layout EMC+PPSD
84     
85     };
86     
87 #endif // AliPHOSV0_H