X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=client%2Fsrc%2Fvariants%2FCircular.js;h=47758442128409c3ee787bec9bf7560d9e426602;hb=5d74fceaa93054b410f469fe6ed4d5a4609bf98d;hp=73f87aaa1aa8f418cb4f1bf15ce0b96ed72ccb9d;hpb=a8f0bbcb3808c8a8af548ab335c61674cffcb6c3;p=vchess.git diff --git a/client/src/variants/Circular.js b/client/src/variants/Circular.js index 73f87aaa..47758442 100644 --- a/client/src/variants/Circular.js +++ b/client/src/variants/Circular.js @@ -3,6 +3,7 @@ import { ArrayFun } from "@/utils/array"; import { shuffle } from "@/utils/alea"; export class CircularRules extends ChessRules { + static get HasCastle() { return false; } @@ -35,8 +36,10 @@ export class CircularRules extends ChessRules { } static GenRandInitFen(randomness) { - if (randomness == 0) - return "8/8/pppppppp/rnbqkbnr/8/8/PPPPPPPP/RNBQKBNR w 0 1111111111111111"; + if (randomness == 0) { + return "8/8/pppppppp/rnbqkbnr/8/8/PPPPPPPP/RNBQKBNR " + + "w 0 1111111111111111"; + } let pieces = { w: new Array(8), b: new Array(8) }; // Shuffle pieces on first and last rank @@ -53,8 +56,10 @@ export class CircularRules extends ChessRules { if (rem2 == positions[1] % 2) { // Fix bishops (on different colors) for (let i=2; i<8; i++) { - if (positions[i] % 2 != rem2) + if (positions[i] % 2 != rem2) { [positions[1], positions[i]] = [positions[i], positions[1]]; + break; + } } } for (let i = 0; i < 8; i++) pieces[c][positions[i]] = composition[i]; @@ -219,4 +224,5 @@ export class CircularRules extends ChessRules { static get SEARCH_DEPTH() { return 2; } + };