X-Git-Url: https://git.auder.net/?p=vchess.git;a=blobdiff_plain;f=public%2Fjavascripts%2Fvariants%2FUltima.js;h=57f3e25c6e8cd6fbabfafe7ccc224fde1c1e3c8b;hp=7f9531eb82ef281a9f5a899161f8e34c7d05b46e;hb=2f3c845159670ec8bfba8a3999571d6ee1e45320;hpb=0279ac93197aa072991bce8f643ca68e99a54bc7 diff --git a/public/javascripts/variants/Ultima.js b/public/javascripts/variants/Ultima.js index 7f9531eb..57f3e25c 100644 --- a/public/javascripts/variants/Ultima.js +++ b/public/javascripts/variants/Ultima.js @@ -50,16 +50,46 @@ class UltimaRules extends ChessRules // - a "bishop" is a chameleon, capturing as its prey // - a "queen" is a withdrawer, capturing by moving away from pieces - getPotentialMovesFrom([x,y]) + // Is piece on square (x,y) immobilized? + isImmobilized([x,y]) { - // Pre-check: is thing on this square immobilized? - // In this case add potential suicide as a move "taking the immobilizer" + // Final check: is this knight immobilized? + let foundImmobilizer = false; + let neutralized = false; + outerLoop: + for (let step of steps) + { + const [i2,j2] = [i+step[0],j+step[1]]; + if (i2>=0 && i2=0 && j2=0 && i3=0 && j3=0 && i2=0 && j2=0 && i1=0 && i2=0 && j1=0 && j2 0) + const [sizeX,sizeY] = VariantRules.size; + // King must be on same column and a rook on same row (or reverse) + if (x == this.kingPos[colors[0]][0]) //using colors[0], only element in this case { - this.kingPos[c][0] = move.appear[0].x; - this.kingPos[c][1] = move.appear[0].y; + // Look for enemy rook on this column + for (let i=0; i=0 && i0=0 && j0=0 && i=0 && j=0 && i=0 && j= 0) - return "*"; + // We cheat a little here: since this function is used exclusively for king, + // it's enough to check the immediate surrounding of the square. + const V = VariantRules; + const adjacentSteps = V.steps[V.ROOK].concat(V.steps[V.BISHOP]); + const [sizeX,sizeY] = V.size; + for (let step of adjacentSteps) + { + const [i,j] = [x+step[0],y+step[1]]; + if (i>=0 && i=0 && j=0 && sq2[0]=0 && sq2[1] 0) + { + this.kingPos[c][0] = move.appear[0].x; + this.kingPos[c][1] = move.appear[0].y; + } } static get VALUES() { //TODO: totally experimental! @@ -460,10 +573,6 @@ class UltimaRules extends ChessRules static get SEARCH_DEPTH() { return 2; } //TODO? - static get THRESHOLD_MATE() { - return 500; //checkmates evals may be slightly below 1000 - } - static GenRandInitFen() { let pieces = { "w": new Array(8), "b": new Array(8) }; @@ -521,15 +630,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); - } }