X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=client%2Fsrc%2Fvariants%2FAntiking1.js;h=75cc14cb26fdcbfae9e7943d52f153dbfde2e80e;hb=32f6285ee325a14286562a53baefc647201df2af;hp=42450d1725adddc64caf8fe1afa97399b1699a74;hpb=c583ef1c1dfd19aee88b22c2175202fbdf4dc1c0;p=vchess.git diff --git a/client/src/variants/Antiking1.js b/client/src/variants/Antiking1.js index 42450d17..75cc14cb 100644 --- a/client/src/variants/Antiking1.js +++ b/client/src/variants/Antiking1.js @@ -1,10 +1,15 @@ import { ChessRules } from "@/base_rules"; +import { BerolinaRules } from "@/variants/Berolina"; import { ArrayFun } from "@/utils/array"; import { randInt } from "@/utils/alea"; -export const VariantRules = class Antiking1Rules extends ChessRules { - static get HasEnpassant() { - return false; +export class Antiking1Rules extends BerolinaRules { + static get PawnSpecs() { + return Object.assign( + {}, + ChessRules.PawnSpecs, + { twoSquares: false } + ); } static get HasCastle() { @@ -110,43 +115,6 @@ export const VariantRules = class Antiking1Rules extends ChessRules { return moves; } - getPotentialPawnMoves([x, y]) { - const color = this.turn; - let moves = []; - const [sizeX, sizeY] = [V.size.x, V.size.y]; - const shiftX = color == "w" ? -1 : 1; - const startRank = color == "w" ? sizeX - 2 : 1; - const lastRank = color == "w" ? 0 : sizeX - 1; - const finalPieces = - x + shiftX == lastRank ? [V.ROOK, V.KNIGHT, V.BISHOP, V.QUEEN] : [V.PAWN]; - - // One square diagonally - for (let shiftY of [-1, 1]) { - if (this.board[x + shiftX][y + shiftY] == V.EMPTY) { - for (let piece of finalPieces) { - moves.push( - this.getBasicMove([x, y], [x + shiftX, y + shiftY], { - c: color, - p: piece - }) - ); - } - } - } - // Capture - if ( - this.board[x + shiftX][y] != V.EMPTY && - this.canTake([x, y], [x + shiftX, y]) - ) { - for (let piece of finalPieces) - moves.push( - this.getBasicMove([x, y], [x + shiftX, y], { c: color, p: piece }) - ); - } - - return moves; - } - getPotentialAntikingMoves(sq) { // The antiking moves like a king (only captured colors differ) return this.getSlideNJumpMoves( @@ -163,19 +131,6 @@ export const VariantRules = class Antiking1Rules extends ChessRules { ); } - isAttackedByPawn([x, y], color) { - let pawnShift = (color == "w" ? 1 : -1); - if (x + pawnShift >= 0 && x + pawnShift < V.size.x) { - if ( - this.getPiece(x + pawnShift, y) == V.PAWN && - this.getColor(x + pawnShift, y) == color - ) { - return true; - } - } - return false; - } - isAttackedByKing([x, y], color) { // Antiking is not attacked by king: if (this.getPiece(x, y) == V.ANTIKING) return false;