]> git.uio.no Git - u/mrichter/AliRoot.git/blob - MUON/mapping/AliMpSegmentation.h
In SetNofManusPerModule(): return false if no action
[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 #ifndef ALIMPSLATMOTIFMAP_H
40 #  include "AliMpSlatMotifMap.h"
41 #endif
42
43 class AliMpVSegmentation;
44 class AliMpSegmentation;
45 class TRootIOCtor;
46
47 class AliMpSegmentation : public  TObject {
48
49   public:
50     AliMpSegmentation(TRootIOCtor* /*ioCtor*/);
51     virtual ~AliMpSegmentation();
52     
53     // static methods
54     static AliMpSegmentation* Instance();
55
56     // methods
57     const AliMpVSegmentation* GetMpSegmentation(
58                                  Int_t detElemId, AliMp::CathodType cath, 
59                                  Bool_t warn = true) const;
60
61     const AliMpVSegmentation* GetMpSegmentationByElectronics(
62                                  Int_t detElemId, Int_t elCardID, 
63                                  Bool_t warn = true) const;
64     
65   private:
66     /// Not implemented
67     AliMpSegmentation();
68     /// Not implemented
69     AliMpSegmentation(const AliMpSegmentation& rhs);
70     /// Not implemented
71     AliMpSegmentation& operator=(const AliMpSegmentation& rhs);
72
73     AliMpVSegmentation* CreateMpSegmentation(
74                               Int_t detElemId, AliMp::CathodType cath);
75
76     AliMpExMap* FillElCardsMap(Int_t detElemId);
77
78     // static data members
79     static AliMpSegmentation* fgInstance; ///< Singleton instance
80
81     // data members
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,1)  // 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