summaryrefslogtreecommitdiffhomepage
path: root/Stars45/CampaignPlanStrategic.h
diff options
context:
space:
mode:
Diffstat (limited to 'Stars45/CampaignPlanStrategic.h')
-rw-r--r--Stars45/CampaignPlanStrategic.h59
1 files changed, 59 insertions, 0 deletions
diff --git a/Stars45/CampaignPlanStrategic.h b/Stars45/CampaignPlanStrategic.h
new file mode 100644
index 0000000..b5376f8
--- /dev/null
+++ b/Stars45/CampaignPlanStrategic.h
@@ -0,0 +1,59 @@
+/* Project Starshatter 4.5
+ Destroyer Studios LLC
+ Copyright © 1997-2004. All Rights Reserved.
+
+ SUBSYSTEM: Stars.exe
+ FILE: CampaignPlanStrategic.h
+ AUTHOR: John DiCamillo
+
+
+ OVERVIEW
+ ========
+ CampaignPlanStrategic prioritizes targets and defensible
+ allied forces as the first step in force tasking. This
+ algorithm computes which enemy resources are most important
+ to attack, based on the AI value of each combat group, and
+ strategic weighting factors that help shape the strategy
+ to the objectives for the current campaign.
+*/
+
+#ifndef CampaignPlanStrategic_h
+#define CampaignPlanStrategic_h
+
+#include "Types.h"
+#include "CampaignPlan.h"
+
+// +--------------------------------------------------------------------+
+
+class CampaignPlanStrategic : public CampaignPlan
+{
+public:
+ static const char* TYPENAME() { return "CampaignPlanStrategic"; }
+
+ CampaignPlanStrategic(Campaign* c) : CampaignPlan(c) { }
+ virtual ~CampaignPlanStrategic() { }
+
+ // operations:
+ virtual void ExecFrame();
+
+protected:
+ void PlaceGroup(CombatGroup* g);
+
+ void ScoreCombatant(Combatant* c);
+
+ void ScoreDefensible(Combatant* c);
+ void ScoreDefend(Combatant* c, CombatGroup* g);
+
+ void ScoreTargets(Combatant* c, Combatant* t);
+ void ScoreTarget(Combatant* c, CombatGroup* g);
+
+ void ScoreNeeds(Combatant* c);
+
+ // zone alocation:
+ void BuildGroupList(CombatGroup* g, List<CombatGroup>& groups);
+ void AssignZones(Combatant* c);
+ void ResolveZoneMovement(CombatGroup* g);
+};
+
+#endif CampaignPlanStrategic_h
+