X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=client%2Fsrc%2Fvariants%2FOrda.js;h=4bca5496c41617b1ab240a11f9bb5be233e89d70;hb=4313762da3237b04f204e121a20cab3ba7bb5dd2;hp=4d911f4045a0100fe8e5b1d3d288e0c28f7f71c8;hpb=c7550017d88ff6eb32e2c76a271a7f9edc4a3bf6;p=vchess.git diff --git a/client/src/variants/Orda.js b/client/src/variants/Orda.js index 4d911f40..4bca5496 100644 --- a/client/src/variants/Orda.js +++ b/client/src/variants/Orda.js @@ -3,6 +3,7 @@ import { ArrayFun } from "@/utils/array"; import { randInt } from "@/utils/alea"; export class OrdaRules extends ChessRules { + static get PawnSpecs() { return Object.assign( {}, @@ -23,8 +24,8 @@ export class OrdaRules extends ChessRules { return b; } - static GenRandInitFen(randomness) { - if (randomness == 0) + static GenRandInitFen(options) { + if (options.randomness == 0) return "lhaykahl/8/pppppppp/8/8/8/PPPPPPPP/RNBQKBNR w 0 ah -"; // Mapping kingdom --> horde: @@ -36,58 +37,11 @@ export class OrdaRules extends ChessRules { 'k': 'k' }; - let pieces = { w: new Array(8), b: new Array(8) }; - let flags = ""; - // Shuffle pieces on first (and last rank if randomness == 2) - for (let c of ["w", "b"]) { - if (c == 'b' && randomness == 1) { - pieces['b'] = pieces['w'].map(p => piecesMap[p]); - break; - } - - // TODO: same code as in base_rules. Should extract and factorize? - - let positions = ArrayFun.range(8); - - let randIndex = 2 * randInt(4); - const bishop1Pos = positions[randIndex]; - let randIndex_tmp = 2 * randInt(4) + 1; - const bishop2Pos = positions[randIndex_tmp]; - positions.splice(Math.max(randIndex, randIndex_tmp), 1); - positions.splice(Math.min(randIndex, randIndex_tmp), 1); - - randIndex = randInt(6); - const knight1Pos = positions[randIndex]; - positions.splice(randIndex, 1); - randIndex = randInt(5); - const knight2Pos = positions[randIndex]; - positions.splice(randIndex, 1); - - randIndex = randInt(4); - const queenPos = positions[randIndex]; - positions.splice(randIndex, 1); - - const rook1Pos = positions[0]; - const kingPos = positions[1]; - const rook2Pos = positions[2]; - - pieces[c][rook1Pos] = "r"; - pieces[c][knight1Pos] = "n"; - pieces[c][bishop1Pos] = "b"; - pieces[c][queenPos] = "q"; - pieces[c][kingPos] = "k"; - pieces[c][bishop2Pos] = "b"; - pieces[c][knight2Pos] = "n"; - pieces[c][rook2Pos] = "r"; - if (c == 'b') pieces[c] = pieces[c].map(p => piecesMap[p]); - else flags = V.CoordToColumn(rook1Pos) + V.CoordToColumn(rook2Pos); - } - // Add turn + flags + enpassant + const baseFen = ChessRules.GenRandInitFen(options); return ( - pieces["b"].join("") + - "/8/pppppppp/8/8/8/PPPPPPPP/" + - pieces["w"].join("").toUpperCase() + - " w 0 " + flags + " -" + baseFen.substr(0, 8).split('').map(p => piecesMap[p]).join('') + + // Skip 3 first rows + black castle flags + "/8/pppppppp" + baseFen.substr(19, 31) + " -" ); } @@ -135,6 +89,7 @@ export class OrdaRules extends ChessRules { return []; } + // TODO: merge this extension into base_rules.js getSlideNJumpMoves([x, y], steps, oneStep, options) { options = options || {}; let moves = []; @@ -155,76 +110,36 @@ export class OrdaRules extends ChessRules { getPotentialLancerMoves(sq) { const onlyMoves = this.getSlideNJumpMoves( - sq, - V.steps[V.KNIGHT], - "oneStep", - { onlyMove: true } - ); + sq, V.steps[V.KNIGHT], "oneStep", { onlyMove: true }); const onlyTakes = this.getSlideNJumpMoves( - sq, - V.steps[V.ROOK], - null, - { onlyTake: true } - ); + sq, V.steps[V.ROOK], null, { onlyTake: true }); return onlyMoves.concat(onlyTakes); } getPotentialArcherMoves(sq) { const onlyMoves = this.getSlideNJumpMoves( - sq, - V.steps[V.KNIGHT], - "oneStep", - { onlyMove: true } - ); + sq, V.steps[V.KNIGHT], "oneStep", { onlyMove: true }); const onlyTakes = this.getSlideNJumpMoves( - sq, - V.steps[V.BISHOP], - null, - { onlyTake: true } - ); - return onlyMoves.concat(onlyTakes); - } - - getPotentialLancerMoves(sq) { - const onlyMoves = this.getSlideNJumpMoves( - sq, - V.steps[V.KNIGHT], - "oneStep", - { onlyMove: true } - ); - const onlyTakes = this.getSlideNJumpMoves( - sq, - V.steps[V.ROOK], - null, - { onlyTake: true } - ); + sq, V.steps[V.BISHOP], null, { onlyTake: true }); return onlyMoves.concat(onlyTakes); } getPotentialKheshigMoves(sq) { - return this.getSlideNJumpMoves( - sq, - V.steps[V.KNIGHT].concat(V.steps[V.ROOK]).concat(V.steps[V.BISHOP]), - "oneStep" - ); + const steps = + V.steps[V.KNIGHT].concat(V.steps[V.ROOK]).concat(V.steps[V.BISHOP]); + return super.getSlideNJumpMoves(sq, steps, 1); } getPotentialYurtMoves(sq) { - return this.getSlideNJumpMoves( - sq, - V.steps[V.BISHOP].concat([1, 0]), - "oneSTep" - ); + return super.getSlideNJumpMoves( + sq, V.steps[V.BISHOP].concat([ [1, 0] ]), 1); } getPotentialKingMoves([x, y]) { if (this.getColor(x, y) == 'w') return super.getPotentialKingMoves([x, y]); // Horde doesn't castle: - return this.getSlideNJumpMoves( - [x, y], - V.steps[V.ROOK].concat(V.steps[V.BISHOP]), - "oneStep" - ); + return super.getSlideNJumpMoves( + [x, y], V.steps[V.ROOK].concat(V.steps[V.BISHOP]), 1); } isAttacked(sq, color) { @@ -234,13 +149,14 @@ export class OrdaRules extends ChessRules { this.isAttackedByKheshig(sq, color) ); } - // Horde: only pawn and queen (if promotions) in common: + // Horde: only pawn, king and queen (if promotions) in common: return ( super.isAttackedByPawn(sq, color) || this.isAttackedByLancer(sq, color) || this.isAttackedByKheshig(sq, color) || this.isAttackedByArcher(sq, color) || this.isAttackedByYurt(sq, color) || + super.isAttackedByKing(sq, color) || super.isAttackedByQueen(sq, color) ); } @@ -254,23 +170,14 @@ export class OrdaRules extends ChessRules { } isAttackedByKheshig(sq, color) { - return super.isAttackedBySlideNJump( - sq, - color, - V.KHESHIG, - V.steps[V.KNIGHT].concat(V.steps[V.ROOK]).concat(V.steps[V.BISHOP]), - "oneStep" - ); + const steps = + V.steps[V.KNIGHT].concat(V.steps[V.ROOK]).concat(V.steps[V.BISHOP]); + return super.isAttackedBySlideNJump(sq, color, V.KHESHIG, steps, 1); } isAttackedByYurt(sq, color) { return super.isAttackedBySlideNJump( - sq, - color, - V.YURT, - V.steps[V.BISHOP].concat([1, 0]), - "oneStep" - ); + sq, color, V.YURT, V.steps[V.BISHOP].concat([ [1, 0] ]), 1); } updateCastleFlags(move, piece) { @@ -320,4 +227,5 @@ export class OrdaRules extends ChessRules { } ); } + };