summaryrefslogtreecommitdiff
path: root/rules.js
diff options
context:
space:
mode:
authorTor Andersson <tor@ccxvii.net>2024-08-02 15:46:36 +0200
committerTor Andersson <tor@ccxvii.net>2024-08-05 20:46:48 +0200
commit4a995d6c2a2e680a8e0a3fa49f4a6b6227444316 (patch)
tree11cb6f74405d8100279666e716b95099781841ca /rules.js
parent94986a6b0c821650f580a9731e35cb929eccf0b0 (diff)
downloadtime-of-crisis-4a995d6c2a2e680a8e0a3fa49f4a6b6227444316.tar.gz
v2: new cards and improvements (sans logic)
Diffstat (limited to 'rules.js')
-rw-r--r--rules.js140
1 files changed, 90 insertions, 50 deletions
diff --git a/rules.js b/rules.js
index 31a364d..9362b8e 100644
--- a/rules.js
+++ b/rules.js
@@ -316,11 +316,13 @@ const CARD_S3X = [ 122, 129 ]
const CARD_P3X = [ 130, 137 ]
const CARD_M4 = [ 138, 143 ]
const CARD_S4 = [ 144, 149 ]
-const CARD_S4B = [ 150, 155 ]
+const CARD_S4_V2 = [ 150, 155 ] // updated damnatio
const CARD_P4 = [ 156, 161 ]
const CARD_M4X = [ 162, 167 ]
const CARD_S4X = [ 168, 173 ]
const CARD_P4X = [ 174, 179 ]
+const CARD_S3_V2 = [ 180, 188 ] // updated foederati
+const CARD_P4X_V2 = [ 189, 194 ] // updated demagogue
const CARD_INDEX = [
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3,
@@ -329,6 +331,8 @@ const CARD_INDEX = [
11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15,
15, 15, 15, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 19, 19, 19, 19, 19, 19, 20, 20,
20, 20, 20, 20, 21, 21, 21, 21, 21, 21,
+ 22, 22, 22, 22, 22, 22, 22, 22,
+ 23, 23, 23, 23, 23, 23,
]
const CARD_INFO = [
@@ -354,6 +358,8 @@ const CARD_INFO = [
{ name: "M4(Spiculum)", type: 0, value: 4, event: "Spiculum" },
{ name: "S4(Triumph)", type: 1, value: 4, event: "Triumph" },
{ name: "P4(Demagogue)", type: 2, value: 4, event: "Demagogue" },
+ { name: "S3(Foederati)", type: 1, value: 3, event: "Foederati" },
+ { name: "P4(Demagogue)", type: 2, value: 4, event: "Demagogue" },
]
function card_name(c) {
@@ -483,6 +489,10 @@ const BIT_MILITIA = 1 << 11
const BIT_BREAKAWAY = 1 << 12
const BIT_SEAT_OF_POWER = 1 << 13
const BIT_MILITIA_CASTRA = 1 << 14
+const BIT_MARKET = 1 << 15
+const BIT_MONUMENT = 1 << 16
+const BIT_PORT = 1 << 17
+const BIT_TEMPLE = 1 << 18
function is_no_place_governor(where) {
return where >= game.provinces.length
@@ -517,9 +527,20 @@ function remove_militia(where) { game.provinces[where] &= ~BIT_MILITIA }
function has_amphitheater(where) { return game.provinces[where] & BIT_AMPHITHEATER }
function has_basilica(where) { return game.provinces[where] & BIT_BASILICA }
function has_limes(where) { return game.provinces[where] & BIT_LIMES }
+function has_market(where) { return game.provinces[where] & BIT_MARKET }
+function has_monument(where) { return game.provinces[where] & BIT_MONUMENT }
+function has_port(where) { return game.provinces[where] & BIT_PORT }
+function has_temple(where) { return game.provinces[where] & BIT_TEMPLE }
+
function add_amphitheater(where) { game.provinces[where] |= BIT_AMPHITHEATER }
function add_basilica(where) { game.provinces[where] |= BIT_BASILICA }
function add_limes(where) { game.provinces[where] |= BIT_LIMES }
+function add_market(where) { game.provinces[where] |= BIT_MARKET }
+function add_monument(where) { game.provinces[where] |= BIT_MONUMENT }
+function add_port(where) { game.provinces[where] |= BIT_PORT }
+function add_temple(where) { game.provinces[where] |= BIT_TEMPLE }
+
+function remove_monument(where) { game.provinces[where] &= ~BIT_MONUMENT }
function is_breakaway(where) { return game.provinces[where] & BIT_BREAKAWAY }
function add_breakaway(where) { game.provinces[where] |= BIT_BREAKAWAY }
@@ -2639,7 +2660,7 @@ function goto_place_governor_success() {
place_governor(game.where, game.selected_governor)
- if (old_emperor >= 0 && !was_senate_emperor && (has_card_event(CARD_S4) || has_card_event(CARD_S4B))) {
+ if (old_emperor >= 0 && !was_senate_emperor && (has_card_event(CARD_S4) || has_card_event(CARD_S4_V2))) {
game.count = (old_emperor << 3) | old_support
game.state = "damnatio_memoriae"
} else {
@@ -2710,7 +2731,7 @@ states.damnatio_memoriae = {
prompt() {
prompt("Place Governor: You may play Damnatio Memoriae.")
gen_card_event(CARD_S4)
- gen_card_event(CARD_S4B)
+ gen_card_event(CARD_S4_V2)
view.actions.pass = 1
},
card(c) {
@@ -3757,7 +3778,7 @@ function play_triumph() {
// TODO: skip players who have no turn left (auto-select worst card?)
function can_play_demagogue() {
- return !used_card_event(CARD_P4X)
+ return !used_card_event(CARD_P4X) && !used_card_event(CARD_P4X_V2)
}
function play_demagogue() {
@@ -5460,7 +5481,11 @@ function setup_market_pile(cards) {
let pile = []
for (let c = cards[0]; c <= cards[1]; ++c)
pile.push(c)
- return pile
+ game.market.push(pile)
+}
+
+function setup_market_pile_random(cards1, cards2) {
+ setup_market_pile(random(2) ? cards1 : cards2)
}
function setup_barbarians(tribe, home) {
@@ -5544,59 +5569,74 @@ exports.setup = function (seed, scenario, options) {
game.emperor = NEUTRAL_EMPEROR
}
+ game.market = []
+
switch (scenario) {
default:
case "Standard":
- game.market = [
- setup_market_pile(CARD_M2),
- setup_market_pile(CARD_S2),
- setup_market_pile(CARD_P2),
- setup_market_pile(CARD_M3),
- setup_market_pile(CARD_S3),
- setup_market_pile(CARD_P3),
- setup_market_pile(CARD_M4),
- setup_market_pile(CARD_S4),
- setup_market_pile(CARD_P4),
- ]
+ setup_market_pile(CARD_M2)
+ setup_market_pile(CARD_S2)
+ setup_market_pile(CARD_P2)
+ setup_market_pile(CARD_M3)
+ if (is_classic())
+ setup_market_pile(CARD_S3)
+ else
+ setup_market_pile(CARD_S3_V2)
+ setup_market_pile(CARD_P3)
+ setup_market_pile(CARD_M4)
+ setup_market_pile(CARD_S4)
+ setup_market_pile(CARD_P4)
break
+
case "Expansion - Fixed":
- game.market = [
- setup_market_pile(CARD_M2),
- setup_market_pile(CARD_S2),
- setup_market_pile(CARD_P2),
- setup_market_pile(CARD_M2X),
- setup_market_pile(CARD_S2X),
- setup_market_pile(CARD_P2X),
- setup_market_pile(CARD_M3),
- setup_market_pile(CARD_S3),
- setup_market_pile(CARD_P3),
- setup_market_pile(CARD_M3X),
- setup_market_pile(CARD_S3X),
- setup_market_pile(CARD_P3X),
- setup_market_pile(CARD_M4),
- setup_market_pile(CARD_S4B),
- setup_market_pile(CARD_P4),
- setup_market_pile(CARD_M4X),
- setup_market_pile(CARD_S4X),
- ]
- if (!options.no_demagogue)
- game.market.push(setup_market_pile(CARD_P4X))
+ setup_market_pile(CARD_M2)
+ setup_market_pile(CARD_S2)
+ setup_market_pile(CARD_P2)
+ setup_market_pile(CARD_M2X)
+ setup_market_pile(CARD_S2X)
+ setup_market_pile(CARD_P2X)
+ setup_market_pile(CARD_M3)
+ if (is_classic())
+ setup_market_pile(CARD_S3)
+ else
+ setup_market_pile(CARD_S3_V2)
+ setup_market_pile(CARD_P3)
+ setup_market_pile(CARD_M3X)
+ setup_market_pile(CARD_S3X)
+ setup_market_pile(CARD_P3X)
+ setup_market_pile(CARD_M4)
+ setup_market_pile(CARD_S4_V2)
+ setup_market_pile(CARD_P4)
+ setup_market_pile(CARD_M4X)
+ setup_market_pile(CARD_S4X)
+ if (!options.no_demagogue) {
+ if (is_classic())
+ setup_market_pile(CARD_P4X)
+ else
+ setup_market_pile(CARD_P4X_V2)
+ }
break
+
case "Expansion - Random":
- game.market = [
- setup_market_pile(random(2) ? CARD_M2 : CARD_M2X),
- setup_market_pile(random(2) ? CARD_S2 : CARD_S2X),
- setup_market_pile(random(2) ? CARD_P2 : CARD_P2X),
- setup_market_pile(random(2) ? CARD_M3 : CARD_M3X),
- setup_market_pile(random(2) ? CARD_S3 : CARD_S3X),
- setup_market_pile(random(2) ? CARD_P3 : CARD_P3X),
- setup_market_pile(random(2) ? CARD_M4 : CARD_M4X),
- setup_market_pile(random(2) ? CARD_S4B : CARD_S4X),
- ]
- if (!options.no_demagogue)
- game.market.push(setup_market_pile(random(2) ? CARD_P4 : CARD_P4X))
+ setup_market_pile_random(CARD_M2, CARD_M2X)
+ setup_market_pile_random(CARD_S2, CARD_S2X)
+ setup_market_pile_random(CARD_P2, CARD_P2X)
+ setup_market_pile_random(CARD_M3, CARD_M3X)
+ if (is_classic())
+ setup_market_pile_random(CARD_S3, CARD_S3X)
else
- game.market.push(setup_market_pile(CARD_P4))
+ setup_market_pile_random(CARD_S3_V2, CARD_S3X)
+ setup_market_pile_random(CARD_P3, CARD_P3X)
+ setup_market_pile_random(CARD_M4, CARD_M4X)
+ setup_market_pile_random(CARD_S4_V2, CARD_S4X)
+ if (!options.no_demagogue) {
+ if (is_classic())
+ setup_market_pile_random(CARD_P4, CARD_P4X)
+ else
+ setup_market_pile_random(CARD_P4, CARD_P4X_V2)
+ } else {
+ setup_market_pile(CARD_P4)
+ }
break
}