X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=client%2Fsrc%2Fvariants%2FRoyalrace.js;h=3be0c149f39a6bc344cd58b912d072fbb6290a3d;hb=4313762da3237b04f204e121a20cab3ba7bb5dd2;hp=5232cc94a4616c028f1910fd760ff857a9c0fafd;hpb=306dab5f2087a35669a114587c0415b31145665b;p=vchess.git diff --git a/client/src/variants/Royalrace.js b/client/src/variants/Royalrace.js index 5232cc94..3be0c149 100644 --- a/client/src/variants/Royalrace.js +++ b/client/src/variants/Royalrace.js @@ -3,6 +3,7 @@ import { ArrayFun } from "@/utils/array"; import { randInt, shuffle } from "@/utils/alea"; export class RoyalraceRules extends ChessRules { + static get HasFlags() { return false; } @@ -23,14 +24,14 @@ export class RoyalraceRules extends ChessRules { return (b[1] == V.KNIGHT ? "Enpassant/" : "") + b; } - static GenRandInitFen(randomness) { - if (randomness == 0) + static GenRandInitFen(options) { + if (options.randomness == 0) return "92/92/92/92/92/92/92/92/92/qrbnp1PNBRQ/krbnp1PNBRK w 0"; let pieces = { w: new Array(10), b: new Array(10) }; // Shuffle pieces on first and second rank for (let c of ["w", "b"]) { - if (c == 'b' && randomness == 1) { + if (c == 'b' && options.randomness == 1) { pieces['b'] = JSON.parse(JSON.stringify(pieces['w'])).reverse(); pieces['b'] = pieces['b'].splice(5,10).reverse().concat( @@ -108,6 +109,7 @@ export class RoyalraceRules extends ChessRules { ); } + // TODO: simplify this when base function is more general. getPotentialPawnMoves([x, y]) { // Normal moves (as a rook) let moves = @@ -152,30 +154,13 @@ export class RoyalraceRules extends ChessRules { isAttackedByPawn([x, y], color) { // Pawns can capture forward and backward: - for (let pawnShift of [-1, 1]) { - if (0 < x + pawnShift && x + pawnShift < V.size.x) { - for (let i of [-1, 1]) { - if ( - y + i >= 0 && - y + i < V.size.y && - this.getPiece(x + pawnShift, y + i) == V.PAWN && - this.getColor(x + pawnShift, y + i) == color - ) { - return true; - } - } - } - } - return false; + return this.isAttackedBySlideNJump( + sq, color, V.PAWN, V.steps[V.BISHOP], 1); } isAttackedByKnight(sq, color) { return this.isAttackedBySlideNJump( - sq, - color, - V.KNIGHT, - V.steps[V.KNIGHT] - ); + sq, color, V.KNIGHT, V.steps[V.KNIGHT]); } getCurrentScore() { @@ -219,4 +204,5 @@ export class RoyalraceRules extends ChessRules { V.CoordsToSquare(move.end) ); } + };