X-Git-Url: https://git.auder.net/?p=vchess.git;a=blobdiff_plain;f=client%2Fsrc%2Fvariants%2FSuction.js;h=9ac5b4424a4df2f6ca70cd703ec5aa1592204dec;hp=0fc88ce431849089fb964172e69d79eb17897cae;hb=3a2a7b5fd3c6bfd0752838094c27e1fb6172d109;hpb=afbf3ca7151ef15a9e579b0f913683ab212396c4 diff --git a/client/src/variants/Suction.js b/client/src/variants/Suction.js index 0fc88ce4..9ac5b442 100644 --- a/client/src/variants/Suction.js +++ b/client/src/variants/Suction.js @@ -1,11 +1,18 @@ import { ChessRules, PiPo, Move } from "@/base_rules"; export const VariantRules = class SuctionRules extends ChessRules { + static get HasFlags() { + return false; + } + setOtherVariables(fen) { + +console.log(fen); + super.setOtherVariables(fen); - // Local stack of captures + // Local stack of "captures" this.cmoves = []; - const cmove = fen.split(" ")[5]; + const cmove = V.ParseFen(fen).cmove; if (cmove == "-") this.cmoves.push(null); else { this.cmoves.push({ @@ -15,6 +22,12 @@ export const VariantRules = class SuctionRules extends ChessRules { } } + static ParseFen(fen) { + return Object.assign({}, ChessRules.ParseFen(fen), { + cmove: fen.split(" ")[4] + }); + } + static IsGoodFen(fen) { if (!ChessRules.IsGoodFen(fen)) return false; const fenParts = fen.split(" "); @@ -171,27 +184,9 @@ export const VariantRules = class SuctionRules extends ChessRules { }); } - updateVariables(move) { - super.updateVariables(move); - if (move.vanish.length == 2) { - // Was opponent king swapped? - if (move.vanish[1].p == V.KING) - this.kingPos[this.turn] = [move.appear[1].x, move.appear[1].y]; - } - } - - unupdateVariables(move) { - super.unupdateVariables(move); - if (move.appear.length == 2) { - // Was opponent king swapped? - if (move.appear[1].p == V.KING) - this.kingPos[move.vanish[1].c] = [move.vanish[1].x,move.vanish[1].y]; - } - } - static GenRandInitFen(randomness) { // Add empty cmove: - return ChessRules.GenRandInitFen(randomness) + " -"; + return ChessRules.GenRandInitFen(randomness).slice(0, -6) + "- -"; } getFen() { @@ -203,14 +198,23 @@ export const VariantRules = class SuctionRules extends ChessRules { return super.getFen() + " " + cmoveFen; } - play(move) { + postPlay(move) { + super.postPlay(move); + if (move.vanish.length == 2) { + // Was opponent king swapped? + if (move.vanish[1].p == V.KING) + this.kingPos[this.turn] = [move.appear[1].x, move.appear[1].y]; + } this.cmoves.push(this.getCmove(move)); - super.play(move); } - undo(move) { + postUndo(move) { + super.postUndo(move); + if (move.appear.length == 2) { + if (move.appear[1].p == V.KING) + this.kingPos[move.vanish[1].c] = [move.vanish[1].x, move.vanish[1].y]; + } this.cmoves.pop(); - super.undo(move); } atLeastOneMove() {