@gamepark/rules-api 6.38.5 → 7.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Action.js +1 -2
- package/dist/Bot.js +15 -37
- package/dist/Bot.js.map +1 -1
- package/dist/Competitive.js +3 -9
- package/dist/Competitive.js.map +1 -1
- package/dist/Eliminations.js +2 -6
- package/dist/Eliminations.js.map +1 -1
- package/dist/GameSetup.js +1 -2
- package/dist/HiddenInformation.js +2 -6
- package/dist/HiddenInformation.js.map +1 -1
- package/dist/LocalMovePreview.js +1 -5
- package/dist/LocalMovePreview.js.map +1 -1
- package/dist/RandomMove.js +1 -2
- package/dist/Rules.js +49 -59
- package/dist/Rules.js.map +1 -1
- package/dist/SecretInformation.d.ts +11 -0
- package/dist/SecretInformation.js +2 -6
- package/dist/SecretInformation.js.map +1 -1
- package/dist/TimeLimit.js +1 -5
- package/dist/TimeLimit.js.map +1 -1
- package/dist/Undo.js +2 -6
- package/dist/Undo.js.map +1 -1
- package/dist/UnpredictableMove.js +1 -5
- package/dist/UnpredictableMove.js.map +1 -1
- package/dist/index.js +16 -32
- package/dist/index.js.map +1 -1
- package/dist/material/HiddenMaterialRules.d.ts +1 -1
- package/dist/material/HiddenMaterialRules.js +125 -189
- package/dist/material/HiddenMaterialRules.js.map +1 -1
- package/dist/material/MaterialGame.js +1 -2
- package/dist/material/MaterialGameSetup.js +52 -70
- package/dist/material/MaterialGameSetup.js.map +1 -1
- package/dist/material/MaterialRules.d.ts +1 -1
- package/dist/material/MaterialRules.js +186 -255
- package/dist/material/MaterialRules.js.map +1 -1
- package/dist/material/SecretMaterialRules.js +9 -35
- package/dist/material/SecretMaterialRules.js.map +1 -1
- package/dist/material/index.js +11 -27
- package/dist/material/index.js.map +1 -1
- package/dist/material/items/Material.js +177 -268
- package/dist/material/items/Material.js.map +1 -1
- package/dist/material/items/MaterialDeck.js +10 -36
- package/dist/material/items/MaterialDeck.js.map +1 -1
- package/dist/material/items/MaterialItem.js +1 -2
- package/dist/material/items/MaterialMoney.js +89 -147
- package/dist/material/items/MaterialMoney.js.map +1 -1
- package/dist/material/items/MaterialMutator.js +108 -149
- package/dist/material/items/MaterialMutator.js.map +1 -1
- package/dist/material/items/index.js +5 -21
- package/dist/material/items/index.js.map +1 -1
- package/dist/material/location/Location.js +1 -14
- package/dist/material/location/Location.js.map +1 -1
- package/dist/material/location/LocationBuilder.js +26 -41
- package/dist/material/location/LocationBuilder.js.map +1 -1
- package/dist/material/location/index.js +3 -19
- package/dist/material/location/index.js.map +1 -1
- package/dist/material/location/strategy/FillGapStrategy.js +9 -16
- package/dist/material/location/strategy/FillGapStrategy.js.map +1 -1
- package/dist/material/location/strategy/LocationStrategy.js +1 -2
- package/dist/material/location/strategy/PositiveSequenceStrategy.js +26 -35
- package/dist/material/location/strategy/PositiveSequenceStrategy.js.map +1 -1
- package/dist/material/location/strategy/StackingStrategy.js +15 -22
- package/dist/material/location/strategy/StackingStrategy.js.map +1 -1
- package/dist/material/location/strategy/index.js +5 -23
- package/dist/material/location/strategy/index.js.map +1 -1
- package/dist/material/memory/GameMemory.js +10 -14
- package/dist/material/memory/GameMemory.js.map +1 -1
- package/dist/material/memory/PlayerMemory.js +13 -18
- package/dist/material/memory/PlayerMemory.js.map +1 -1
- package/dist/material/memory/index.js +2 -18
- package/dist/material/memory/index.js.map +1 -1
- package/dist/material/moves/CustomMove.js +4 -9
- package/dist/material/moves/CustomMove.js.map +1 -1
- package/dist/material/moves/MaterialMove.js +1 -2
- package/dist/material/moves/MaterialMoveBuilder.js +16 -32
- package/dist/material/moves/MaterialMoveBuilder.js.map +1 -1
- package/dist/material/moves/MoveKind.js +2 -5
- package/dist/material/moves/MoveKind.js.map +1 -1
- package/dist/material/moves/index.js +7 -23
- package/dist/material/moves/index.js.map +1 -1
- package/dist/material/moves/items/CreateItem.js +6 -13
- package/dist/material/moves/items/CreateItem.js.map +1 -1
- package/dist/material/moves/items/CreateItemsAtOnce.js +6 -13
- package/dist/material/moves/items/CreateItemsAtOnce.js.map +1 -1
- package/dist/material/moves/items/DeleteItem.js +6 -13
- package/dist/material/moves/items/DeleteItem.js.map +1 -1
- package/dist/material/moves/items/DeleteItemsAtOnce.js +6 -13
- package/dist/material/moves/items/DeleteItemsAtOnce.js.map +1 -1
- package/dist/material/moves/items/ItemMove.js +1 -2
- package/dist/material/moves/items/ItemMoveType.js +2 -5
- package/dist/material/moves/items/ItemMoveType.js.map +1 -1
- package/dist/material/moves/items/MoveItem.js +6 -13
- package/dist/material/moves/items/MoveItem.js.map +1 -1
- package/dist/material/moves/items/MoveItemsAtOnce.js +6 -13
- package/dist/material/moves/items/MoveItemsAtOnce.js.map +1 -1
- package/dist/material/moves/items/RollItem.js +6 -13
- package/dist/material/moves/items/RollItem.js.map +1 -1
- package/dist/material/moves/items/SelectItem.js +6 -13
- package/dist/material/moves/items/SelectItem.js.map +1 -1
- package/dist/material/moves/items/Shuffle.js +7 -15
- package/dist/material/moves/items/Shuffle.js.map +1 -1
- package/dist/material/moves/items/index.js +11 -27
- package/dist/material/moves/items/index.js.map +1 -1
- package/dist/material/moves/local/CloseTutorialPopup.js +4 -8
- package/dist/material/moves/local/CloseTutorialPopup.js.map +1 -1
- package/dist/material/moves/local/DisplayHelp.js +2 -5
- package/dist/material/moves/local/DisplayHelp.js.map +1 -1
- package/dist/material/moves/local/DropItem.js +1 -2
- package/dist/material/moves/local/LocalMove.js +2 -5
- package/dist/material/moves/local/LocalMove.js.map +1 -1
- package/dist/material/moves/local/SetTutorialStep.js +4 -8
- package/dist/material/moves/local/SetTutorialStep.js.map +1 -1
- package/dist/material/moves/local/index.js +5 -21
- package/dist/material/moves/local/index.js.map +1 -1
- package/dist/material/moves/rules/EndGame.js +4 -8
- package/dist/material/moves/rules/EndGame.js.map +1 -1
- package/dist/material/moves/rules/EndPlayerTurn.js +4 -8
- package/dist/material/moves/rules/EndPlayerTurn.js.map +1 -1
- package/dist/material/moves/rules/RuleMove.js +3 -7
- package/dist/material/moves/rules/RuleMove.js.map +1 -1
- package/dist/material/moves/rules/StartPlayerTurn.js +4 -8
- package/dist/material/moves/rules/StartPlayerTurn.js.map +1 -1
- package/dist/material/moves/rules/StartRule.js +4 -8
- package/dist/material/moves/rules/StartRule.js.map +1 -1
- package/dist/material/moves/rules/StartSimultaneousRule.js +4 -8
- package/dist/material/moves/rules/StartSimultaneousRule.js.map +1 -1
- package/dist/material/moves/rules/index.js +6 -22
- package/dist/material/moves/rules/index.js.map +1 -1
- package/dist/material/rules/MaterialRulesPart.d.ts +1 -1
- package/dist/material/rules/MaterialRulesPart.js +38 -63
- package/dist/material/rules/MaterialRulesPart.js.map +1 -1
- package/dist/material/rules/PlayerTurnRule.js +20 -52
- package/dist/material/rules/PlayerTurnRule.js.map +1 -1
- package/dist/material/rules/RuleStep.js +1 -2
- package/dist/material/rules/SimultaneousRule.js +19 -51
- package/dist/material/rules/SimultaneousRule.js.map +1 -1
- package/dist/material/rules/index.js +4 -20
- package/dist/material/rules/index.js.map +1 -1
- package/dist/material/tutorial/TutorialState.js +1 -2
- package/dist/material/tutorial/index.js +1 -17
- package/dist/material/tutorial/index.js.map +1 -1
- package/dist/options/EnumArrayOption.js +3 -7
- package/dist/options/EnumArrayOption.js.map +1 -1
- package/dist/options/EnumOption.js +1 -5
- package/dist/options/EnumOption.js.map +1 -1
- package/dist/options/Option.js +1 -2
- package/dist/options/OptionSpecOf.js +1 -2
- package/dist/options/OptionsSpec.js +1 -2
- package/dist/options/OptionsValidationError.js +6 -28
- package/dist/options/OptionsValidationError.js.map +1 -1
- package/dist/options/PlayerEnumOption.js +19 -33
- package/dist/options/PlayerEnumOption.js.map +1 -1
- package/dist/options/PlayersOptionsSpec.js +1 -2
- package/dist/options/WithIdOption.js +1 -2
- package/dist/options/WithPlayerOptionsSpec.js +1 -5
- package/dist/options/WithPlayerOptionsSpec.js.map +1 -1
- package/dist/options/WithPlayersOptions.js +1 -2
- package/dist/options/index.js +12 -28
- package/dist/options/index.js.map +1 -1
- package/dist/options/isWithPlayerIdOptions.js +3 -7
- package/dist/options/isWithPlayerIdOptions.js.map +1 -1
- package/dist/utils/action-view.util.js +18 -26
- package/dist/utils/action-view.util.js.map +1 -1
- package/dist/utils/action.util.js +11 -17
- package/dist/utils/action.util.js.map +1 -1
- package/dist/utils/adjacent-groups.util.js +33 -42
- package/dist/utils/adjacent-groups.util.js.map +1 -1
- package/dist/utils/automatic-moves.util.js +10 -16
- package/dist/utils/automatic-moves.util.js.map +1 -1
- package/dist/utils/enum.util.js +7 -14
- package/dist/utils/enum.util.js.map +1 -1
- package/dist/utils/game-view.util.js +5 -9
- package/dist/utils/game-view.util.js.map +1 -1
- package/dist/utils/grid.hex.util.js +36 -88
- package/dist/utils/grid.hex.util.js.map +1 -1
- package/dist/utils/grid.squares.util.js +8 -19
- package/dist/utils/grid.squares.util.js.map +1 -1
- package/dist/utils/grid.util.js +1 -5
- package/dist/utils/grid.util.js.map +1 -1
- package/dist/utils/index.js +16 -32
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/listing.util.js +8 -14
- package/dist/utils/listing.util.js.map +1 -1
- package/dist/utils/loops.util.js +3 -7
- package/dist/utils/loops.util.js.map +1 -1
- package/dist/utils/money.util.js +54 -79
- package/dist/utils/money.util.js.map +1 -1
- package/dist/utils/neighbors.util.js +6 -11
- package/dist/utils/neighbors.util.js.map +1 -1
- package/dist/utils/polyhex.util.js +36 -56
- package/dist/utils/polyhex.util.js.map +1 -1
- package/dist/utils/random.util.js +2 -6
- package/dist/utils/random.util.js.map +1 -1
- package/dist/utils/rank.util.js +9 -13
- package/dist/utils/rank.util.js.map +1 -1
- package/package.json +38 -38
- package/dist/ApplyAutomaticMoves.d.ts +0 -2
- package/dist/ApplyAutomaticMoves.js +0 -25
- package/dist/ApplyAutomaticMoves.js.map +0 -1
- package/dist/DefaultGameSetup.d.ts +0 -7
- package/dist/DefaultGameSetup.js +0 -15
- package/dist/DefaultGameSetup.js.map +0 -1
- package/dist/Dummy.d.ts +0 -7
- package/dist/Dummy.js +0 -27
- package/dist/Dummy.js.map +0 -1
- package/dist/GameSetupCreator.d.ts +0 -4
- package/dist/GameSetupCreator.js +0 -3
- package/dist/GameSetupCreator.js.map +0 -1
- package/dist/IncompleteInformation.d.ts +0 -14
- package/dist/IncompleteInformation.js +0 -38
- package/dist/IncompleteInformation.js.map +0 -1
- package/dist/LoopWithFuse.d.ts +0 -4
- package/dist/LoopWithFuse.js +0 -15
- package/dist/LoopWithFuse.js.map +0 -1
- package/dist/Robot.d.ts +0 -1
- package/dist/Robot.js +0 -3
- package/dist/Robot.js.map +0 -1
- package/dist/RulesCreator.d.ts +0 -7
- package/dist/RulesCreator.js +0 -3
- package/dist/RulesCreator.js.map +0 -1
- package/dist/material/location/strategy/StakingStrategy.d.ts +0 -12
- package/dist/material/location/strategy/StakingStrategy.js +0 -32
- package/dist/material/location/strategy/StakingStrategy.js.map +0 -1
- package/dist/material/moves/items/ItemMovesBuilder.d.ts +0 -8
- package/dist/material/moves/items/ItemMovesBuilder.js +0 -34
- package/dist/material/moves/items/ItemMovesBuilder.js.map +0 -1
- package/dist/material/rules/MaterialMoveBuilder.d.ts +0 -9
- package/dist/material/rules/MaterialMoveBuilder.js +0 -28
- package/dist/material/rules/MaterialMoveBuilder.js.map +0 -1
- package/dist/material/rules/MaterialRulesMovesBuilder.d.ts +0 -12
- package/dist/material/rules/MaterialRulesMovesBuilder.js +0 -36
- package/dist/material/rules/MaterialRulesMovesBuilder.js.map +0 -1
- package/dist/setup/DefaultGameSetup.d.ts +0 -7
- package/dist/setup/DefaultGameSetup.js +0 -15
- package/dist/setup/DefaultGameSetup.js.map +0 -1
- package/dist/setup/GameSetup.d.ts +0 -3
- package/dist/setup/GameSetup.js +0 -3
- package/dist/setup/GameSetup.js.map +0 -1
- package/dist/setup/GameSetupCreator.d.ts +0 -4
- package/dist/setup/GameSetupCreator.js +0 -3
- package/dist/setup/GameSetupCreator.js.map +0 -1
- package/dist/setup/index.d.ts +0 -2
- package/dist/setup/index.js +0 -19
- package/dist/setup/index.js.map +0 -1
- package/dist/utils/EnumUtils.d.ts +0 -1
- package/dist/utils/EnumUtils.js +0 -8
- package/dist/utils/EnumUtils.js.map +0 -1
- package/dist/utils/coordinates.util.d.ts +0 -5
- package/dist/utils/coordinates.util.js +0 -16
- package/dist/utils/coordinates.util.js.map +0 -1
- package/dist/utils/isDeadEndMove.util.d.ts +0 -2
- package/dist/utils/isDeadEndMove.util.js +0 -19
- package/dist/utils/isDeadEndMove.util.js.map +0 -1
|
@@ -1,64 +1,48 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Polyhex = void 0;
|
|
4
|
-
var grid_hex_util_1 = require("./grid.hex.util");
|
|
1
|
+
import { getHexagonsAtDistance, HexGridSystem, hexRotate, hexTranslate } from './grid.hex.util';
|
|
5
2
|
/**
|
|
6
3
|
* Class to work on Polyhex (multiple hexagons linked together)
|
|
7
4
|
*/
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
5
|
+
export class Polyhex {
|
|
6
|
+
grid;
|
|
7
|
+
system = HexGridSystem.Axial;
|
|
8
|
+
xMin = 0;
|
|
9
|
+
yMin = 0;
|
|
10
|
+
isEmpty = (value) => value == null; // true for null and undefined
|
|
11
|
+
constructor(grid, config) {
|
|
11
12
|
this.grid = grid;
|
|
12
|
-
this.system =
|
|
13
|
-
this.xMin =
|
|
14
|
-
this.yMin =
|
|
15
|
-
this.isEmpty =
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
this.
|
|
19
|
-
|
|
13
|
+
this.system = config?.system ?? this.system;
|
|
14
|
+
this.xMin = config?.xMin ?? this.xMin;
|
|
15
|
+
this.yMin = config?.yMin ?? this.yMin;
|
|
16
|
+
this.isEmpty = config?.isEmpty ?? this.isEmpty;
|
|
17
|
+
}
|
|
18
|
+
get xMax() {
|
|
19
|
+
return Math.max(...this.grid.map((line) => line.length)) + this.xMin - 1;
|
|
20
|
+
}
|
|
21
|
+
get yMax() {
|
|
22
|
+
return this.grid.length + this.yMin - 1;
|
|
23
|
+
}
|
|
24
|
+
getValue(coordinates) {
|
|
25
|
+
return this.grid[coordinates.y - this.yMin]?.[coordinates.x - this.xMin];
|
|
20
26
|
}
|
|
21
|
-
Object.defineProperty(Polyhex.prototype, "xMax", {
|
|
22
|
-
get: function () {
|
|
23
|
-
return Math.max.apply(Math, this.grid.map(function (line) { return line.length; })) + this.xMin - 1;
|
|
24
|
-
},
|
|
25
|
-
enumerable: false,
|
|
26
|
-
configurable: true
|
|
27
|
-
});
|
|
28
|
-
Object.defineProperty(Polyhex.prototype, "yMax", {
|
|
29
|
-
get: function () {
|
|
30
|
-
return this.grid.length + this.yMin - 1;
|
|
31
|
-
},
|
|
32
|
-
enumerable: false,
|
|
33
|
-
configurable: true
|
|
34
|
-
});
|
|
35
|
-
Polyhex.prototype.getValue = function (coordinates) {
|
|
36
|
-
var _a;
|
|
37
|
-
return (_a = this.grid[coordinates.y - this.yMin]) === null || _a === void 0 ? void 0 : _a[coordinates.x - this.xMin];
|
|
38
|
-
};
|
|
39
27
|
/**
|
|
40
28
|
* Utility function to merge multiple polyhex together to create a bigger polyhex: it merges given polyhex grid in current polyhex.
|
|
41
29
|
* @param polyhex Polyhex to merge in the current polyhex
|
|
42
30
|
* @param location Location to merge the new polyhex in
|
|
43
31
|
* @param onOverlap Callback function when a non-empty value is erased
|
|
44
32
|
*/
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
}; }
|
|
50
|
-
for (var y = 0; y < polyhex.length; y++) {
|
|
51
|
-
for (var x = 0; x < polyhex[y].length; x++) {
|
|
33
|
+
merge(polyhex, location = {}, onOverlap = () => {
|
|
34
|
+
}) {
|
|
35
|
+
for (let y = 0; y < polyhex.length; y++) {
|
|
36
|
+
for (let x = 0; x < polyhex[y].length; x++) {
|
|
52
37
|
if (!this.isEmpty(polyhex[y][x])) {
|
|
53
|
-
|
|
54
|
-
|
|
38
|
+
const rotatedCoordinates = hexRotate({ x, y }, location.rotation, this.system);
|
|
39
|
+
const coordinates = hexTranslate(rotatedCoordinates, { x: location.x ?? 0, y: location.y ?? 0 }, this.system);
|
|
55
40
|
while (coordinates.y < this.yMin) {
|
|
56
41
|
this.grid.unshift([]);
|
|
57
42
|
this.yMin--;
|
|
58
43
|
}
|
|
59
44
|
while (coordinates.x < this.xMin) {
|
|
60
|
-
for (
|
|
61
|
-
var line1 = _c[_i];
|
|
45
|
+
for (const line1 of this.grid) {
|
|
62
46
|
line1.unshift(undefined);
|
|
63
47
|
}
|
|
64
48
|
this.xMin--;
|
|
@@ -73,21 +57,19 @@ var Polyhex = /** @class */ (function () {
|
|
|
73
57
|
}
|
|
74
58
|
}
|
|
75
59
|
}
|
|
76
|
-
}
|
|
60
|
+
}
|
|
77
61
|
/**
|
|
78
62
|
* Get the minimum distance from given hexagon to a hexagon of the polyhex that matches given predicate
|
|
79
63
|
* @param hex Starting hexagon
|
|
80
64
|
* @param predicate The predicate to match (not empty by default)
|
|
81
65
|
* @returns the minimum distance found
|
|
82
66
|
*/
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
var distance = 0;
|
|
87
|
-
var maxDistance = this.xMax + this.yMax - this.xMin - this.yMin;
|
|
67
|
+
getDistance(hex, predicate = (value) => !this.isEmpty(value)) {
|
|
68
|
+
let distance = 0;
|
|
69
|
+
const maxDistance = this.xMax + this.yMax - this.xMin - this.yMin;
|
|
88
70
|
while (distance < maxDistance) {
|
|
89
|
-
|
|
90
|
-
if (hexagonsAtDistance.some(
|
|
71
|
+
const hexagonsAtDistance = getHexagonsAtDistance(hex, distance, this.system);
|
|
72
|
+
if (hexagonsAtDistance.some((hex) => predicate(this.getValue(hex)))) {
|
|
91
73
|
return distance;
|
|
92
74
|
}
|
|
93
75
|
else {
|
|
@@ -95,8 +77,6 @@ var Polyhex = /** @class */ (function () {
|
|
|
95
77
|
}
|
|
96
78
|
}
|
|
97
79
|
return Infinity;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
}());
|
|
101
|
-
exports.Polyhex = Polyhex;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
102
82
|
//# sourceMappingURL=polyhex.util.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"polyhex.util.js","sourceRoot":"","sources":["../../src/utils/polyhex.util.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"polyhex.util.js","sourceRoot":"","sources":["../../src/utils/polyhex.util.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +1,10 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.hasRandomMove = void 0;
|
|
4
1
|
/**
|
|
5
2
|
* Type guard for rules with Random moves
|
|
6
3
|
* @param rules The game's rules
|
|
7
4
|
* @return true if the rules implements {@link RandomMove} interface
|
|
8
5
|
*/
|
|
9
|
-
function hasRandomMove(rules) {
|
|
10
|
-
|
|
6
|
+
export function hasRandomMove(rules) {
|
|
7
|
+
const test = rules;
|
|
11
8
|
return typeof test.randomize === 'function';
|
|
12
9
|
}
|
|
13
|
-
exports.hasRandomMove = hasRandomMove;
|
|
14
10
|
//# sourceMappingURL=random.util.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"random.util.js","sourceRoot":"","sources":["../../src/utils/random.util.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"random.util.js","sourceRoot":"","sources":["../../src/utils/random.util.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AACH,MAAM,UAAU,aAAa,CAC3B,KAAkC;IAElC,MAAM,IAAI,GAAG,KAAuE,CAAA;IACpF,OAAO,OAAO,IAAI,CAAC,SAAS,KAAK,UAAU,CAAA;AAC7C,CAAC"}
|
package/dist/utils/rank.util.js
CHANGED
|
@@ -1,21 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
var Competitive_1 = require("../Competitive");
|
|
5
|
-
var rankPlayers = function (rules, playerA, playerB) {
|
|
6
|
-
if ((0, Competitive_1.isCompetitiveRank)(rules)) {
|
|
1
|
+
import { isCompetitiveRank, isCompetitiveScore } from '../Competitive';
|
|
2
|
+
export const rankPlayers = (rules, playerA, playerB) => {
|
|
3
|
+
if (isCompetitiveRank(rules)) {
|
|
7
4
|
return rules.rankPlayers(playerA, playerB);
|
|
8
5
|
}
|
|
9
|
-
if (
|
|
10
|
-
|
|
11
|
-
|
|
6
|
+
if (isCompetitiveScore(rules)) {
|
|
7
|
+
const scoreA = rules.getScore(playerA);
|
|
8
|
+
const scoreB = rules.getScore(playerB);
|
|
12
9
|
if (scoreA !== scoreB) {
|
|
13
10
|
return rules.rankByLowerScore ? scoreA - scoreB : scoreB - scoreA;
|
|
14
11
|
}
|
|
15
12
|
if (rules.getTieBreaker) {
|
|
16
|
-
for (
|
|
17
|
-
|
|
18
|
-
|
|
13
|
+
for (let tieBreaker = 1; tieBreaker <= 10; tieBreaker++) {
|
|
14
|
+
const tieBreakerA = rules.getTieBreaker(tieBreaker, playerA);
|
|
15
|
+
const tieBreakerB = rules.getTieBreaker(tieBreaker, playerB);
|
|
19
16
|
if (tieBreakerA === undefined) {
|
|
20
17
|
return tieBreakerB === undefined ? 0 : Infinity;
|
|
21
18
|
}
|
|
@@ -31,5 +28,4 @@ var rankPlayers = function (rules, playerA, playerB) {
|
|
|
31
28
|
}
|
|
32
29
|
return 0;
|
|
33
30
|
};
|
|
34
|
-
exports.rankPlayers = rankPlayers;
|
|
35
31
|
//# sourceMappingURL=rank.util.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rank.util.js","sourceRoot":"","sources":["../../src/utils/rank.util.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"rank.util.js","sourceRoot":"","sources":["../../src/utils/rank.util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AAGtE,MAAM,CAAC,MAAM,WAAW,GAAG,CAAiB,KAAgC,EAAE,OAAiB,EAAE,OAAiB,EAAE,EAAE;IACpH,IAAI,iBAAiB,CAAC,KAAK,CAAC,EAAE,CAAC;QAC7B,OAAO,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;IAC5C,CAAC;IACD,IAAI,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;QAC9B,MAAM,MAAM,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;QACtC,MAAM,MAAM,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;QACtC,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;YACtB,OAAO,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAA;QACnE,CAAC;QACD,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;YACxB,KAAK,IAAI,UAAU,GAAG,CAAC,EAAE,UAAU,IAAI,EAAE,EAAE,UAAU,EAAE,EAAE,CAAC;gBACxD,MAAM,WAAW,GAAG,KAAK,CAAC,aAAa,CAAC,UAAU,EAAE,OAAO,CAAC,CAAA;gBAC5D,MAAM,WAAW,GAAG,KAAK,CAAC,aAAa,CAAC,UAAU,EAAE,OAAO,CAAC,CAAA;gBAC5D,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;oBAC9B,OAAO,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAA;gBACjD,CAAC;qBAAM,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;oBACrC,OAAO,CAAC,QAAQ,CAAA;gBAClB,CAAC;qBAAM,IAAI,WAAW,KAAK,WAAW,EAAE,CAAC;oBACvC,OAAO,WAAW,GAAG,WAAW,CAAA;gBAClC,CAAC;YACH,CAAC;YACD,OAAO,CAAC,KAAK,CAAC,kFAAkF,CAAC,CAAA;QACnG,CAAC;IACH,CAAC;IACD,OAAO,CAAC,CAAA;AACV,CAAC,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@gamepark/rules-api",
|
|
3
|
-
"version": "
|
|
4
|
-
"description": "API to implement the rules of a board game",
|
|
5
|
-
"
|
|
6
|
-
"
|
|
7
|
-
"
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
"
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
"
|
|
17
|
-
"
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
"
|
|
21
|
-
"
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
"@types/
|
|
27
|
-
"@types/node": "^
|
|
28
|
-
"
|
|
29
|
-
"
|
|
30
|
-
"
|
|
31
|
-
"ts-jest": "^29.
|
|
32
|
-
"typescript": "^5.
|
|
33
|
-
},
|
|
34
|
-
"peerDependencies": {
|
|
35
|
-
"
|
|
36
|
-
},
|
|
37
|
-
"packageManager": "yarn@
|
|
38
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@gamepark/rules-api",
|
|
3
|
+
"version": "7.0.0-beta.1",
|
|
4
|
+
"description": "API to implement the rules of a board game",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "dist/index.js",
|
|
7
|
+
"types": "dist/index.d.ts",
|
|
8
|
+
"files": [
|
|
9
|
+
"dist"
|
|
10
|
+
],
|
|
11
|
+
"scripts": {
|
|
12
|
+
"build": "tsc",
|
|
13
|
+
"prepublishOnly": "tsc"
|
|
14
|
+
},
|
|
15
|
+
"keywords": [
|
|
16
|
+
"Game Park",
|
|
17
|
+
"Board games",
|
|
18
|
+
"Rules"
|
|
19
|
+
],
|
|
20
|
+
"author": "Romain Fromi <romain@game-park.com> (https://game-park.com/)",
|
|
21
|
+
"license": "ISC",
|
|
22
|
+
"publishConfig": {
|
|
23
|
+
"access": "public"
|
|
24
|
+
},
|
|
25
|
+
"devDependencies": {
|
|
26
|
+
"@types/jest": "^30.0.0",
|
|
27
|
+
"@types/node": "^24.5.1",
|
|
28
|
+
"es-toolkit": "^1.39.10",
|
|
29
|
+
"i18next": "^25.5.2",
|
|
30
|
+
"jest": "^30.1.3",
|
|
31
|
+
"ts-jest": "^29.4.2",
|
|
32
|
+
"typescript": "^5.9.2"
|
|
33
|
+
},
|
|
34
|
+
"peerDependencies": {
|
|
35
|
+
"es-toolkit": "^1.39.10"
|
|
36
|
+
},
|
|
37
|
+
"packageManager": "yarn@4.9.4"
|
|
38
|
+
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.applyAutomaticMoves = void 0;
|
|
4
|
-
var RandomMove_1 = require("./RandomMove");
|
|
5
|
-
var LoopWithFuse_1 = require("./LoopWithFuse");
|
|
6
|
-
function applyAutomaticMoves(rules, moves, preprocessMove) {
|
|
7
|
-
if (moves === void 0) { moves = []; }
|
|
8
|
-
(0, LoopWithFuse_1.loopWithFuse)(function () {
|
|
9
|
-
var _a;
|
|
10
|
-
if (moves.length === 0 && rules.getAutomaticMoves) {
|
|
11
|
-
moves.push.apply(moves, rules.getAutomaticMoves());
|
|
12
|
-
}
|
|
13
|
-
var move = moves.shift();
|
|
14
|
-
if (!move)
|
|
15
|
-
return false;
|
|
16
|
-
var randomizedMove = (0, RandomMove_1.hasRandomMove)(rules) ? rules.randomize(move) : move;
|
|
17
|
-
if (preprocessMove)
|
|
18
|
-
preprocessMove(randomizedMove);
|
|
19
|
-
var consequences = (_a = rules.play(JSON.parse(JSON.stringify(randomizedMove)))) !== null && _a !== void 0 ? _a : [];
|
|
20
|
-
moves.unshift.apply(moves, consequences);
|
|
21
|
-
return true;
|
|
22
|
-
}, { errorFn: function () { return new Error("Infinite loop detected while applying move consequences: ".concat(JSON.stringify(moves), ")")); } });
|
|
23
|
-
}
|
|
24
|
-
exports.applyAutomaticMoves = applyAutomaticMoves;
|
|
25
|
-
//# sourceMappingURL=ApplyAutomaticMoves.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ApplyAutomaticMoves.js","sourceRoot":"","sources":["../src/ApplyAutomaticMoves.ts"],"names":[],"mappings":";;;AAAA,2CAA4C;AAC5C,+CAA6C;AAG7C,SAAgB,mBAAmB,CAAuB,KAAkC,EAAE,KAAkB,EAAE,cAAqC;IAAzD,sBAAA,EAAA,UAAkB;IAC9G,IAAA,2BAAY,EAAC;;QACX,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,iBAAiB,EAAE,CAAC;YAClD,KAAK,CAAC,IAAI,OAAV,KAAK,EAAS,KAAK,CAAC,iBAAiB,EAAE,EAAC;QAC1C,CAAC;QACD,IAAM,IAAI,GAAG,KAAK,CAAC,KAAK,EAAE,CAAA;QAC1B,IAAI,CAAC,IAAI;YAAE,OAAO,KAAK,CAAA;QACvB,IAAM,cAAc,GAAG,IAAA,0BAAa,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QAC1E,IAAI,cAAc;YAAE,cAAc,CAAC,cAAc,CAAC,CAAA;QAClD,IAAM,YAAY,GAAG,MAAA,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,CAAC,mCAAI,EAAE,CAAA;QACjF,KAAK,CAAC,OAAO,OAAb,KAAK,EAAY,YAAY,EAAC;QAC9B,OAAO,IAAI,CAAA;IACb,CAAC,EAAE,EAAC,OAAO,EAAE,cAAM,OAAA,IAAI,KAAK,CAAC,mEAA4D,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAG,CAAC,EAA/F,CAA+F,EAAC,CAAC,CAAA;AACtH,CAAC;AAbD,kDAaC"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { RulesCreator } from './RulesCreator';
|
|
2
|
-
import { GameSetup } from './GameSetup';
|
|
3
|
-
export declare class DefaultGameSetup<Game = any, Move = any, PlayerId = any, Options = any> implements GameSetup<Game, Options> {
|
|
4
|
-
private readonly Rules;
|
|
5
|
-
constructor(Rules: RulesCreator<Game, Move, PlayerId, Options>);
|
|
6
|
-
setup(options: Options): any;
|
|
7
|
-
}
|
package/dist/DefaultGameSetup.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DefaultGameSetup = void 0;
|
|
4
|
-
var DefaultGameSetup = (function () {
|
|
5
|
-
function DefaultGameSetup(Rules) {
|
|
6
|
-
this.Rules = Rules;
|
|
7
|
-
}
|
|
8
|
-
DefaultGameSetup.prototype.setup = function (options) {
|
|
9
|
-
var rules = new this.Rules(options);
|
|
10
|
-
return rules.game;
|
|
11
|
-
};
|
|
12
|
-
return DefaultGameSetup;
|
|
13
|
-
}());
|
|
14
|
-
exports.DefaultGameSetup = DefaultGameSetup;
|
|
15
|
-
//# sourceMappingURL=DefaultGameSetup.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DefaultGameSetup.js","sourceRoot":"","sources":["../src/DefaultGameSetup.ts"],"names":[],"mappings":";;;AAGA;IAGE,0BAAY,KAAkD;QAC5D,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;IAED,gCAAK,GAAL,UAAM,OAAgB;QACpB,IAAM,KAAK,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QACrC,OAAO,KAAK,CAAC,IAAI,CAAA;IACnB,CAAC;IACH,uBAAC;AAAD,CAAC,AAXD,IAWC;AAXY,4CAAgB"}
|
package/dist/Dummy.d.ts
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { RulesCreator } from './RulesCreator';
|
|
2
|
-
export declare class Dummy<Game, Move = string, PlayerId = number> {
|
|
3
|
-
Rules: RulesCreator<Game, Move, PlayerId>;
|
|
4
|
-
constructor(Rules: RulesCreator<Game, Move, PlayerId>);
|
|
5
|
-
getRandomMove(state: Game, playerId: PlayerId): Promise<Move[]>;
|
|
6
|
-
getLegalMoves(state: Game, player: PlayerId): Move[];
|
|
7
|
-
}
|
package/dist/Dummy.js
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Dummy = void 0;
|
|
4
|
-
var Dummy = (function () {
|
|
5
|
-
function Dummy(Rules) {
|
|
6
|
-
this.Rules = Rules;
|
|
7
|
-
}
|
|
8
|
-
Dummy.prototype.getRandomMove = function (state, playerId) {
|
|
9
|
-
var moves = this.getLegalMoves(state, playerId);
|
|
10
|
-
if (!moves.length)
|
|
11
|
-
return Promise.resolve([]);
|
|
12
|
-
return Promise.resolve([moves[Math.floor(Math.random() * moves.length)]]);
|
|
13
|
-
};
|
|
14
|
-
Dummy.prototype.getLegalMoves = function (state, player) {
|
|
15
|
-
var rules = new this.Rules(state, { player: player });
|
|
16
|
-
if (rules.getLegalMoves) {
|
|
17
|
-
return rules.getLegalMoves(player);
|
|
18
|
-
}
|
|
19
|
-
else {
|
|
20
|
-
console.error('Dummy player cannot work if getLegalMoves is not implemented!');
|
|
21
|
-
return [];
|
|
22
|
-
}
|
|
23
|
-
};
|
|
24
|
-
return Dummy;
|
|
25
|
-
}());
|
|
26
|
-
exports.Dummy = Dummy;
|
|
27
|
-
//# sourceMappingURL=Dummy.js.map
|
package/dist/Dummy.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Dummy.js","sourceRoot":"","sources":["../src/Dummy.ts"],"names":[],"mappings":";;;AAEA;IAIE,eAAY,KAAyC;QACnD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;IAED,6BAAa,GAAb,UAAc,KAAW,EAAE,QAAkB;QAC3C,IAAI,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;QAC/C,IAAI,CAAC,KAAK,CAAC,MAAM;YAAE,OAAO,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;QAC7C,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;IAC3E,CAAC;IAED,6BAAa,GAAb,UAAc,KAAW,EAAE,MAAgB;QACzC,IAAM,KAAK,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,MAAM,QAAA,EAAE,CAAC,CAAA;QAC/C,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;YACxB,OAAO,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAA;QACpC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,+DAA+D,CAAC,CAAA;YAC9E,OAAO,EAAE,CAAA;QACX,CAAC;IACH,CAAC;IACH,YAAC;AAAD,CAAC,AAvBD,IAuBC;AAvBY,sBAAK"}
|
package/dist/GameSetupCreator.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"GameSetupCreator.js","sourceRoot":"","sources":["../src/GameSetupCreator.ts"],"names":[],"mappings":""}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { Rules } from './Rules';
|
|
2
|
-
export interface IncompleteInformation<GameView = any, Move = any, MoveView = any> {
|
|
3
|
-
getView(): GameView;
|
|
4
|
-
getMoveView(move: Move): MoveView;
|
|
5
|
-
}
|
|
6
|
-
export declare function hasIncompleteInformation<GameView = any, Move = any, MoveView = any>(rules: Object): rules is IncompleteInformation<GameView, Move, MoveView>;
|
|
7
|
-
export interface SecretInformation<GameView = any, Move = any, MoveView = any, PlayerId = any> extends IncompleteInformation<GameView, Move, MoveView> {
|
|
8
|
-
getPlayerView(playerId: PlayerId): GameView;
|
|
9
|
-
getPlayerMoveView?(move: Move, playerId: PlayerId): MoveView;
|
|
10
|
-
keepMoveSecret?(move: Move, playerId: PlayerId): boolean;
|
|
11
|
-
}
|
|
12
|
-
export declare function hasSecretInformation<GameView = any, Move = any, MoveView = any, PlayerId = any>(rules: Object): rules is SecretInformation<GameView, Move, MoveView, PlayerId>;
|
|
13
|
-
export declare function getGameView<Game, GameView, PlayerId>(rules: Rules<Game, any, PlayerId>, playerId?: PlayerId): GameView;
|
|
14
|
-
export declare function getMoveView<GameView, Move, MoveView, PlayerId>(rules: Rules<any, Move, PlayerId>, move: Move, playerId?: PlayerId): MoveView;
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getMoveView = exports.getGameView = exports.hasSecretInformation = exports.hasIncompleteInformation = void 0;
|
|
4
|
-
function hasIncompleteInformation(rules) {
|
|
5
|
-
var test = rules;
|
|
6
|
-
return typeof test.getView === 'function' && typeof test.getMoveView === 'function';
|
|
7
|
-
}
|
|
8
|
-
exports.hasIncompleteInformation = hasIncompleteInformation;
|
|
9
|
-
function hasSecretInformation(rules) {
|
|
10
|
-
var test = rules;
|
|
11
|
-
return typeof test.getPlayerView === 'function';
|
|
12
|
-
}
|
|
13
|
-
exports.hasSecretInformation = hasSecretInformation;
|
|
14
|
-
function getGameView(rules, playerId) {
|
|
15
|
-
if (hasSecretInformation(rules) && playerId !== undefined) {
|
|
16
|
-
return rules.getPlayerView(playerId);
|
|
17
|
-
}
|
|
18
|
-
else if (hasIncompleteInformation(rules)) {
|
|
19
|
-
return rules.getView();
|
|
20
|
-
}
|
|
21
|
-
else {
|
|
22
|
-
return rules.game;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
exports.getGameView = getGameView;
|
|
26
|
-
function getMoveView(rules, move, playerId) {
|
|
27
|
-
if (hasSecretInformation(rules) && rules.getPlayerMoveView && playerId !== undefined) {
|
|
28
|
-
return JSON.parse(JSON.stringify(rules.getPlayerMoveView(move, playerId)));
|
|
29
|
-
}
|
|
30
|
-
else if (hasIncompleteInformation(rules)) {
|
|
31
|
-
return JSON.parse(JSON.stringify(rules.getMoveView(move)));
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
return move;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
exports.getMoveView = getMoveView;
|
|
38
|
-
//# sourceMappingURL=IncompleteInformation.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"IncompleteInformation.js","sourceRoot":"","sources":["../src/IncompleteInformation.ts"],"names":[],"mappings":";;;AAQA,SAAgB,wBAAwB,CAA6C,KAAa;IAChG,IAAM,IAAI,GAAG,KAAwD,CAAA;IACrE,OAAO,OAAO,IAAI,CAAC,OAAO,KAAK,UAAU,IAAI,OAAO,IAAI,CAAC,WAAW,KAAK,UAAU,CAAA;AACrF,CAAC;AAHD,4DAGC;AAUD,SAAgB,oBAAoB,CAA6D,KAAa;IAC5G,IAAM,IAAI,GAAG,KAA8D,CAAA;IAC3E,OAAO,OAAO,IAAI,CAAC,aAAa,KAAK,UAAU,CAAA;AACjD,CAAC;AAHD,oDAGC;AAED,SAAgB,WAAW,CAA2B,KAAiC,EAAE,QAAmB;IAC1G,IAAI,oBAAoB,CAA+B,KAAK,CAAC,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;QACxF,OAAO,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;IACtC,CAAC;SAAM,IAAI,wBAAwB,CAAW,KAAK,CAAC,EAAE,CAAC;QACrD,OAAO,KAAK,CAAC,OAAO,EAAE,CAAA;IACxB,CAAC;SAAM,CAAC;QACN,OAAO,KAAK,CAAC,IAAuB,CAAA;IACtC,CAAC;AACH,CAAC;AARD,kCAQC;AAED,SAAgB,WAAW,CAAqC,KAAiC,EAAE,IAAU,EAAE,QAAmB;IAChI,IAAI,oBAAoB,CAAqC,KAAK,CAAC,IAAI,KAAK,CAAC,iBAAiB,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;QACzH,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAA;IAC5E,CAAC;SAAM,IAAI,wBAAwB,CAA2B,KAAK,CAAC,EAAE,CAAC;QACrE,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAC5D,CAAC;SAAM,CAAC;QACN,OAAO,IAAuB,CAAA;IAChC,CAAC;AACH,CAAC;AARD,kCAQC"}
|
package/dist/LoopWithFuse.d.ts
DELETED
package/dist/LoopWithFuse.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.loopWithFuse = void 0;
|
|
4
|
-
function loopWithFuse(repeat, options) {
|
|
5
|
-
var attempts = (options === null || options === void 0 ? void 0 : options.attempts) || (process.env.NODE_ENV === 'development' ? 1000 : 10000);
|
|
6
|
-
var errorFn = (options === null || options === void 0 ? void 0 : options.errorFn) || (function () { return new Error('Infinite loop detected'); });
|
|
7
|
-
while (repeat()) {
|
|
8
|
-
if (attempts == 0) {
|
|
9
|
-
throw errorFn();
|
|
10
|
-
}
|
|
11
|
-
attempts--;
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
exports.loopWithFuse = loopWithFuse;
|
|
15
|
-
//# sourceMappingURL=LoopWithFuse.js.map
|
package/dist/LoopWithFuse.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"LoopWithFuse.js","sourceRoot":"","sources":["../src/LoopWithFuse.ts"],"names":[],"mappings":";;;AAAA,SAAgB,YAAY,CAAC,MAAqB,EAAE,OAAsD;IACxG,IAAI,QAAQ,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,KAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;IAC3F,IAAM,OAAO,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,KAAI,CAAC,cAAM,OAAA,IAAI,KAAK,CAAC,wBAAwB,CAAC,EAAnC,CAAmC,CAAC,CAAA;IAC/E,OAAO,MAAM,EAAE,EAAE,CAAC;QAChB,IAAI,QAAQ,IAAI,CAAC,EAAE,CAAC;YAClB,MAAM,OAAO,EAAE,CAAA;QACjB,CAAC;QACD,QAAQ,EAAE,CAAA;IACZ,CAAC;AACH,CAAC;AATD,oCASC"}
|
package/dist/Robot.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export type Robot<Game, Move = string, PlayerId = number> = (state: Game, playerId: PlayerId) => Promise<Move[]>;
|
package/dist/Robot.js
DELETED
package/dist/Robot.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Robot.js","sourceRoot":"","sources":["../src/Robot.ts"],"names":[],"mappings":""}
|
package/dist/RulesCreator.d.ts
DELETED
package/dist/RulesCreator.js
DELETED
package/dist/RulesCreator.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RulesCreator.js","sourceRoot":"","sources":["../src/RulesCreator.ts"],"names":[],"mappings":""}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Material, MaterialItem } from '../../items';
|
|
2
|
-
import { LocationStrategy } from './LocationStrategy';
|
|
3
|
-
/**
|
|
4
|
-
* This strategy will only work on items with the same location.x and location.y, to maintain a positive sequence on location.z,
|
|
5
|
-
* for example to easily stack scoring pawns when they are on the same spot.
|
|
6
|
-
*/
|
|
7
|
-
export declare class StakingStrategy implements LocationStrategy {
|
|
8
|
-
private delegate;
|
|
9
|
-
addItem(material: Material, item: MaterialItem): void;
|
|
10
|
-
moveItem(material: Material, item: MaterialItem, index: number): void;
|
|
11
|
-
removeItem(material: Material, item: MaterialItem): void;
|
|
12
|
-
}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.StakingStrategy = void 0;
|
|
4
|
-
var PositiveSequenceStrategy_1 = require("./PositiveSequenceStrategy");
|
|
5
|
-
/**
|
|
6
|
-
* This strategy will only work on items with the same location.x and location.y, to maintain a positive sequence on location.z,
|
|
7
|
-
* for example to easily stack scoring pawns when they are on the same spot.
|
|
8
|
-
*/
|
|
9
|
-
var StakingStrategy = /** @class */ (function () {
|
|
10
|
-
function StakingStrategy() {
|
|
11
|
-
this.delegate = new PositiveSequenceStrategy_1.PositiveSequenceStrategy('z');
|
|
12
|
-
}
|
|
13
|
-
StakingStrategy.prototype.addItem = function (material, item) {
|
|
14
|
-
this.delegate.addItem(material.location(function (l) { return l.x === item.location.x && l.y === item.location.y; }), item);
|
|
15
|
-
};
|
|
16
|
-
StakingStrategy.prototype.moveItem = function (material, item, index) {
|
|
17
|
-
var itemBefore = material.getItem(index);
|
|
18
|
-
if (itemBefore.location.x === item.location.x && itemBefore.location.y === itemBefore.location.y) {
|
|
19
|
-
this.delegate.moveItem(material, item, index);
|
|
20
|
-
}
|
|
21
|
-
else {
|
|
22
|
-
this.delegate.removeItem(material.index(function (i) { return i !== index; }).location(function (l) { return l.x === itemBefore.location.x && l.y === itemBefore.location.y; }), itemBefore);
|
|
23
|
-
this.delegate.addItem(material.location(function (l) { return l.x === item.location.x && l.y === item.location.y; }), item);
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
StakingStrategy.prototype.removeItem = function (material, item) {
|
|
27
|
-
this.delegate.removeItem(material.location(function (l) { return l.x === item.location.x && l.y === item.location.y; }), item);
|
|
28
|
-
};
|
|
29
|
-
return StakingStrategy;
|
|
30
|
-
}());
|
|
31
|
-
exports.StakingStrategy = StakingStrategy;
|
|
32
|
-
//# sourceMappingURL=StakingStrategy.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"StakingStrategy.js","sourceRoot":"","sources":["../../../../src/material/location/strategy/StakingStrategy.ts"],"names":[],"mappings":";;;AAEA,uEAAqE;AAErE;;;GAGG;AACH;IAAA;QACU,aAAQ,GAAG,IAAI,mDAAwB,CAAC,GAAG,CAAC,CAAA;IAmBtD,CAAC;IAjBC,iCAAO,GAAP,UAAQ,QAAkB,EAAE,IAAkB;QAC5C,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAlD,CAAkD,CAAC,EAAE,IAAI,CAAC,CAAA;IACzG,CAAC;IAED,kCAAQ,GAAR,UAAS,QAAkB,EAAE,IAAkB,EAAE,KAAa;QAC5D,IAAM,UAAU,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;QAC1C,IAAI,UAAU,CAAC,QAAQ,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,UAAU,CAAC,QAAQ,CAAC,CAAC,KAAK,UAAU,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;YACjG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,IAAI,EAAE,KAAK,CAAC,CAAA;QAC/C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,KAAK,KAAK,EAAX,CAAW,CAAC,CAAC,QAAQ,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,KAAK,UAAU,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,UAAU,CAAC,QAAQ,CAAC,CAAC,EAA9D,CAA8D,CAAC,EAAE,UAAU,CAAC,CAAA;YACpJ,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAlD,CAAkD,CAAC,EAAE,IAAI,CAAC,CAAA;QACzG,CAAC;IACH,CAAC;IAED,oCAAU,GAAV,UAAW,QAAkB,EAAE,IAAkB;QAC/C,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAlD,CAAkD,CAAC,EAAE,IAAI,CAAC,CAAA;IAC5G,CAAC;IACH,sBAAC;AAAD,CAAC,AApBD,IAoBC;AApBY,0CAAe"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { MaterialMove } from '../MaterialMove';
|
|
2
|
-
import { MaterialItem } from '../../items';
|
|
3
|
-
export declare class ItemMovesBuilder<Player extends number = number, MaterialType extends number = number, LocationType extends number = number> {
|
|
4
|
-
items: Partial<Record<MaterialType, MaterialItem<Player, LocationType>[]>>;
|
|
5
|
-
moves: MaterialMove<Player, MaterialType, LocationType>[];
|
|
6
|
-
constructor(items: Partial<Record<MaterialType, MaterialItem<Player, LocationType>[]>>);
|
|
7
|
-
shuffle(itemsType: MaterialType, predicate?: (item: MaterialItem<Player, LocationType>) => boolean): this;
|
|
8
|
-
}
|