X-Git-Url: https://git.auder.net/?p=vchess.git;a=blobdiff_plain;f=client%2Fsrc%2Fvariants%2FAlice.js;h=a3d3ff434082368209f5172882b2503f361b29ad;hp=15e629a4024f9e42c30d3918e6f16bbdb080d213;hb=b9ce3d0fbe6cf8cba01912706ad578144bc9b42f;hpb=8948a2876de183467f610a703d8c7f6d7c2df570 diff --git a/client/src/variants/Alice.js b/client/src/variants/Alice.js index 15e629a4..a3d3ff43 100644 --- a/client/src/variants/Alice.js +++ b/client/src/variants/Alice.js @@ -60,6 +60,30 @@ export class AliceRules extends ChessRules { return undefined; //default } + // king can be l or L (on the other mirror side) + static IsGoodPosition(position) { + if (position.length == 0) return false; + const rows = position.split("/"); + if (rows.length != V.size.x) return false; + let kings = { "k": 0, "K": 0, 'l': 0, 'L': 0 }; + for (let row of rows) { + let sumElts = 0; + for (let i = 0; i < row.length; i++) { + if (['K','k','L','l'].includes(row[i])) kings[row[i]]++; + if (V.PIECES.includes(row[i].toLowerCase())) sumElts++; + else { + const num = parseInt(row[i]); + if (isNaN(num)) return false; + sumElts += num; + } + } + if (sumElts != V.size.y) return false; + } + if (kings['k'] + kings['l'] != 1 || kings['K'] + kings['L'] != 1) + return false; + return true; + } + setOtherVariables(fen) { super.setOtherVariables(fen); const rows = V.ParseFen(fen).position.split("/");