blob: 933d8f2819a93359a54b9a67cd9877f6df43528f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
/***************************************************************************
timecontrol.h - description
-------------------
begin : Son Jan 12 2003
copyright : (C) 2003 by Martin Witte
email : [email protected]
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef KRADIO_TIMECONTROL_H
#define KRADIO_TIMECONTROL_H
#include <tqobject.h>
#include <tqtimer.h>
#include "../../src/include/alarm.h"
#include "../../src/include/plugins.h"
#include "../../src/include/timecontrol_interfaces.h"
// well, it has to be a TQObject :( , but only for
// receiving TQTimer - timeouts
class TimeControl : public TQObject,
public PluginBase,
public ITimeControl
{
Q_OBJECT
protected:
AlarmVector m_alarms;
Alarm const * m_waitingFor; // m_alarmTimer is exactly for this date/time
int m_countdownSeconds; // in seconds
TQDateTime m_countdownEnd;
TQTimer m_alarmTimer;
TQTimer m_countdownTimer;
mutable TQDateTime m_nextAlarm_tmp; // used to recognize nextAlarm changes
public:
TimeControl (const TQString &name);
~TimeControl();
virtual TQString pluginClassName() const { return "TimeControl"; }
virtual const TQString &name() const { return PluginBase::name(); }
virtual TQString &name() { return PluginBase::name(); }
virtual bool connectI (Interface *i);
virtual bool disconnectI (Interface *i);
// PluginBase
public:
virtual void saveState (TDEConfig *) const;
virtual void restoreState (TDEConfig *);
virtual ConfigPageInfo createConfigurationPage();
virtual AboutPageInfo createAboutPage();
// ITimeControl Interface methods
RECEIVERS:
bool setAlarms(const AlarmVector &sl);
bool setCountdownSeconds(int n);
bool startCountdown();
bool stopCountdown();
ANSWERS:
TQDateTime getNextAlarmTime () const;
const Alarm* getNextAlarm () const;
const AlarmVector & getAlarms () const { return m_alarms; }
int getCountdownSeconds () const { return m_countdownSeconds; }
TQDateTime getCountdownEnd () const;
// slots for receiving timeout messages of timers
protected slots:
virtual void slotQTimerAlarmTimeout();
virtual void slotQTimerCountdownTimeout();
};
#endif
|