X-Git-Url: https://git.auder.net/%7B%7B%20path%28%27mixstore_store_package_upsert%27%29%20%7D%7D?a=blobdiff_plain;f=variants%2FChakart%2Fclass.js;h=96a53f3640990b32479cce6d424a82a4b3d19e54;hb=33b427488bb6ee5c505c3a024bccedbef763f80e;hp=d804548e0c0d3ffe74537de3a3b2d13ccdc8f162;hpb=98d144512e5505f5ef8b702b139ca6ceff92c823;p=xogo.git diff --git a/variants/Chakart/class.js b/variants/Chakart/class.js index d804548..96a53f3 100644 --- a/variants/Chakart/class.js +++ b/variants/Chakart/class.js @@ -116,7 +116,6 @@ export default class ChakartRules extends ChessRules { { 'y': { // Virtual piece for "king remote shell captures" - moves: [], attack: [ { steps: [ @@ -312,7 +311,7 @@ export default class ChakartRules extends ChessRules { moves.push(this.getBasicMove([x, y], [x + shiftX, nextY])); } } - this.pawnPostProcess(moves, color, oppCol); + moves = super.pawnPostProcess(moves, color, oppCol); // Add mushroom on before-last square (+ potential segments) moves.forEach(m => { let [mx, my] = [x, y]; @@ -472,8 +471,7 @@ export default class ChakartRules extends ChessRules { ) ) { // "Forgotten" promotion, which occurred after some effect - let moves = [move]; - super.pawnPostProcess(moves, color, C.GetOppCol(color)); + let moves = super.pawnPostProcess([move], color, C.GetOppCol(color)); super.showChoices(moves, r); } else @@ -481,6 +479,8 @@ export default class ChakartRules extends ChessRules { } computeNextMove(move) { + if (move.koopa) + return null; // Set potential random effects, so that play() is deterministic // from opponent viewpoint: const endPiece = this.getPiece(move.end.x, move.end.y); @@ -641,6 +641,7 @@ export default class ChakartRules extends ChessRules { p: this.getPiece(move.start.x, move.start.y) })); } + em.koopa = true; //avoid applying effect break; case "chomp": // Eat piece