1 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
2 * See cxx source for full Copyright notice */
5 // $MpId: AliMpDDLStore.h,v 1.6 2006/05/24 13:58:16 ivana Exp $
7 /// \ingroup management
8 /// \class AliMpDDLStore
9 /// \brief The top container class for DDLs, det elements and bus patched
11 /// It provides acces to DDL, det element and bus patches objects
12 /// via various characteristics.
14 /// \author Ivana Hrivnacova, IPN Orsay;
15 /// Christian Finck, SUBATECH Nantes
17 #ifndef ALI_MP_DDL_STORE_H
18 #define ALI_MP_DDL_STORE_H
20 #include "AliMpExMap.h"
21 #include "AliMpIntPair.h"
22 #include "AliMpGlobalCrate.h"
24 #include <TObjArray.h>
29 class AliMpDetElement;
31 class AliMpLocalBoard;
32 class AliMpTriggerCrate;
36 class AliMpDDLStore : public TObject {
39 AliMpDDLStore(TRootIOCtor* /*ioCtor*/);
40 virtual ~AliMpDDLStore();
42 // static access method
43 static AliMpDDLStore* Instance(Bool_t warn = true);
44 static AliMpDDLStore* ReadData(Bool_t warn = true);
47 AliMpDDL* GetDDL(Int_t ddlId, Bool_t warn = true) const;
48 AliMpDetElement* GetDetElement(Int_t detElemId, Bool_t warn = true) const;
49 AliMpBusPatch* GetBusPatch(Int_t busPatchId, Bool_t warn = true) const;
50 AliMpLocalBoard* GetLocalBoard(Int_t localBoardId, Bool_t warn = true) const;
51 AliMpTriggerCrate* GetTriggerCrate(TString crateName, Bool_t warn = true) const;
52 AliMpTriggerCrate* GetTriggerCrate(Int_t ddlId, Int_t index, Bool_t warn = true) const;
53 /// Get Global Crate object
54 AliMpGlobalCrate* GetGlobalCrate() const {return fGlobalCrate;}
56 Int_t GetDEfromBus(Int_t busPatchId) const;
57 Int_t GetDEfromLocalBoard(Int_t localBoardId, Int_t chamberId) const;
58 Int_t GetNextDEfromLocalBoard(Int_t localBoardId, Int_t chamberId) const;
59 Int_t GetPreviousDEfromLocalBoard(Int_t localBoardId, Int_t chamberId) const;
61 Int_t GetDDLfromBus(Int_t busPatchId) const;
62 Int_t GetBusPatchId(Int_t detElemId, Int_t manuId) const;
64 /// Return trigger crates iterator
65 TExMapIter GetTriggerCrateItr() const {return fTriggerCrates.GetIterator();}
67 /// Return trigger local board iterator
68 TExMapIter GetLocalBoardItr() const {return fLocalBoards.GetIterator();}
70 /// Get an iterator to loop over bus patches
71 TExMapIter GetBusPatchesIterator() const { return fBusPatches.GetIterator(); }
73 /// read Global trigger crate file
74 static Bool_t ReadGlobalTrigger(AliMpGlobalCrate& crate, const Char_t* globalName = 0);
76 /// read local trigger crate file
77 static Bool_t ReadRegionalTrigger(AliMpExMap& triggerCrates, AliMpExMap& localBoards,
78 TObjArray& dlls, const Char_t* fileName = 0, Bool_t warn = true);
80 /// Get detection elt and Manu number from serial number
81 AliMpIntPair GetDetElemIdManu(Int_t manuSerial) const;
83 /// print info of all manus
84 void PrintAllManu() const;
90 AliMpDDLStore(const AliMpDDLStore& rhs);
92 AliMpDDLStore& operator=(const AliMpDDLStore& rhs);
95 Int_t GetManuListIndex(Int_t detElemId) const;
96 Int_t GetBusPatchIndex(Int_t detElemId, Int_t manuId) const;
98 Bool_t ReadTriggerDDLs();
100 Bool_t SetPatchModules();
101 Bool_t SetBusPatchLength();
102 Int_t GetLocalBoardId(TString name) const;
104 // static data members
105 static AliMpDDLStore* fgInstance; ///< Singleton instance
106 static const Int_t fgkNofDDLs; ///< Total number of DDLs
107 static const Int_t fgkNofTriggerDDLs; ///< Total number of trigger DDLs
110 TObjArray fDDLs; ///< Array of DDL objects
111 AliMpExMap fBusPatches; ///< The map of bus patches per their IDs
112 AliMpExMap fTriggerCrates; ///< The map of trigger crate per their ID
113 AliMpExMap fLocalBoards; ///< The map of local board per their ID
114 TArrayI fManuList12[16]; ///< Arrays of 1st manu in bus
115 TArrayI fManuBridge2[16]; ///< Arrays of manu number before the bridge in buspatch
116 AliMpGlobalCrate* fGlobalCrate; ///< Global Crate Object
118 ClassDef(AliMpDDLStore,3) // The manager class for definition of detection element types
121 #endif //ALI_MP_DDL_STORE_H