diff options
| author | Kelly Rauchenberger <fefferburbia@gmail.com> | 2018-05-17 15:55:37 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-05-17 15:55:37 -0400 |
| commit | 90aadf3844386824140a20d7fbb847bc16009a94 (patch) | |
| tree | 6f83fce90e71abb22b1a8f3e09c79963b2a34d5d /src/components/schedulable.h | |
| parent | bc63fa57ced1c7329f7fdcfd168eaf7e290158bc (diff) | |
| parent | 86f0106d0523825549f1e74b835688c78a10cf6c (diff) | |
| download | therapy-90aadf3844386824140a20d7fbb847bc16009a94.tar.gz therapy-90aadf3844386824140a20d7fbb847bc16009a94.tar.bz2 therapy-90aadf3844386824140a20d7fbb847bc16009a94.zip | |
Merge pull request #7 from hatkirby/es-rewrite
The ECS rewrite exceeds the original branch in functionality, so it is time to merge it in.
Diffstat (limited to 'src/components/schedulable.h')
| -rw-r--r-- | src/components/schedulable.h | 21 |
1 files changed, 21 insertions, 0 deletions
| diff --git a/src/components/schedulable.h b/src/components/schedulable.h new file mode 100644 index 0000000..a92bbba --- /dev/null +++ b/src/components/schedulable.h | |||
| @@ -0,0 +1,21 @@ | |||
| 1 | #ifndef SCHEDULABLE_H_1DA3FA2A | ||
| 2 | #define SCHEDULABLE_H_1DA3FA2A | ||
| 3 | |||
| 4 | #include "component.h" | ||
| 5 | #include <tuple> | ||
| 6 | #include <list> | ||
| 7 | #include <functional> | ||
| 8 | #include "entity_manager.h" | ||
| 9 | |||
| 10 | class SchedulableComponent : public Component { | ||
| 11 | public: | ||
| 12 | |||
| 13 | using id_type = EntityManager::id_type; | ||
| 14 | |||
| 15 | using Callback = std::function<void(id_type)>; | ||
| 16 | using Action = std::tuple<double, Callback>; | ||
| 17 | |||
| 18 | std::list<Action> actions; | ||
| 19 | }; | ||
| 20 | |||
| 21 | #endif /* end of include guard: SCHEDULABLE_H_1DA3FA2A */ | ||
