diff options
author | Dan Goodliffe <dan@randomdan.homeip.net> | 2021-03-09 01:21:04 +0000 |
---|---|---|
committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2021-03-09 01:21:04 +0000 |
commit | 82e51328e0cc1e1e17565420fecb05df68827f07 (patch) | |
tree | 1449db69349bfa59242a862e6d5a50b32782115d /game | |
parent | Push link based movement into Vehicle (diff) | |
download | ilt-82e51328e0cc1e1e17565420fecb05df68827f07.tar.bz2 ilt-82e51328e0cc1e1e17565420fecb05df68827f07.tar.xz ilt-82e51328e0cc1e1e17565420fecb05df68827f07.zip |
Split ActivityOf<> into its own file
Diffstat (limited to 'game')
-rw-r--r-- | game/activities/go.h | 2 | ||||
-rw-r--r-- | game/activities/idle.h | 2 | ||||
-rw-r--r-- | game/activity.h | 10 | ||||
-rw-r--r-- | game/activityOf.h | 17 |
4 files changed, 19 insertions, 12 deletions
diff --git a/game/activities/go.h b/game/activities/go.h index 8727539..858b804 100644 --- a/game/activities/go.h +++ b/game/activities/go.h @@ -1,7 +1,7 @@ #ifndef GO_H #define GO_H -#include "../activity.h" +#include "../activityOf.h" class Go : public Activity::Of<Go> { public: diff --git a/game/activities/idle.h b/game/activities/idle.h index 04bc6e5..902d014 100644 --- a/game/activities/idle.h +++ b/game/activities/idle.h @@ -1,7 +1,7 @@ #ifndef IDLE_H #define IDLE_H -#include "../activity.h" +#include "../activityOf.h" class Idle : public Activity::Of<Idle> { public: diff --git a/game/activity.h b/game/activity.h index 33c36fd..f7eda21 100644 --- a/game/activity.h +++ b/game/activity.h @@ -25,14 +25,4 @@ public: virtual void doActivity(const AC *, TickDuration) = 0; }; -template<typename T> class Activity::Of : public Activity { - void - apply(Vehicle * v, TickDuration dur) const override - { - if (auto tv = dynamic_cast<Can<T> *>(v)) { - tv->doActivity(static_cast<const T *>(this), dur); - } - } -}; - #endif diff --git a/game/activityOf.h b/game/activityOf.h new file mode 100644 index 0000000..a26efd1 --- /dev/null +++ b/game/activityOf.h @@ -0,0 +1,17 @@ +#ifndef ACTIVITYOF_H +#define ACTIVITYOF_H + +#include "activity.h" +#include "vehicles/vehicle.h" + +template<typename T> class Activity::Of : public Activity { + void + apply(Vehicle * v, TickDuration dur) const override + { + if (auto tv = dynamic_cast<Can<T> *>(v)) { + tv->doActivity(static_cast<const T *>(this), dur); + } + } +}; + +#endif |