/// /// module TurnSequence { export var rulebook = new Rulebook("Turn Sequence"); export var playerActions = []; export let lastTurnTime : number = 0; export async function execute (action? : Action) { // Only one action at a time if (playerActions.push(action) == 1) { let t0 = performance.now(); console.debug(Rulebook.getIndentation() + " Player Action: " + (action ? action.getCommandText() : "none")); await rulebook.execute({ noun: action }); playerActions = []; let t1 = performance.now(); lastTurnTime = t1 - t0; console.debug("Total: " + (t1 - t0) + " milliseconds."); if (Settings.sayTurnTime) { Elements.CurrentTurnHandler.printAsContent(new Say(new SayBold("Time taken for turn: "), (t1 - t0), " milliseconds.")); } } } /** * This is the Prepare Elements for the turn rule. * @type {Rule} */ export var PrepareElementsRule = new Rule({ firstPriority: Rule.PRIORITY_HIGHEST, // This will be about the first Rule to be executed priority: Rule.PRIORITY_MEDIUM, // This needs to be done before the majority of the rules, but we don't want it to be the very first no matter what name: "Begin Turn (Elements Side)", code: function (runner : RulebookRunner) { Elements.CurrentTurnHandler.startTurn(runner.noun); } }); TurnSequence.rulebook.addRule(PrepareElementsRule); /** * This is the Do Player Action Rule. * @type {Rule} */ export let PlayerActionRule = new Rule({ firstPriority: Rule.PRIORITY_HIGH, priority: Rule.PRIORITY_MEDIUM, name: "Do Player Action", code: async (rulebook : RulebookRunner) => { let playerAction = rulebook.noun; if (playerAction != undefined) { let promise = playerAction.execute(); await promise; Elements.CurrentTurnHandler.printAsContent(playerAction.say); if (playerAction.requiresTurn) { WorldState.incrementPlayerTurn(); } } } }); rulebook.addRule(PlayerActionRule); /** * This is the Run Every Turn Rules. * @type {Rule} */ export var RunEveryTurnRulesRule = new Rule({ firstPriority: Rule.PRIORITY_MEDIUM, priority: Rule.PRIORITY_MEDIUM, name: "Run Every Turn Rules", code: async function () { while (WorldState.isTurnWaiting()) { await EveryTurn.EveryTurn.execute({}); } } }); rulebook.addRule(RunEveryTurnRulesRule); /** * This is the Inform Elements the turn has ended rule. * @type {Rule} */ export var RemoveTurnFromElementsRule = new Rule({ firstPriority: Rule.PRIORITY_LOWEST, // This will be about the last rule to be executed priority: Rule.PRIORITY_MEDIUM, // This needs to be done after the majority of the rules, but we don't care if it's the very last or not name: "End Turn (Elements/Controls Side)", code: async function (rulebook : RulebookRunner) { Elements.CurrentTurnHandler.endTurn(); Controls.KeyHandler.reset(); await Elements.HyperlinkHandler.hyperlinkCommonActions(); await Elements.RoomHandler.updateRoom(); await Elements.RememberedHandler.updateMap(); let playerAction = rulebook.noun; console.log(playerAction); if (playerAction) { await Elements.HyperlinkHandler.hyperlinkObject(playerAction.getNoun(0)); } else { await Elements.HyperlinkHandler.hyperlinkObject(); } await Elements.InventoryHandler.updateInventory(); await Elements.AppearanceHandler.updateAppearance(); //await Elements.StatusLineHandler.updateStatusLine(); } }); TurnSequence.rulebook.addRule(RemoveTurnFromElementsRule); }