projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add New Zealand Chess
[vchess.git]
/
client
/
src
/
variants
/
Schess.js
diff --git
a/client/src/variants/Schess.js
b/client/src/variants/Schess.js
index
0d12b74
..
d8e1b1c
100644
(file)
--- a/
client/src/variants/Schess.js
+++ b/
client/src/variants/Schess.js
@@
-1,6
+1,7
@@
import { ChessRules, PiPo } from "@/base_rules";
export class SchessRules extends ChessRules {
import { ChessRules, PiPo } from "@/base_rules";
export class SchessRules extends ChessRules {
+
static get PawnSpecs() {
return Object.assign(
{},
static get PawnSpecs() {
return Object.assign(
{},
@@
-119,12
+120,12
@@
export class SchessRules extends ChessRules {
const fenParsed = V.ParseFen(fen);
this.pocket = {
"w": {
const fenParsed = V.ParseFen(fen);
this.pocket = {
"w": {
- h: parseInt(fenParsed.pocket[0]),
- e: parseInt(fenParsed.pocket[1])
+ h: parseInt(fenParsed.pocket[0]
, 10
),
+ e: parseInt(fenParsed.pocket[1]
, 10
)
},
"b": {
},
"b": {
- h: parseInt(fenParsed.pocket[2]),
- e: parseInt(fenParsed.pocket[3])
+ h: parseInt(fenParsed.pocket[2]
, 10
),
+ e: parseInt(fenParsed.pocket[3]
, 10
)
}
};
}
}
};
}
@@
-291,7
+292,6
@@
export class SchessRules extends ChessRules {
([V.HAWK, V.ELEPHANT, V.NOTHING].includes(move.appear[0].p) ? 1 : 0);
this.kingPos[color][0] = move.appear[shift].x;
this.kingPos[color][1] = move.appear[shift].y;
([V.HAWK, V.ELEPHANT, V.NOTHING].includes(move.appear[0].p) ? 1 : 0);
this.kingPos[color][0] = move.appear[shift].x;
this.kingPos[color][1] = move.appear[shift].y;
- return;
}
this.updateCastleFlags(move, piece);
}
this.updateCastleFlags(move, piece);
@@
-342,7
+342,14
@@
export class SchessRules extends ChessRules {
const nothingAppear = (move.appear[0].p == V.NOTHING);
if (pPieceAppear || nothingAppear) {
let suffix = "";
const nothingAppear = (move.appear[0].p == V.NOTHING);
if (pPieceAppear || nothingAppear) {
let suffix = "";
- if (pPieceAppear) suffix = "/" + move.appear[0].p.toUpperCase();
+ if (pPieceAppear) {
+ suffix = "/" + move.appear[0].p.toUpperCase();
+ if (move.appear.length == 3) {
+ // Castling; indicate square
+ suffix +=
+ V.CoordsToSquare({ x: move.appear[0].x, y: move.appear[0].y });
+ }
+ }
let cmove = JSON.parse(JSON.stringify(move));
cmove.appear.shift();
return super.getNotation(cmove) + suffix;
let cmove = JSON.parse(JSON.stringify(move));
cmove.appear.shift();
return super.getNotation(cmove) + suffix;
@@
-350,4
+357,5
@@
export class SchessRules extends ChessRules {
}
return super.getNotation(move);
}
}
return super.getNotation(move);
}
+
};
};