4 #ifndef ALIHLTPHOSPROCESSOR_H
5 #define ALIHLTPHOSPROCESSOR_H
6 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
7 * See cxx source for full Copyright notice */
9 #include "AliHLTProcessor.h"
10 #include "AliHLTPHOSBase.h"
11 #include "AliHLTPHOSDefinitions.h"
12 #include "AliHLTDataTypes.h"
14 using namespace PhosHLTConst;
16 class AliHLTPHOSProcessor:public AliHLTProcessor, public AliHLTPHOSBase
20 AliHLTPHOSProcessor();
21 virtual ~AliHLTPHOSProcessor();
22 virtual int DoInit(int argc, const char** argv) = 0;
23 virtual int Deinit() = 0;
24 virtual const char* GetComponentID() = 0;
25 virtual void GetInputDataTypes( std::vector <AliHLTComponentDataType>& list) =0;
26 virtual AliHLTComponentDataType GetOutputDataType() =0;
27 virtual void GetOutputDataSize(unsigned long& constBase, double& inputMultiplier) =0;
28 virtual AliHLTComponent* Spawn() = 0;
32 const char *IntToChar(int number);
34 *Check file and write messages to AliLog system
36 bool CheckFileLog(const char *origin, const char *filename, const char *opt);
37 void DoneWritingLog(const char *origin, const char *filename);
39 using AliHLTProcessor::DoEvent;
42 void ScanRunNumberFromFile();
43 virtual int ScanArgumentsModule(int argc, const char** argv);
44 int fPhosEventCount; /**<Global event counter for this component*/
45 AliHLTUInt8_t fModuleID; /**<ID of the module this component read data from (0-4)*/
47 Bool_t fPrintInfoModule; /**<wether or not to print debugg info to std out*/
48 int fPrintInfoFrequncyModule; /**<Defines the update frequency for information printet to std out*/
50 static const AliHLTComponentDataType fgkInputDataTypes[]; /**<List of datatypes that can be given to this component*/
56 AliHLTPHOSProcessor(const AliHLTPHOSProcessor & );
57 AliHLTPHOSProcessor & operator = (const AliHLTPHOSProcessor &);