6 //* This file is property of and copyright by the ALICE HLT Project *
7 //* ALICE Experiment at CERN, All rights reserved. *
8 //* See cxx source for full Copyright notice *
11 @author Matthias Richter
13 @brief Virtual Interface to the AliDAQ class.
19 * Virtual interface to the AliDAQ class.
20 * In order to keep the libHLTbase free of AliRoot dependencies, the
21 * implementation has been separated from libHLTbase.
22 * Implementation in libHLTrec.
28 static Int_t NumberOfDetectors();
30 static Int_t DetectorID(const char *detectorName);
31 static const char *DetectorName(Int_t detectorID);
33 static Int_t DdlIDOffset(const char *detectorName);
34 static Int_t DdlIDOffset(Int_t detectorID);
36 static const char *DetectorNameFromDdlID(Int_t ddlID, Int_t &ddlIndex);
37 static Int_t DetectorIDFromDdlID(Int_t ddlID, Int_t &ddlIndex);
39 static Int_t DdlID(const char *detectorName, Int_t ddlIndex);
40 static Int_t DdlID(Int_t detectorID, Int_t ddlIndex);
41 static const char *DdlFileName(const char *detectorName, Int_t ddlIndex);
42 static const char *DdlFileName(Int_t detectorID, Int_t ddlIndex);
44 static Int_t NumberOfDdls(const char *detectorName);
45 static Int_t NumberOfDdls(Int_t detectorID);
47 static const char *ListOfTriggeredDetectors(UInt_t detectorPattern);
48 static UInt_t DetectorPattern(const char *detectorList);
50 static const char *OfflineModuleName(const char *detectorName);
51 static const char *OfflineModuleName(Int_t detectorID);
53 static const char *OnlineName(const char *detectorName);
54 static const char *OnlineName(Int_t detectorID);
56 static AliHLTDAQ* GetInstance();
59 virtual Int_t VirtNumberOfDetectors()=0;
61 virtual Int_t VirtDetectorID(const char *detectorName)=0;
62 virtual const char *VirtDetectorName(Int_t detectorID)=0;
64 virtual Int_t VirtDdlIDOffset(const char *detectorName)=0;
65 virtual Int_t VirtDdlIDOffset(Int_t detectorID)=0;
67 virtual const char *VirtDetectorNameFromDdlID(Int_t ddlID, Int_t &ddlIndex)=0;
68 virtual Int_t VirtDetectorIDFromDdlID(Int_t ddlID, Int_t &ddlIndex)=0;
70 virtual Int_t VirtDdlID(const char *detectorName, Int_t ddlIndex)=0;
71 virtual Int_t VirtDdlID(Int_t detectorID, Int_t ddlIndex)=0;
72 virtual const char *VirtDdlFileName(const char *detectorName, Int_t ddlIndex)=0;
73 virtual const char *VirtDdlFileName(Int_t detectorID, Int_t ddlIndex)=0;
75 virtual Int_t VirtNumberOfDdls(const char *detectorName)=0;
76 virtual Int_t VirtNumberOfDdls(Int_t detectorID)=0;
78 virtual const char *VirtListOfTriggeredDetectors(UInt_t detectorPattern)=0;
79 virtual UInt_t VirtDetectorPattern(const char *detectorList)=0;
81 virtual const char *VirtOfflineModuleName(const char *detectorName)=0;
82 virtual const char *VirtOfflineModuleName(Int_t detectorID)=0;
84 virtual const char *VirtOnlineName(const char *detectorName)=0;
85 virtual const char *VirtOnlineName(Int_t detectorID)=0;
87 /** global instance */
88 static AliHLTDAQ* fgpInstance; //!
90 /** the name of the actual implementation */
91 static const char* fgkImplName; //!
93 /** the library of the implementation */
94 static const char* fgkImplLibrary; //!