44dab7f0d7c7200272d63bee021673b6c9723dec
1 import { ChessRules
} from "@/base_rules";
2 import { randInt
} from "@/utils/alea";
3 import { ArrayFun
} from "@/utils/array";
5 export const VariantRules
= class UpsidedownRules
extends ChessRules
{
6 static get HasFlags() {
10 static get HasEnpassant() {
14 getPotentialKingMoves(sq
) {
16 return this.getSlideNJumpMoves(
18 V
.steps
[V
.ROOK
].concat(V
.steps
[V
.BISHOP
]),
23 static GenRandInitFen(randomness
) {
24 if (!randomness
) randomness
= 2;
26 return "RNBQKBNR/PPPPPPPP/8/8/8/8/pppppppp/rnbqkbnr w 0";
28 let pieces
= { w: new Array(8), b: new Array(8) };
29 for (let c
of ["w", "b"]) {
30 if (c
== 'b' && randomness
== 1) {
31 pieces
['b'] = pieces
['w'];
35 let positions
= ArrayFun
.range(8);
37 let randIndex
= randInt(8);
38 const kingPos
= positions
[randIndex
];
39 positions
.splice(randIndex
, 1);
41 // At least a knight must be next to the king:
42 let knight1Pos
= undefined;
43 if (kingPos
== 0) knight1Pos
= 1;
44 else if (kingPos
== V
.size
.y
- 1) knight1Pos
= V
.size
.y
- 2;
45 else knight1Pos
= kingPos
+ (Math
.random() < 0.5 ? 1 : -1);
46 // Search for knight1Pos index in positions and remove it
47 const knight1Index
= positions
.indexOf(knight1Pos
);
48 positions
.splice(knight1Index
, 1);
50 // King+knight1 are on two consecutive squares: one light, one dark
51 randIndex
= 2 * randInt(3);
52 const bishop1Pos
= positions
[randIndex
];
53 let randIndex_tmp
= 2 * randInt(3) + 1;
54 const bishop2Pos
= positions
[randIndex_tmp
];
55 positions
.splice(Math
.max(randIndex
, randIndex_tmp
), 1);
56 positions
.splice(Math
.min(randIndex
, randIndex_tmp
), 1);
58 randIndex
= randInt(4);
59 const knight2Pos
= positions
[randIndex
];
60 positions
.splice(randIndex
, 1);
62 randIndex
= randInt(3);
63 const queenPos
= positions
[randIndex
];
64 positions
.splice(randIndex
, 1);
66 const rook1Pos
= positions
[0];
67 const rook2Pos
= positions
[1];
69 pieces
[c
][rook1Pos
] = "r";
70 pieces
[c
][knight1Pos
] = "n";
71 pieces
[c
][bishop1Pos
] = "b";
72 pieces
[c
][queenPos
] = "q";
73 pieces
[c
][kingPos
] = "k";
74 pieces
[c
][bishop2Pos
] = "b";
75 pieces
[c
][knight2Pos
] = "n";
76 pieces
[c
][rook2Pos
] = "r";
79 pieces
["w"].join("").toUpperCase() +
80 "/PPPPPPPP/8/8/8/8/pppppppp/" +
81 pieces
["b"].join("") +
83 ); //no castle, no en-passant