X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=client%2Fsrc%2Fvariants%2FCircular.js;h=333ad3208967639637d7e04bc0d2fb173f963338;hb=4313762da3237b04f204e121a20cab3ba7bb5dd2;hp=d1f8230b1de6d9197e0b387e52aabf8be026b8a3;hpb=2c5d7b20742b802d9c47916915c1114bcfc9a9c3;p=vchess.git diff --git a/client/src/variants/Circular.js b/client/src/variants/Circular.js index d1f8230b..333ad320 100644 --- a/client/src/variants/Circular.js +++ b/client/src/variants/Circular.js @@ -3,6 +3,7 @@ import { ArrayFun } from "@/utils/array"; import { shuffle } from "@/utils/alea"; export class CircularRules extends ChessRules { + static get HasCastle() { return false; } @@ -34,8 +35,8 @@ export class CircularRules extends ChessRules { this.pawnFlags = flags; } - static GenRandInitFen(randomness) { - if (randomness == 0) { + static GenRandInitFen(options) { + if (options.randomness == 0) { return "8/8/pppppppp/rnbqkbnr/8/8/PPPPPPPP/RNBQKBNR " + "w 0 1111111111111111"; } @@ -43,7 +44,7 @@ export class CircularRules extends ChessRules { let pieces = { w: new Array(8), b: new Array(8) }; // Shuffle pieces on first and last rank for (let c of ["w", "b"]) { - if (c == 'b' && randomness == 1) { + if (c == 'b' && options.randomness == 1) { pieces['b'] = pieces['w']; break; } @@ -55,8 +56,10 @@ export class CircularRules extends ChessRules { if (rem2 == positions[1] % 2) { // Fix bishops (on different colors) for (let i=2; i<8; i++) { - if (positions[i] % 2 != rem2) + if (positions[i] % 2 != rem2) { [positions[1], positions[i]] = [positions[i], positions[1]]; + break; + } } } for (let i = 0; i < 8; i++) pieces[c][positions[i]] = composition[i]; @@ -89,7 +92,7 @@ export class CircularRules extends ChessRules { let j = y + step[1]; while (V.OnBoard(i, j) && this.board[i][j] == V.EMPTY) { moves.push(this.getBasicMove([x, y], [i, j])); - if (oneStep !== undefined) continue outerLoop; + if (oneStep) continue outerLoop; i = V.ComputeX(i + step[0]); j += step[1]; } @@ -221,4 +224,5 @@ export class CircularRules extends ChessRules { static get SEARCH_DEPTH() { return 2; } + };