Cleaner fen generation + first draft of Apocalypse + a few fixes
[xogo.git] / variants / Giveaway / class.js
index 69addf2..15a8998 100644 (file)
@@ -36,47 +36,44 @@ export default class GiveawayRules extends ChessRules {
     return res;
   }
 
-  genRandInitFen(seed) {
+  genRandInitBaseFen() {
     if (this.options["mode"] == "losers")
-      return super.genRandInitFen(seed);
+      return super.genRandInitBaseFen();
 
-    if (this.options["randomness"] == 0) {
-      return (
-        'rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w 0 {"enpassant":"-"}'
-      );
-    }
-
-    Random.setSeed(seed);
-    let pieces = { w: new Array(8), b: new Array(8) };
-    for (let c of ["w", "b"]) {
-      if (c == 'b' && this.options["randomness"] == 1) {
-        pieces['b'] = pieces['w'];
-        break;
-      }
-
-      // Get random squares for every piece, totally freely
-      let positions = Random.shuffle(ArrayFun.range(8));
-      const composition = ['b', 'b', 'r', 'r', 'n', 'n', 'k', 'q'];
-      const rem2 = positions[0] % 2;
-      if (rem2 == positions[1] % 2) {
-        // Fix bishops (on different colors)
-        for (let i=2; i<8; i++) {
-          if (positions[i] % 2 != rem2) {
-            [positions[1], positions[i]] = [positions[i], positions[1]];
-            break;
+    let fen = "";
+    if (this.options["randomness"] == 0)
+      fen = "rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w 0";
+    else {
+      let pieces = { w: new Array(8), b: new Array(8) };
+      for (let c of ["w", "b"]) {
+        if (c == 'b' && this.options["randomness"] == 1) {
+          pieces['b'] = pieces['w'];
+          break;
+        }
+        // Get random squares for every piece, totally freely
+        let positions = Random.shuffle(ArrayFun.range(8));
+        const composition = ['b', 'b', 'r', 'r', 'n', 'n', 'k', 'q'];
+        const rem2 = positions[0] % 2;
+        if (rem2 == positions[1] % 2) {
+          // Fix bishops (on different colors)
+          for (let i=2; i<8; i++) {
+            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];
       }
-      for (let i = 0; i < 8; i++)
-        pieces[c][positions[i]] = composition[i];
+      fen = (
+        pieces["b"].join("") +
+        "/pppppppp/8/8/8/8/PPPPPPPP/" +
+        pieces["w"].join("").toUpperCase() +
+        " w 0"
+      );
     }
-    return (
-      pieces["b"].join("") +
-      "/pppppppp/8/8/8/8/PPPPPPPP/" +
-      pieces["w"].join("").toUpperCase() +
-      // En-passant allowed, but no flags
-      ' w 0 {"enpassant":"-"}'
-    );
+    return { fen: fen, o: {} };
   }
 
   constructor(o) {
@@ -91,7 +88,8 @@ export default class GiveawayRules extends ChessRules {
   }
 
   getCurrentScore() {
-    if (this.atLeastOneMove()) return "*";
+    if (this.atLeastOneMove(this.turn))
+      return "*";
     // No valid move: the side who cannot move wins
     return (this.turn == "w" ? "1-0" : "0-1");
   }