Logo ROOT   6.30.04
Reference Guide
 All Namespaces Files Pages
TTimer.h
Go to the documentation of this file.
1 // @(#)root/base:$Id$
2 // Author: Fons Rademakers 28/11/96
3 
4 /*************************************************************************
5  * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6  * All rights reserved. *
7  * *
8  * For the licensing terms see $ROOTSYS/LICENSE. *
9  * For the list of contributors see $ROOTSYS/README/CREDITS. *
10  *************************************************************************/
11 
12 #ifndef ROOT_TTimer
13 #define ROOT_TTimer
14 
15 
16 //////////////////////////////////////////////////////////////////////////
17 // //
18 // TTimer //
19 // //
20 // Handles synchronous and a-synchronous timer events. You can use //
21 // this class in one of the following ways: //
22 // - Sub-class TTimer and override the Notify() method. //
23 // - Re-implement the TObject::HandleTimer() method in your class //
24 // and pass a pointer to this object to timer, see the SetObject() //
25 // method. //
26 // - Pass an interpreter command to timer, see SetCommand() method. //
27 // - Create a TTimer, connect its Timeout() signal to the //
28 // appropriate methods. Then when the time is up it will emit a //
29 // Timeout() signal and call connected slots. //
30 // //
31 // Minimum timeout interval is defined in TSystem::ESysConstants as //
32 // kItimerResolution (currently 10 ms). //
33 // //
34 // Signal/slots example: //
35 // TTimer *timer = new TTimer(); //
36 // timer->Connect("Timeout()", "myObjectClassName", //
37 // myObject, "TimerDone()"); //
38 // timer->Start(2000, kTRUE); // 2 seconds single-shot //
39 // //
40 // // Timeout signal is emitted repeadetly with minimum timeout //
41 // // timer->Start(0, kFALSE); //
42 // //
43 //////////////////////////////////////////////////////////////////////////
44 
45 #include "TSysEvtHandler.h"
46 #include "TTime.h"
47 #include "TString.h"
48 
49 
50 
51 class TTimer : public TSysEvtHandler {
52 
53 protected:
54  TTime fTime; // time out time in ms
55  TTime fAbsTime; // absolute time out time in ms
56  Bool_t fTimeout; // true if timer has timed out
57  Bool_t fSync; // true if synchrounous timer
58  Bool_t fIntSyscalls; // true is a-synchronous timer is to interrupt system calls
59  UInt_t fTimeID; // the system ID of this timer (for WIN32)
60  TObject *fObject; // object to be notified (if any)
61  TString fCommand; // interpreter command to be executed
62 
63 private:
64  TTimer(const TTimer&); // not implemented
65  TTimer& operator=(const TTimer&); // not implemented
66 
67 public:
68  TTimer(Long_t milliSec = 0, Bool_t mode = kTRUE);
69  TTimer(TObject *obj, Long_t milliSec, Bool_t mode = kTRUE);
70  TTimer(const char *command, Long_t milliSec, Bool_t mode = kTRUE);
71  virtual ~TTimer() { Remove(); }
72 
73  Bool_t CheckTimer(const TTime &now);
74  const char *GetCommand() const { return fCommand.Data(); }
75  TObject *GetObject() { return fObject; }
76  TTime GetTime() const { return fTime; }
77  UInt_t GetTimerID() { return fTimeID;}
78  TTime GetAbsTime() const { return fAbsTime; }
79  Bool_t HasTimedOut() const { return fTimeout; }
80  Bool_t IsSync() const { return fSync; }
81  Bool_t IsAsync() const { return !fSync; }
82  Bool_t IsInterruptingSyscalls() const { return fIntSyscalls; }
83  virtual Bool_t Notify();
84  void Add() { TurnOn(); }
85  void Remove() { TurnOff(); }
86  void Reset();
87  void SetCommand(const char *command);
88  void SetObject(TObject *object);
89  void SetInterruptSyscalls(Bool_t set = kTRUE);
90  void SetTime(Long_t milliSec) { fTime = milliSec; }
91  void SetTimerID(UInt_t id = 0) { fTimeID = id; }
92  virtual void Start(Long_t milliSec = -1, Bool_t singleShot = kFALSE);
93  virtual void Stop() { TurnOff(); }
94  virtual void TurnOn(); //*SIGNAL*
95  virtual void TurnOff(); //*SIGNAL*
96  virtual void Timeout() { Emit("Timeout()"); } //*SIGNAL*
97 
98  static void SingleShot(Int_t milliSec, const char *receiver_class,
99  void *receiver, const char *method);
100 
101  ClassDef(TTimer,0) //Handle timer event
102 };
103 
104 #endif