]> git.uio.no Git - u/mrichter/AliRoot.git/blob - MUON/mapping/AliMpSegmentation.h
Fixing part of the Coding violation
[u/mrichter/AliRoot.git] / MUON / mapping / AliMpSegmentation.h
1 #ifndef ALI_MP_SEGMENTATION_H
2 #define ALI_MP_SEGMENTATION_H
3
4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5  * See cxx source for full Copyright notice                               */
6
7 // $Id$ 
8 // $MpId: AliMpSegmentation.h,v 1.7 2006/05/24 13:58:16 ivana Exp $ 
9
10 /// \ingroup management
11 /// \class AliMpSegmentation
12 /// \brief Singleton container class for mapping segmentations
13 ///
14 /// It provides access to mapping segmentations based on the
15 /// AliMpVSegmentation interface.                                        \n
16 /// Mapping segmentations for all detection elements
17 /// are created at the first call to AliMpSegmentation::Instance().
18 /// The class is a singleton, it has all constructors
19 /// private, except for the special constructor for Root I/O.
20 ///
21 /// \author Ivana Hrivnacova, IPN Orsay; Laurent Aphecetche, SUBATECH
22
23 #ifndef ROOT_TObject
24 #  include <TObject.h>
25 #endif
26
27 #ifndef ALI_MP_STRING_OBJ_MAP_H
28 #  include "AliMpStringObjMap.h"
29 #endif
30
31 #ifndef ALI_MP_EX_MAP_H
32 #  include "AliMpExMap.h"
33 #endif
34
35 #ifndef ALI_MP_CATHOD_TYPE_H
36 #  include "AliMpCathodType.h"
37 #endif
38
39 class AliMpDEStore;
40 class AliMpVSegmentation;
41 class AliMpSegmentation;
42 class AliMpSlatMotifMap;
43 class TRootIOCtor;
44
45 class AliMpSegmentation : public  TObject {
46
47   public:
48     AliMpSegmentation(TRootIOCtor* /*ioCtor*/);
49     virtual ~AliMpSegmentation();
50     
51     // static methods
52     static AliMpSegmentation* Instance(Bool_t warn = true);
53     static AliMpSegmentation* ReadData(Bool_t warn = true);
54
55     // methods
56     const AliMpVSegmentation* GetMpSegmentation(
57                                  Int_t detElemId, AliMp::CathodType cath, 
58                                  Bool_t warn = true) const;
59
60     const AliMpVSegmentation* GetMpSegmentationByElectronics(
61                                  Int_t detElemId, Int_t elCardID, 
62                                  Bool_t warn = true) const;
63     
64   private:
65     /// Not implemented
66     AliMpSegmentation();
67     /// Not implemented
68     AliMpSegmentation(const AliMpSegmentation& rhs);
69     /// Not implemented
70     AliMpSegmentation& operator=(const AliMpSegmentation& rhs);
71
72     AliMpVSegmentation* CreateMpSegmentation(
73                               Int_t detElemId, AliMp::CathodType cath);
74
75     AliMpExMap* FillElCardsMap(Int_t detElemId);
76
77     // static data members
78     static AliMpSegmentation* fgInstance; ///< Singleton instance
79
80     // data members
81     AliMpDEStore*      fDetElements;    ///< Detection element store
82     AliMpStringObjMap  fMpSegmentations;///< Map of mapping segmentations to DE seg names
83     AliMpExMap         fElCardsMap;     ///< Map of el. cards IDs to segmentations
84     AliMpSlatMotifMap* fSlatMotifMap; ///< Map of motif, motifTypes to avoid duplications and allow proper deletion
85     
86   ClassDef(AliMpSegmentation,2)  // The factory for building mapping segmentations
87 };
88
89 #endif //ALI_MP_SEGMENTATION_H
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104