From: Benjamin Auder <benjamin.auder@somewhere> Date: Fri, 23 Nov 2018 12:09:51 +0000 (+0100) Subject: Fix magnetic promotions, attempt to fix Alice chess X-Git-Url: https://git.auder.net/variants/%24%7Bvname%7D/%7B%7B%20asset%28%27mixstore/scripts/common.css?a=commitdiff_plain;h=f6cc7faf4301dc4a7ae5bb07f16403f280beddc3;p=vchess.git Fix magnetic promotions, attempt to fix Alice chess --- diff --git a/public/javascripts/components/game.js b/public/javascripts/components/game.js index e3cc6af0..ca8a6bff 100644 --- a/public/javascripts/components/game.js +++ b/public/javascripts/components/game.js @@ -574,7 +574,7 @@ Vue.component('my-game', { this.newGame("computer"); }, newGame: function(mode, fenInit, color, oppId, moves, continuation) { - const fen = fenInit || VariantRules.GenRandInitFen(); + const fen = "pppppppp/rnbqkbnr/8/8/8/8/PPPPPPPP/ROBQKBOR 1111"; //fenInit || VariantRules.GenRandInitFen(); console.log(fen); //DEBUG this.score = "*"; if (mode=="human" && !oppId) diff --git a/public/javascripts/variants/Alice.js b/public/javascripts/variants/Alice.js index 3cba8d02..1e1ce46d 100644 --- a/public/javascripts/variants/Alice.js +++ b/public/javascripts/variants/Alice.js @@ -76,12 +76,15 @@ class AliceRules extends ChessRules return false; } } - m.appear.forEach(psq => { - if (Object.keys(VariantRules.ALICE_CODES).includes(psq.p)) + // If the move is computed on board1, m.appear change for Alice pieces. + if (mirrorSide==1) + { + m.appear.forEach(psq => { //forEach: castling taken into account psq.p = VariantRules.ALICE_CODES[psq.p]; //goto board2 - else - psq.p = VariantRules.ALICE_PIECES[psq.p]; //goto board1 - }); + }); + } + else //move on board2: mark vanishing piece as Alice + m.vanish[0].p = VariantRules.ALICE_CODES[m.vanish[0].p] return true; }); } diff --git a/public/javascripts/variants/Magnetic.js b/public/javascripts/variants/Magnetic.js index 7fecf780..d1436c0f 100644 --- a/public/javascripts/variants/Magnetic.js +++ b/public/javascripts/variants/Magnetic.js @@ -112,7 +112,7 @@ class MagneticRules extends ChessRules // Scan move for pawn (max 1) on 8th rank for (let i=1; i<move.appear.length; i++) { - if (move.appear[i].p==V.PAWN && move.appear[i].x==lastRank) + if (move.appear[i].p==V.PAWN && move.appear[i].c==color && move.appear[i].x==lastRank) { move.appear[i].p = V.ROOK; moves.push(move);