]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - MUON/AliMUONDigitMaker.h
Bug fix for loading the LUT for chambers 1 to 6. (Indra)
[u/mrichter/AliRoot.git] / MUON / AliMUONDigitMaker.h
index 7a20f30cc557d1a0f3d449c53afa135843d363be..0341a74f12583cb36dea5707b2763e9839a51e4a 100644 (file)
 //  Author: Ch, Finck
 
 #include <TObject.h>
-#include "TStopwatch.h"
 
 class TArrayS;
 
 class AliRawReader;
-class AliMUONTriggerCrateStore;
 class AliMUONLocalStruct;
 
-class AliMUONRawStreamTracker;
-class AliMUONRawStreamTrigger;
+class AliMUONRawStreamTrackerHP;
+class AliMUONRawStreamTriggerHP;
 
 class AliMUONVDigitStore;
 class AliMUONVTriggerStore;
 
+class AliMUONLogger;
+
 class AliMUONDigitMaker : public TObject 
 {
  public:
-  AliMUONDigitMaker(); // Constructor
+  AliMUONDigitMaker(Bool_t enableErrorLogger, Bool_t a, Bool_t b);
+
+  AliMUONDigitMaker(Bool_t enableErrorLogger = kTRUE); // Constructor
+
   virtual ~AliMUONDigitMaker(void); // Destructor
     
+  /// Code to indicate readout errors
+  enum ErrorCode
+  {
+    kOK=0,             ///< everything is OK 
+    kTrackerBAD=1<<1,  ///< tracker part had readout errors 
+    kTriggerBAD=1<<2   ///< trigger part had readout errors 
+  };
+  
   // write raw data
   Int_t  Raw2Digits(AliRawReader* rawReader, 
                     AliMUONVDigitStore* digitContainer=0,
@@ -43,15 +54,23 @@ class AliMUONDigitMaker : public TObject
   Int_t TriggerDigits(Int_t nBoard, TArrayS* xyPattern, 
                       AliMUONVDigitStore& digitStore) const;
 
+  Bool_t TriggerToDigitsStore(const AliMUONVTriggerStore& triggerStore, 
+                              AliMUONVDigitStore& digitStore) const;
+
         /// Set flag to generates scaler event
   void  SetScalerEvent() { fScalerEvent = kTRUE; }
 
-        /// Set Crate array
-  void  SetCrateManager(AliMUONTriggerCrateStore* crateManager) { fCrateManager =  crateManager; }
-
         /// Set flag whether or not we should generate digits for the trigger
   void  SetMakeTriggerDigits(Bool_t flag = kFALSE) { fMakeTriggerDigits = flag; }
 
+  /// Return the raw stream object which decodes DDL raw data from tracking stations.
+  AliMUONRawStreamTrackerHP* GetRawStreamTracker() const { return fRawStreamTracker; }
+
+  /// Return the raw stream object which decodes DDL raw data from the trigger system.
+  AliMUONRawStreamTriggerHP* GetRawStreamTrigger() const { return fRawStreamTrigger; }
+
+  void Print(Option_t* opt="") const;
+
 private:
     
   /// Not implemented
@@ -59,26 +78,19 @@ private:
   /// Not implemented
   AliMUONDigitMaker& operator=(const AliMUONDigitMaker& rhs); // assignment operator
 
-  void GetCrateName(Char_t* name, Int_t iDDL, Int_t iReg) const;
-
 private:
-
-  Bool_t           fScalerEvent;       //!< flag to generates scaler event
+  Bool_t fScalerEvent;       //!< flag to generates scaler event
   Bool_t fMakeTriggerDigits; //!< whether or not we should generate digits for the trigger
   
-  AliMUONRawStreamTracker* fRawStreamTracker;  //!< pointer of raw stream for tracker
-  AliMUONRawStreamTrigger* fRawStreamTrigger;  //!< pointer of raw stream for trigger
-
-  AliMUONTriggerCrateStore* fCrateManager;     //!< Crate array
-
-  TStopwatch fTrackerTimer;                    //!< time watcher for tracker part
-  TStopwatch fTriggerTimer;                    //!< time watcher for trigger part
-  TStopwatch fMappingTimer;                    //!< time watcher for mapping-tracker part
+  AliMUONRawStreamTrackerHP* fRawStreamTracker; //!< pointer of raw stream for tracker
+  AliMUONRawStreamTriggerHP* fRawStreamTrigger;  //!< pointer of raw stream for trigger
 
   AliMUONVDigitStore* fDigitStore; //!< not owner
   AliMUONVTriggerStore* fTriggerStore; //!< not owner
+
+  AliMUONLogger* fLogger; //!< to log messages
   
-  ClassDef(AliMUONDigitMaker,4) // MUON digit maker from rawdata
+  ClassDef(AliMUONDigitMaker,7) // MUON digit maker from rawdata
 };
        
 #endif