X-Git-Url: https://git.auder.net/variants/Cwda/complete_rules.html?a=blobdiff_plain;f=client%2Fsrc%2Fvariants%2FLosers.js;h=b39d24fb6b0ae221bd49c4f6933b1323a3a08d1c;hb=2f9fcef3eb606c6389249c35393265de7d8f392f;hp=d752f984bc4f5375ba3b23eba44f7694d812c979;hpb=6b7b2cf720e6255e4da0dc34fee363c456346a58;p=vchess.git diff --git a/client/src/variants/Losers.js b/client/src/variants/Losers.js index d752f984..b39d24fb 100644 --- a/client/src/variants/Losers.js +++ b/client/src/variants/Losers.js @@ -2,7 +2,7 @@ import { ChessRules } from "@/base_rules"; import { ArrayFun } from "@/utils/array"; import { randInt } from "@/utils/alea"; -export const VariantRules = class LosersRules extends ChessRules { +export class LosersRules extends ChessRules { // Trim all non-capturing moves static KeepCaptures(moves) { return moves.filter(m => m.vanish.length == 2); @@ -38,7 +38,8 @@ export const VariantRules = class LosersRules extends ChessRules { getAllValidMoves() { const moves = super.getAllValidMoves(); - if (moves.some(m => m.vanish.length == 2)) return V.KeepCaptures(moves); + if (moves.some(m => m.vanish.length == 2 && m.appear.length == 1)) + return V.KeepCaptures(moves); return moves; } @@ -64,10 +65,6 @@ export const VariantRules = class LosersRules extends ChessRules { return this.turn == "w" ? "1-0" : "0-1"; } - static get SEARCH_DEPTH() { - return 4; - } - evalPosition() { // Less material is better (more subtle in fact but...) return -super.evalPosition();