b38a544c8181fcaa09b4369731c128d69deb0e99
[u/mrichter/AliRoot.git] / MUON / AliMUONPreprocessor.h
1 #ifndef ALIMUONPREPROCESSOR_H
2 #define ALIMUONPREPROCESSOR_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
9 /// \ingroup shuttle
10 /// \class AliMUONPreprocessor
11 /// \brief Shuttle preprocessor for MUON subsystems (TRK and TRG)
12 /// 
13 //  Author Laurent Aphecetche
14
15 #ifndef ALI_PREPROCESSOR_H
16 #  include "AliPreprocessor.h"
17 #endif
18
19 class AliMUONVSubprocessor;
20 class TObjArray;
21
22 class AliMUONPreprocessor : public AliPreprocessor
23 {
24 public:
25   virtual void Initialize(Int_t run, UInt_t startTime, UInt_t endTime);
26   virtual UInt_t Process(TMap* dcsAliasMap);
27   virtual void Print(Option_t* opt="") const;
28   
29   void Log(const char* message) { AliPreprocessor::Log(message); }
30   
31   TList* GetFileSources(Int_t system, const char* id) 
32   { return AliPreprocessor::GetFileSources(system,id); }
33
34   UInt_t Store(const char* pathLevel2, const char* pathLevel3, TObject* object,
35                AliCDBMetaData* metaData, 
36                Int_t validityStart = 0, Bool_t validityInfinite = kFALSE)
37   {
38     return AliPreprocessor::Store(pathLevel2,pathLevel3,object,metaData,
39                                   validityStart,validityInfinite);
40   }
41   
42   const char* GetFile(Int_t system, const char* id, const char* source)
43   {
44     return AliPreprocessor::GetFile(system,id,source);
45   }  
46   
47 protected:
48   AliMUONPreprocessor(const char* detName, AliShuttleInterface* shuttle);
49   virtual ~AliMUONPreprocessor();
50   
51   void Add(AliMUONVSubprocessor* subProcessor); 
52   void ClearSubprocessors();
53   
54 private:
55   AliMUONPreprocessor(const AliMUONPreprocessor& rhs);
56   AliMUONPreprocessor& operator=(const AliMUONPreprocessor& rhs);
57   
58   AliMUONVSubprocessor* Subprocessor(Int_t i) const;
59   
60 private:
61
62   TObjArray* fSubprocessors; ///!< sub processors to execute
63   
64   ClassDef(AliMUONPreprocessor,1) // MUON Shuttle preprocessor
65 };
66
67 #endif