From: Benjamin Auder Date: Tue, 27 Apr 2021 18:16:56 +0000 (+0200) Subject: Fix Shogi.js X-Git-Url: https://git.auder.net/doc/html/pieces/cp.svg?a=commitdiff_plain;h=3972f7876bc08c1ff90e3d2e1fd74a56626d8fc8;p=vchess.git Fix Shogi.js --- diff --git a/client/src/variants/Shogi.js b/client/src/variants/Shogi.js index 5f85e753..9806351c 100644 --- a/client/src/variants/Shogi.js +++ b/client/src/variants/Shogi.js @@ -335,7 +335,7 @@ export class ShogiRules extends ChessRules { } // Modified to take promotions into account - getSlideNJumpMoves([x, y], steps, options) { + getSlideNJumpMoves_opt([x, y], steps, options) { options = options || {}; const color = this.turn; const oneStep = options.oneStep; @@ -375,7 +375,7 @@ export class ShogiRules extends ChessRules { getPotentialGoldMoves(sq) { const forward = (this.turn == 'w' ? -1 : 1); - return this.getSlideNJumpMoves( + return this.getSlideNJumpMoves_opt( sq, V.steps[V.ROOK].concat([ [forward, 1], [forward, -1] ]), { oneStep: true } @@ -385,7 +385,7 @@ export class ShogiRules extends ChessRules { getPotentialPawnMoves(sq) { const forward = (this.turn == 'w' ? -1 : 1); return ( - this.getSlideNJumpMoves( + this.getSlideNJumpMoves_opt( sq, [[forward, 0]], { @@ -399,7 +399,7 @@ export class ShogiRules extends ChessRules { getPotentialSilverMoves(sq) { const forward = (this.turn == 'w' ? -1 : 1); - return this.getSlideNJumpMoves( + return this.getSlideNJumpMoves_opt( sq, V.steps[V.BISHOP].concat([ [forward, 0] ]), { @@ -411,7 +411,7 @@ export class ShogiRules extends ChessRules { getPotentialKnightMoves(sq) { const forward = (this.turn == 'w' ? -2 : 2); - return this.getSlideNJumpMoves( + return this.getSlideNJumpMoves_opt( sq, [ [forward, 1], [forward, -1] ], { @@ -424,7 +424,7 @@ export class ShogiRules extends ChessRules { getPotentialLanceMoves(sq) { const forward = (this.turn == 'w' ? -1 : 1); - return this.getSlideNJumpMoves( + return this.getSlideNJumpMoves_opt( sq, [ [forward, 0] ], { @@ -435,26 +435,26 @@ export class ShogiRules extends ChessRules { } getPotentialRookMoves(sq) { - return this.getSlideNJumpMoves( + return this.getSlideNJumpMoves_opt( sq, V.steps[V.ROOK], { promote: V.P_ROOK }); } getPotentialBishopMoves(sq) { - return this.getSlideNJumpMoves( + return this.getSlideNJumpMoves_opt( sq, V.steps[V.BISHOP], { promote: V.P_BISHOP }); } getPotentialDragonMoves(sq) { return ( - this.getSlideNJumpMoves(sq, V.steps[V.ROOK]).concat( - this.getSlideNJumpMoves(sq, V.steps[V.BISHOP], { oneStep: true })) + this.getSlideNJumpMoves_opt(sq, V.steps[V.ROOK]).concat( + this.getSlideNJumpMoves_opt(sq, V.steps[V.BISHOP], { oneStep: true })) ); } getPotentialHorseMoves(sq) { return ( - this.getSlideNJumpMoves(sq, V.steps[V.BISHOP]).concat( - this.getSlideNJumpMoves(sq, V.steps[V.ROOK], { oneStep: true })) + this.getSlideNJumpMoves_opt(sq, V.steps[V.BISHOP]).concat( + this.getSlideNJumpMoves_opt(sq, V.steps[V.ROOK], { oneStep: true })) ); } @@ -526,6 +526,25 @@ export class ShogiRules extends ChessRules { ); } + filterValid(moves) { + if (moves.length == 0) return []; + const color = this.turn; + const lastRanks = (color == 'w' ? [0, 1] : [8, 7]); + return moves.filter(m => { + if ( + (m.appear[0].p == V.KNIGHT && lastRanks.includes(m.end.x)) || + ([V.PAWN, V.LANCE].includes(m.appear[0].p) && lastRanks[0] == m.end.x) + ) { + // Forbid moves resulting in a blocked piece + return false; + } + this.play(m); + const res = !this.underCheck(color); + this.undo(m); + return res; + }); + } + getAllValidMoves() { let moves = super.getAllPotentialMoves(); const color = this.turn;