X-Git-Url: https://git.auder.net/?p=vchess.git;a=blobdiff_plain;f=public%2Fjavascripts%2Fvariants%2FUltima.js;h=c98822dcbf0e85aa68889faf0f4c338194dd79ef;hp=7f9531eb82ef281a9f5a899161f8e34c7d05b46e;hb=9d218497ab97bc0e94ec4c1f0a40cf02df3ea0d4;hpb=0279ac93197aa072991bce8f643ca68e99a54bc7 diff --git a/public/javascripts/variants/Ultima.js b/public/javascripts/variants/Ultima.js index 7f9531eb..c98822dc 100644 --- a/public/javascripts/variants/Ultima.js +++ b/public/javascripts/variants/Ultima.js @@ -53,13 +53,13 @@ class UltimaRules extends ChessRules getPotentialMovesFrom([x,y]) { // Pre-check: is thing on this square immobilized? - // In this case add potential suicide as a move "taking the immobilizer" const piece = this.getPiece(x,y); const color = this.getColor(x,y); const oppCol = this.getOppCol(color); const V = VariantRules; const adjacentSteps = V.steps[V.ROOK].concat(V.steps[V.BISHOP]); const [sizeX,sizeY] = V.size; + outerLoop: for (let step of adjacentSteps) { const [i,j] = [x+step[0],y+step[1]]; @@ -67,15 +67,23 @@ class UltimaRules extends ChessRules && this.getColor(i,j) == oppCol) { const oppPiece = this.getPiece(i,j); - if (oppPiece == V.IMMOBILIZER - || (oppPiece == V.BISHOP && piece == V.IMMOBILIZER)) + if (oppPiece == V.BISHOP && piece == V.IMMOBILIZER) + return []; + if (oppPiece == V.IMMOBILIZER && ![V.BISHOP,V.IMMOBILIZER].includes(piece)) { - return [ new Move({ - appear: [], - vanish: [new PiPo({x:x,y:y,p:piece,c:color})], - start: {x:x,y:y}, - end: {x:i,y:j} - }) ]; + // Moving is impossible only if this immobilizer is not neutralized + for (let step2 of adjacentSteps) + { + const [i2,j2] = [i+step2[0],j+step2[1]]; + if (i2>=0 && i2=0 && j2= 0) - return "*"; - - return this.checkGameEnd(); - } - checkGameEnd() { // Stalemate, or our king disappeared @@ -521,15 +524,4 @@ class UltimaRules extends ChessRules { return "0000"; //TODO: or "-" ? } - - getNotation(move) - { - if (move.appear.length == 0) - { - const startSquare = - String.fromCharCode(97 + move.start.y) + (VariantRules.size[0]-move.start.x); - return "^" + startSquare; //suicide - } - return super.getNotation(move); - } }