diff options
Diffstat (limited to 'rules.js')
-rw-r--r-- | rules.js | 87 |
1 files changed, 26 insertions, 61 deletions
@@ -147,6 +147,7 @@ function start_of_player_turn() { const args = get_active_node_args(); const player = faction_player_map[args.f]; log_h2(player, player); + game.faction_turn = args.f; resolve_active_and_proceed(); } const engine_functions = { @@ -261,19 +262,17 @@ function game_view(state, player) { engine: game.engine, log: game.log, prompt: null, - location: game.location, - selected: game.selected, bag_of_glory: game.bag_of_glory, bonuses: game.bonuses, current_events: game.current_events, - final_bid: game.final_bid[faction_id], fronts: game.fronts, glory: game.glory, hand: game.hands[faction_id], hero_points: game.hero_points, initiative: game.initiative, medallions: game.medallions, - selected_card: game.chosen_cards[faction_id], + played_card: game.played_card, + selected_cards: game.selected_cards[faction_id], tableaus: game.tableaus, tracks: game.tracks, triggered_track_effects: game.triggered_track_effects, @@ -315,11 +314,7 @@ function setup(seed, _scenario, _options) { f: [], }, engine: [], - final_bid: { - a: [], - c: [], - m: [], - }, + faction_turn: null, fronts: { a: { value: -2, @@ -354,11 +349,6 @@ function setup(seed, _scenario, _options) { m: 0, pool: 14, }, - chosen_cards: { - a: null, - c: null, - m: null, - }, initiative: data_1.MODERATES_ID, medallions: { a: [], @@ -366,6 +356,12 @@ function setup(seed, _scenario, _options) { m: [], pool: [], }, + played_card: null, + selected_cards: { + a: [], + c: [], + m: [], + }, tableaus: { a: [], c: [], @@ -383,7 +379,6 @@ function setup(seed, _scenario, _options) { used_medallions: [], turn: 0, year: 0, - state_data: null, }; draw_medallions(); start_year(); @@ -438,7 +433,7 @@ states.activate_icon = { inactive: 'activate an icon', prompt() { view.prompt = 'Choose an icon to activate'; - const c = cards[game.chosen_cards[get_active_faction_id()]]; + const c = cards[game.selected_cards[get_active_faction_id()][0]]; for (const i of c.icons) { gen_action(i); } @@ -774,7 +769,7 @@ states.choose_card = { gen_action_card(c); }, card(c) { - game.chosen_cards[player_faction_map[game.active]] = c; + game.selected_cards[player_faction_map[game.active]].push(c); resolve_active_and_proceed(); }, }; @@ -784,7 +779,7 @@ states.choose_final_bid = { view.prompt = 'Choose a card to add to the Final Bid'; const faction = get_active_faction(); for (let c of game.hands[faction]) { - if (!game.final_bid[faction].includes(c)) { + if (!game.selected_cards[faction].includes(c)) { gen_action_card(c); } } @@ -792,8 +787,8 @@ states.choose_final_bid = { }, card(c) { const faction = get_active_faction(); - game.final_bid[faction].push(c); - if (game.final_bid[faction].length < 3) { + game.selected_cards[faction].push(c); + if (game.selected_cards[faction].length < 3) { next(); } else { @@ -1033,7 +1028,7 @@ states.player_turn = { prompt() { const faction_id = get_faction_id(game.active); const can_spend_hp = game.hero_points[faction_id] > 0; - const can_play_card = game.hands[faction_id].includes(game.chosen_cards[faction_id]); + const can_play_card = game.hands[faction_id].includes(game.selected_cards[faction_id][0]); view.prompt = 'Play a card or spend Hero points'; if (!(can_play_card || can_spend_hp)) { view.prompt = 'End turn'; @@ -1053,11 +1048,14 @@ states.player_turn = { } }, done() { + game.faction_turn = null; + game.played_card = null; resolve_active_and_proceed(true); }, play_for_ap() { const faction_id = get_faction_id(game.active); - const card = game.chosen_cards[faction_id]; + const card = game.selected_cards[faction_id][0]; + game.played_card = card; log_h3(`${game.active} plays ${cards[card].title} for the Action Points`); array_remove(game.hands[faction_id], game.hands[faction_id].indexOf(card)); game.tableaus[faction_id].push(card); @@ -1071,7 +1069,8 @@ states.player_turn = { }, play_for_event() { const faction_id = get_faction_id(game.active); - const card = game.chosen_cards[faction_id]; + const card = game.selected_cards[faction_id][0]; + game.played_card = card; array_remove(game.hands[faction_id], game.hands[faction_id].indexOf(card)); game.trash[faction_id].push(card); log_h3(`${game.active} plays ${cards[card].title} for the Event`); @@ -1219,7 +1218,6 @@ states.swap_card_tableau_hand = { gen_action_card(c); } }, - card(c) { }, }; states.take_hero_points = { inactive: 'take Hero Points', @@ -1550,7 +1548,7 @@ function resolve_final_bid() { let winners = []; for (const f of get_player_order()) { let player_bid = 0; - for (const c of game.final_bid[f]) { + for (const c of game.selected_cards[f]) { player_bid += cards[c].strength; } log(`${faction_player_map[f]} bids ${player_bid}`); @@ -1561,9 +1559,9 @@ function resolve_final_bid() { highest_bid = player_bid; winners = [f]; } - game.hands[f] = game.hands[f].filter((c) => !game.final_bid[f].includes(c)); - game.discard[f].concat(game.final_bid[f]); - game.final_bid[f] = []; + game.hands[f] = game.hands[f].filter((c) => !game.selected_cards[f].includes(c)); + game.discard[f].concat(game.selected_cards[f]); + game.selected_cards[f] = []; } if (winners.length === 1) { win_final_bid(winners[0]); @@ -2120,39 +2118,6 @@ function array_insert(array, index, item) { array[i] = array[i - 1]; array[index] = item; } -function set_clear(set) { - set.length = 0; -} -function set_has(set, item) { - let a = 0; - let b = set.length - 1; - while (a <= b) { - const m = (a + b) >> 1; - const x = set[m]; - if (item < x) - b = m - 1; - else if (item > x) - a = m + 1; - else - return true; - } - return false; -} -function set_add(set, item) { - let a = 0; - let b = set.length - 1; - while (a <= b) { - const m = (a + b) >> 1; - const x = set[m]; - if (item < x) - b = m - 1; - else if (item > x) - a = m + 1; - else - return set; - } - return array_insert(set, a, item); -} function set_delete(set, item) { let a = 0; let b = set.length - 1; |