File: timer.cpp

package info (click to toggle)
ares 126-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 32,600 kB
  • sloc: cpp: 356,508; ansic: 20,394; makefile: 16; sh: 2
file content (46 lines) | stat: -rw-r--r-- 1,014 bytes parent folder | download | duplicates (2)
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
#if defined(Hiro_Timer)

//timeBeginPeriod(1) + timeSetEvent does not seem any more performant than SetTimer
//it also seems buggier, and requires libwinmm

namespace hiro {

static vector<pTimer*> timers;

static auto CALLBACK Timer_timeoutProc(HWND hwnd, UINT msg, UINT_PTR timerID, DWORD time) -> void {
  if(Application::state().quit) return;

  for(auto& timer : timers) {
    if(timer->htimer == timerID) return timer->self().doActivate();
  }
}

auto pTimer::construct() -> void {
  timers.append(this);
  htimer = 0;
}

auto pTimer::destruct() -> void {
  setEnabled(false);
  if(auto index = timers.find(this)) timers.remove(*index);
}

auto pTimer::setEnabled(bool enabled) -> void {
  if(htimer) {
    KillTimer(nullptr, htimer);
    htimer = 0;
  }

  if(enabled == true) {
    htimer = SetTimer(nullptr, 0, state().interval, Timer_timeoutProc);
  }
}

auto pTimer::setInterval(u32 interval) -> void {
  //destroy and recreate timer if interval changed
  setEnabled(self().enabled(true));
}

}

#endif