projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add Pacifist1 & 2
[vchess.git]
/
client
/
src
/
variants
/
Crazyhouse.js
diff --git
a/client/src/variants/Crazyhouse.js
b/client/src/variants/Crazyhouse.js
index
d7d82b8
..
8e61974
100644
(file)
--- a/
client/src/variants/Crazyhouse.js
+++ b/
client/src/variants/Crazyhouse.js
@@
-1,7
+1,7
@@
import { ChessRules, PiPo, Move } from "@/base_rules";
import { ArrayFun } from "@/utils/array";
import { ChessRules, PiPo, Move } from "@/base_rules";
import { ArrayFun } from "@/utils/array";
-export c
onst VariantRules = c
lass CrazyhouseRules extends ChessRules {
+export class CrazyhouseRules extends ChessRules {
static IsGoodFen(fen) {
if (!ChessRules.IsGoodFen(fen)) return false;
const fenParsed = V.ParseFen(fen);
static IsGoodFen(fen) {
if (!ChessRules.IsGoodFen(fen)) return false;
const fenParsed = V.ParseFen(fen);
@@
-22,19
+22,32
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
static ParseFen(fen) {
const fenParts = fen.split(" ");
static ParseFen(fen) {
const fenParts = fen.split(" ");
- return Object.assign(ChessRules.ParseFen(fen), {
- reserve: fenParts[5],
- promoted: fenParts[6]
- });
+ return Object.assign(
+ ChessRules.ParseFen(fen),
+ {
+ reserve: fenParts[5],
+ promoted: fenParts[6]
+ }
+ );
}
}
- static GenRandInitFen() {
- return ChessRules.GenRandInitFen() + " 0000000000 -";
+ static GenRandInitFen(
randomness
) {
+ return ChessRules.GenRandInitFen(
randomness
) + " 0000000000 -";
}
getFen() {
return (
}
getFen() {
return (
- super.getFen() + " " + this.getReserveFen() + " " + this.getPromotedFen()
+ super.getFen() + " " +
+ this.getReserveFen() + " " +
+ this.getPromotedFen()
+ );
+ }
+
+ getFenForRepeat() {
+ return (
+ super.getFenForRepeat() + "_" +
+ this.getReserveFen() + "_" +
+ this.getPromotedFen()
);
}
);
}
@@
-55,11
+68,11
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
let res = "";
for (let i = 0; i < V.size.x; i++) {
for (let j = 0; j < V.size.y; j++) {
let res = "";
for (let i = 0; i < V.size.x; i++) {
for (let j = 0; j < V.size.y; j++) {
- if (this.promoted[i][j]) res += V.CoordsToSquare({ x: i, y: j });
+ if (this.promoted[i][j]) res += V.CoordsToSquare({ x: i, y: j })
+ ","
;
}
}
}
}
+ // Remove last comma:
if (res.length > 0) res = res.slice(0, -1);
if (res.length > 0) res = res.slice(0, -1);
- //remove last comma
else res = "-";
return res;
}
else res = "-";
return res;
}
@@
-87,8
+100,8
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
this.promoted = ArrayFun.init(V.size.x, V.size.y, false);
if (fenParsed.promoted != "-") {
for (let square of fenParsed.promoted.split(",")) {
this.promoted = ArrayFun.init(V.size.x, V.size.y, false);
if (fenParsed.promoted != "-") {
for (let square of fenParsed.promoted.split(",")) {
- const
[x, y]
= V.SquareToCoords(square);
- this.promoted[
x][
y] = true;
+ const
coords
= V.SquareToCoords(square);
+ this.promoted[
coords.x][coords.
y] = true;
}
}
}
}
}
}
@@
-104,9
+117,17
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
}
// Used by the interface:
}
// Used by the interface:
- getReservePpath(
color, index
) {
+ getReservePpath(
index, color
) {
return color + V.RESERVE_PIECES[index];
}
return color + V.RESERVE_PIECES[index];
}
+// // Version if some day I have pieces with numbers printed on it:
+// getReservePpath(index, color) {
+// return (
+// "Crazyhouse/" +
+// color + V.RESERVE_PIECES[index] +
+// "_" + this.vr.reserve[playingColor][V.RESERVE_PIECES[i]]
+// );
+// }
// Ordering on reserve pieces
static get RESERVE_PIECES() {
// Ordering on reserve pieces
static get RESERVE_PIECES() {
@@
-152,12
+173,13
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
}
getAllValidMoves() {
}
getAllValidMoves() {
- let moves = super.getAll
Valid
Moves();
+ let moves = super.getAll
Potential
Moves();
const color = this.turn;
const color = this.turn;
- for (let i = 0; i < V.RESERVE_PIECES.length; i++)
+ for (let i = 0; i < V.RESERVE_PIECES.length; i++)
{
moves = moves.concat(
this.getReserveMoves([V.size.x + (color == "w" ? 0 : 1), i])
);
moves = moves.concat(
this.getReserveMoves([V.size.x + (color == "w" ? 0 : 1), i])
);
+ }
return this.filterValid(moves);
}
return this.filterValid(moves);
}
@@
-175,9
+197,10
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
return true;
}
return true;
}
- updateVariables(move) {
- super.updateVariables(move);
- if (move.vanish.length == 2 && move.appear.length == 2) return; //skip castle
+ postPlay(move) {
+ super.postPlay(move);
+ // Skip castle:
+ if (move.vanish.length == 2 && move.appear.length == 2) return;
const color = move.appear[0].c;
if (move.vanish.length == 0) {
this.reserve[color][move.appear[0].p]--;
const color = move.appear[0].c;
if (move.vanish.length == 0) {
this.reserve[color][move.appear[0].p]--;
@@
-193,8
+216,8
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
else if (move.vanish.length == 2) this.reserve[color][move.vanish[1].p]++;
}
else if (move.vanish.length == 2) this.reserve[color][move.vanish[1].p]++;
}
-
unupdateVariables
(move) {
- super.
unupdateVariables
(move);
+
postUndo
(move) {
+ super.
postUndo
(move);
if (move.vanish.length == 2 && move.appear.length == 2) return;
const color = this.turn;
if (move.vanish.length == 0) {
if (move.vanish.length == 2 && move.appear.length == 2) return;
const color = this.turn;
if (move.vanish.length == 0) {
@@
-208,7
+231,6
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
}
static get SEARCH_DEPTH() {
}
static get SEARCH_DEPTH() {
- // High branching factor
return 2;
}
return 2;
}