summaryrefslogtreecommitdiff
path: root/game
diff options
context:
space:
mode:
authorDan Goodliffe <dan@randomdan.homeip.net>2021-03-09 01:21:04 +0000
committerDan Goodliffe <dan@randomdan.homeip.net>2021-03-09 01:21:04 +0000
commit82e51328e0cc1e1e17565420fecb05df68827f07 (patch)
tree1449db69349bfa59242a862e6d5a50b32782115d /game
parentPush link based movement into Vehicle (diff)
downloadilt-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.h2
-rw-r--r--game/activities/idle.h2
-rw-r--r--game/activity.h10
-rw-r--r--game/activityOf.h17
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