source: tags/Mars-V0.8.7pre/mbase/MEvtLoop.h

Last change on this file was 5911, checked in by tbretz, 20 years ago
*** empty log message ***
File size: 2.9 KB
Line 
1#ifndef MARS_MEvtLoop
2#define MARS_MEvtLoop
3
4/////////////////////////////////////////////////////////////////////////////
5// //
6// MEvtLoop //
7// //
8// Class to execute the tasks in a tasklist //
9// //
10/////////////////////////////////////////////////////////////////////////////
11
12#ifndef MARS_MParContainer
13#include "MParContainer.h"
14#endif
15
16class MTask;
17class MParList;
18class MTaskList;
19class TGProgressBar;
20#ifdef __MARS__
21class MProgressBar;
22#endif
23
24class MEvtLoop : public MParContainer
25{
26private:
27 MParList *fParList;
28 MTaskList *fTaskList; //!
29
30 TGProgressBar *fProgress; //!
31
32 ULong_t fNumEvents; //!
33
34 enum { kIsOwner = BIT(14), kPrivateDisplay = BIT(15) };
35
36 Bool_t HasDuplicateNames(const TString txt) const;
37 Bool_t HasDuplicateNames(TObjArray &arr, const TString txt) const;
38
39 void StreamPrimitive(ofstream &out) const;
40
41 Bool_t ProcessGuiEvents(Int_t num);
42
43public:
44 MEvtLoop(const char *name="Evtloop");
45 virtual ~MEvtLoop();
46
47 void SetParList(MParList *p);
48 MParList *GetParList() const { return fParList; }
49 MTaskList *GetTaskList() const { return fTaskList; }
50
51 MTask *FindTask(const char *name) const;
52 MTask *FindTask(const MTask *obj) const;
53
54 MStatusDisplay *GetDisplay() { return fDisplay; }
55 void SetDisplay(MStatusDisplay *d);
56 void SetPrivateDisplay(Bool_t b=kTRUE) { b ? SetBit(kPrivateDisplay) : ResetBit(kPrivateDisplay); } // Prevent status display from being cascaded in PreProcess
57
58 void SetOwner(Bool_t enable=kTRUE);
59
60 void SetProgressBar(TGProgressBar *bar);
61#ifdef __MARS__
62 void SetProgressBar(MProgressBar *bar);
63#endif
64
65 Bool_t PreProcess(const char *tlist="MTaskList");
66 Int_t Process(UInt_t maxcnt);
67 Bool_t PostProcess() const;
68
69 Bool_t Eventloop(UInt_t maxcnt=0, const char *tlist="MTaskList");
70
71 void MakeMacro(const char *filename="evtloop.C");
72
73 void SavePrimitive(ofstream &out, Option_t *o="");
74
75 Int_t Read(const char *name="Evtloop");
76 Int_t Write(const char *name="Evtloop", Int_t option=0, Int_t bufsize=0) const;
77 Int_t Write(const char *name="Evtloop", Int_t option=0, Int_t bufsize=0)
78 {
79 return const_cast<MEvtLoop*>(this)->Write(name, option, bufsize);
80 }
81
82 void Print(Option_t *opt="") const;
83
84 Int_t ReadEnv(const TEnv &env, TString prefix="", Bool_t print=kFALSE);
85 Bool_t WriteEnv(TEnv &env, TString prefix="", Bool_t print=kFALSE) const;
86
87 Bool_t ReadEnv(const char *config, Bool_t print=kFALSE);
88
89 void RecursiveRemove(TObject *obj);
90
91 ClassDef(MEvtLoop, 1) // Class to execute the tasks in a tasklist
92};
93
94#endif
Note: See TracBrowser for help on using the repository browser.