projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Bug fixes
[vchess.git]
/
client
/
src
/
variants
/
Crazyhouse.js
diff --git
a/client/src/variants/Crazyhouse.js
b/client/src/variants/Crazyhouse.js
index
7dc5346
..
03d7e41
100644
(file)
--- a/
client/src/variants/Crazyhouse.js
+++ b/
client/src/variants/Crazyhouse.js
@@
-28,6
+28,13
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
});
}
});
}
+ getEpSquare(moveOrSquare) {
+ if (typeof moveOrSquare !== "object" || moveOrSquare.vanish.length > 0)
+ return super.getEpSquare(moveOrSquare);
+ // Landing move: no en-passant
+ return undefined;
+ }
+
static GenRandInitFen(randomness) {
return ChessRules.GenRandInitFen(randomness) + " 0000000000 -";
}
static GenRandInitFen(randomness) {
return ChessRules.GenRandInitFen(randomness) + " 0000000000 -";
}
@@
-38,6
+45,17
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
);
}
);
}
+ getFenForRepeat() {
+ return (
+ this.getBaseFen() + "_" +
+ this.getTurnFen() + "_" +
+ this.getFlagsFen() + "_" +
+ this.getEnpassantFen() + "_" +
+ this.getReserveFen() + "_" +
+ this.getPromotedFen()
+ );
+ }
+
getReserveFen() {
let counts = new Array(10);
for (
getReserveFen() {
let counts = new Array(10);
for (
@@
-55,11
+73,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
+105,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;
}
}
}
}
}
}
@@
-107,6
+125,14
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
getReservePpath(index, color) {
return color + V.RESERVE_PIECES[index];
}
getReservePpath(index, color) {
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() {
@@
-208,7
+234,6
@@
export const VariantRules = class CrazyhouseRules extends ChessRules {
}
static get SEARCH_DEPTH() {
}
static get SEARCH_DEPTH() {
- // High branching factor
return 2;
}
return 2;
}