1 #ifndef ALIMUON2DSTOREVALIDATOR_H
2 #define ALIMUON2DSTOREVALIDATOR_H
4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
10 /// \class AliMUON2DStoreValidator
11 /// \brief Determine which channels, manus, DEs, stations are missing
14 // Author Laurent Aphecetche
23 class AliMUONCheckItem;
24 class AliMUONVCalibParam;
26 class AliMUON2DStoreValidator : public TObject
29 AliMUON2DStoreValidator();
30 virtual ~AliMUON2DStoreValidator();
32 TObjArray* Validate(const AliMUONVStore& store, Float_t invalidFloatValue);
34 TObjArray* Validate(const AliMUONVStore& store);
36 TObjArray* Validate(const AliMUONVStore& store,
37 Bool_t (*check)(const AliMUONVCalibParam&,Int_t));
40 AliMUONVStore* GetStatus() const { return fStatus; }
42 /// Reports what is missing, trying to be as concise as possible.
43 void Report(TList& lines) const;
45 static void Report(TList& lines, const TObjArray& chambers);
49 AliMUON2DStoreValidator(const AliMUON2DStoreValidator&);
51 AliMUON2DStoreValidator& operator=(const AliMUON2DStoreValidator&);
53 void AddMissingChannel(Int_t detElemId, Int_t manuId, Int_t manuChannel);
55 void AddMissingManu(Int_t detElemId, Int_t manuId);
57 AliMUONCheckItem* GetChamber(Int_t chamberID);
58 AliMUONCheckItem* GetDE(Int_t detElemId);
59 AliMUONCheckItem* GetManu(Int_t detElemId, Int_t manuId);
61 static void ReportChamber(TList& list, AliMUONCheckItem& chamber);
62 static void ReportDE(TList& list, AliMUONCheckItem& de);
63 static void ReportManu(TList& list, AliMUONCheckItem& manu);
66 TList* fManuList; //!< List of (DE,manuID) pairs.
67 TObjArray* fChambers; //!< Array of AliMUONCheckItem.
68 AliMUONVStore* fStatus; //!< Statuses
70 ClassDef(AliMUON2DStoreValidator,2) // Validator of 2DStore