File: GameJobDispatcher.h

package info (click to toggle)
spring 104.0%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 47,512 kB
  • sloc: cpp: 391,093; ansic: 79,943; python: 12,356; java: 12,201; awk: 5,889; sh: 1,826; xml: 655; makefile: 486; perl: 405; php: 211; objc: 194; sed: 2
file content (69 lines) | stat: -rw-r--r-- 1,276 bytes parent folder | download | duplicates (4)
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
/* This file is part of the Spring engine (GPL v2 or later), see LICENSE.html */

#ifndef _GAME_JOB_DISPATCHER_H
#define _GAME_JOB_DISPATCHER_H

#include <functional>
#include <queue>

#include "System/Misc/SpringTime.h"

class JobDispatcher {
public:
	struct Job {
	public:
		Job(const spring_time t = spring_notime)
		: time(t.toMilliSecsf())
		, freq(0.0f)

		, startDirect(true)
		, catchUp(false)

		, name("")
		{}

		void UpdateTime(float msecs) { time = (catchUp? time: msecs) + (1000.0f / freq); }

		bool operator < (const Job& j) const { return (time < j.time); }
		bool operator > (const Job& j) const { return (time > j.time); }

	public:
		std::function<bool()> f; // allows us to use lambdas

		float time;
		float freq;

		bool startDirect;
		bool catchUp;

		const char* name;
	};

public:
	void AddTimedJob(const Job& j) { jobs.push(j); }
	void Update() {
		const spring_time now = spring_gettime();

		while (!jobs.empty()) {
			Job j = jobs.top();

			if (j.time > now.toMilliSecsf())
				break;

			jobs.pop();

			if (!j.f())
				continue;

			j.UpdateTime(now.toMilliSecsf());
			AddTimedJob(j);
		}
	}

private:
	// job with smallest next-to-execute time goes at the top
	std::priority_queue<Job, std::vector<Job>, std::greater<Job>> jobs;
};

#endif