]> git.uio.no Git - u/mrichter/AliRoot.git/blame - STEER/AliShuttleInterface.h
macro and flowevent maker to run part of the code in root
[u/mrichter/AliRoot.git] / STEER / AliShuttleInterface.h
CommitLineData
57459306 1#ifndef ALI_SHUTTLE_INTERFACE_H
2#define ALI_SHUTTLE_INTERFACE_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//
10// abstract interface class to AliShuttle
11//
12
13#include <TObject.h>
3fe92ec0 14#include <TString.h>
57459306 15
16class TList;
b88146b7 17class AliPreprocessor;
4426d64a 18class AliCDBMetaData;
84090f85 19class AliCDBPath;
4426d64a 20class AliCDBEntry;
57459306 21
22class AliShuttleInterface : public TObject
23{
24 public:
1b82b32d 25 enum System { kDAQ = 0, kDCS, kHLT };
fc665cf2 26 enum { kNDetectors = 20 }; // number of subdetectors in ALICE
57459306 27
eb4a4f5c 28 virtual Bool_t Store(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData,
84090f85 29 Int_t validityStart = 0, Bool_t validityInfinite = kFALSE) = 0;
eb4a4f5c 30 virtual Bool_t StoreReferenceData(const AliCDBPath& path, TObject* object, AliCDBMetaData* metaData) = 0;
9827400b 31 virtual Bool_t StoreReferenceFile(const char* detector, const char* localFile, const char* gridFileName) = 0;
bba57327 32 virtual Bool_t StoreRunMetadataFile(const char* localFile, const char* gridFileName) = 0;
4a33bdd9 33
57459306 34 virtual const char* GetFile(Int_t system, const char* detector, const char* id, const char* source) = 0;
4a33bdd9 35
36 virtual TList* GetFileSources(Int_t system, const char* detector, const char* id = 0) = 0;
37 virtual TList* GetFileIDs(Int_t system, const char* detector, const char* source) = 0;
38
1b82b32d 39 virtual const char* GetRunParameter(const char* lbEntry) = 0;
f12d42ce 40 virtual UInt_t GetStartTimeDCSQuery() = 0;
41 virtual UInt_t GetEndTimeDCSQuery() = 0;
9827400b 42 virtual const char* GetRunType() = 0;
03b6e5e2 43 virtual Bool_t GetHLTStatus() = 0;
ca8ea066 44 virtual const char* GetTriggerConfiguration() = 0;
03b6e5e2 45
4a33bdd9 46 virtual AliCDBEntry* GetFromOCDB(const char* detector, const AliCDBPath& path) = 0;
47
57459306 48 virtual void Log(const char* detector, const char* message) = 0;
49
b88146b7 50 virtual void RegisterPreprocessor(AliPreprocessor* preprocessor) = 0;
51
1b82b32d 52 static const char* GetSystemName(UInt_t system) {return (system < 3) ? fkSystemNames[system] : 0;}
53
54 static const char* GetOfflineDetName(const char* detName);
55 static const char* GetDetName(UInt_t detPos);
f12d42ce 56 static Int_t GetDetPos(const char* detName);
57 static UInt_t NDetectors() {return kNDetectors;}
1b82b32d 58
3fe92ec0 59 static TString GetMainCDB () {return fgkMainCDB;}
3fe92ec0 60 static TString GetLocalCDB () {return fgkLocalCDB;}
3fe92ec0 61
62 static TString GetMainRefStorage() {return fgkMainRefStorage;}
3fe92ec0 63 static TString GetLocalRefStorage() {return fgkLocalRefStorage;}
996c5424 64 static const char* GetShuttleLogDir() {return fgkShuttleLogDir.Data();}
65 static const char* GetShuttleTempDir() {return fgkShuttleTempDir.Data();}
3fe92ec0 66
ffc56633 67 protected:
68
1b82b32d 69 static const char* fkSystemNames[3]; // names of the systems providing data to the shuttle
3fe92ec0 70 static const char* fgkDetName[kNDetectors]; // names of detectors' preprocessors (3-letter code convention)
71 static const char* fgkOfflineDetName[kNDetectors]; // names of detectors in OCDB (AliRoot naming convention)
72
73 static TString fgkMainCDB; // URI of the main (Grid) CDB storage
74 static TString fgkLocalCDB; // URI of the local backup CDB storage
75 static TString fgkMainRefStorage; // URI of the main (Grid) REFERENCE storage
76 static TString fgkLocalRefStorage; // URI of the local REFERENCE storage
77
78 static TString fgkShuttleTempDir; // path of SHUTTLE temp folder
79 static TString fgkShuttleLogDir; // path of SHUTTLE log folder
1b82b32d 80
57459306 81 private:
82 ClassDef(AliShuttleInterface, 0);
83};
84
85#endif