supertux
squirrel_scheduler.hpp
1 // SuperTux
2 // Copyright (C) 2006 Matthias Braun <matze@braunis.de>
3 //
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
16 
17 #ifndef HEADER_SUPERTUX_SQUIRREL_SQUIRREL_SCHEDULER_HPP
18 #define HEADER_SUPERTUX_SQUIRREL_SQUIRREL_SCHEDULER_HPP
19 
20 #include <vector>
21 
22 #include <simplesquirrel/vm.hpp>
23 
26 class SquirrelScheduler final
27 {
28 public:
29  SquirrelScheduler(ssq::VM& vm);
30 
32  void update(float time);
33 
34  SQInteger schedule_thread(HSQUIRRELVM vm, float time, bool skippable);
35 
36 private:
37  struct ScheduleEntry final
38  {
40  HSQOBJECT thread_ref;
42  float wakeup_time;
43  // true if calling force_wake_up should wake this entry up
44  bool skippable;
45 
46  bool operator<(const ScheduleEntry& other) const
47  {
48  // we need the smallest value on top
49  return wakeup_time > other.wakeup_time;
50  }
51  };
52 
53 private:
54  ssq::VM& m_vm;
55 
56  typedef std::vector<ScheduleEntry> ScheduleHeap;
57  ScheduleHeap schedule;
58 
59 private:
60  SquirrelScheduler(const SquirrelScheduler&) = delete;
61  SquirrelScheduler& operator=(const SquirrelScheduler&) = delete;
62 };
63 
64 #endif
65 
66 /* EOF */
void update(float time)
time must be absolute time, not relative updates, i.e.
Definition: squirrel_scheduler.cpp:35
This class keeps a list of squirrel threads that are scheduled for a certain time.
Definition: squirrel_scheduler.hpp:26