summaryrefslogtreecommitdiff
path: root/rules.js
diff options
context:
space:
mode:
authorTor Andersson <tor@ccxvii.net>2024-10-18 00:52:03 +0200
committerTor Andersson <tor@ccxvii.net>2024-10-18 00:52:03 +0200
commit0896110768cfa63710c362a4dfa3b15de551b882 (patch)
tree759650871e71af532067cbcde6fdfb3e1d732f3d /rules.js
parent0e80195d27b4eab2af57b89d6f9348cb39de19d4 (diff)
downloadmaria-0896110768cfa63710c362a4dfa3b15de551b882.tar.gz
Protect from conquests.
Diffstat (limited to 'rules.js')
-rw-r--r--rules.js24
1 files changed, 15 insertions, 9 deletions
diff --git a/rules.js b/rules.js
index b2ebc3a..390494b 100644
--- a/rules.js
+++ b/rules.js
@@ -4,7 +4,6 @@
/* TODO
-victory & elector marker
victory check
supreme commander in mixed stacks
supply phase
@@ -537,6 +536,13 @@ function is_friendly_minor_home_country(s) {
return false
}
+function get_home_power(s) {
+ for (let pow of all_powers)
+ if (set_has(all_home_country_fortresses[pow], s))
+ return pow
+ return -1
+}
+
function is_enemy_controlled_fortress(s) {
for (let other of all_enemy_powers(game.power))
if (is_power_controlled_fortress(other, s))
@@ -575,14 +581,14 @@ function is_space_protected_by_piece(s, p) {
}
function is_protected_from_conquest(s) {
- /*
- TODO
- for (let pow of all_powers) {
- for (let p of all_power_generals[pow])
- if (is_space_protected_by_piece(s, p))
- return true
- }
- */
+ let owner = map_get(game.elector, s, -1)
+ if (owner < 0)
+ owner = map_get(game.victory, s, -1)
+ if (owner < 0)
+ owner = get_home_power(s)
+ for (let p of all_coop_generals(owner))
+ if (is_space_protected_by_piece(s, p))
+ return true
return false
}