projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Update Cwda - RR pieces
[vchess.git]
/
client
/
src
/
variants
/
Pocketknight.js
diff --git
a/client/src/variants/Pocketknight.js
b/client/src/variants/Pocketknight.js
index
6b92a1f
..
ad17f93
100644
(file)
--- a/
client/src/variants/Pocketknight.js
+++ b/
client/src/variants/Pocketknight.js
@@
-2,7
+2,8
@@
import { ChessRules, Move, PiPo } from "@/base_rules";
import { randInt } from "@/utils/alea";
export class PocketknightRules extends ChessRules {
import { randInt } from "@/utils/alea";
export class PocketknightRules extends ChessRules {
- hoverHighlight(x, y) {
+
+ hoverHighlight([x, y]) {
// Testing move validity results in an infinite update loop.
// TODO: find a way to test validity anyway.
return (this.subTurn == 2 && this.board[x][y] == V.EMPTY);
// Testing move validity results in an infinite update loop.
// TODO: find a way to test validity anyway.
return (this.subTurn == 2 && this.board[x][y] == V.EMPTY);
@@
-32,10
+33,9
@@
export class PocketknightRules extends ChessRules {
this.subTurn = 1;
}
this.subTurn = 1;
}
- static GenRandInitFen(
randomnes
s) {
+ static GenRandInitFen(
option
s) {
// Add 2 knight flags
// Add 2 knight flags
- return ChessRules.GenRandInitFen(randomness)
- .slice(0, -2) + "11 -";
+ return ChessRules.GenRandInitFen(options).slice(0, -2) + "11 -";
}
getFlagsFen() {
}
getFlagsFen() {
@@
-44,6
+44,12
@@
export class PocketknightRules extends ChessRules {
);
}
);
}
+ canIplay(side, [x, y]) {
+ if (this.subTurn == 1) return super.canIplay(side, [x, y]);
+ // subturn == 2, drop the knight:
+ return side == this.turn && this.board[x][y] == V.EMPTY;
+ }
+
getPotentialMovesFrom([x, y]) {
if (this.subTurn == 1) {
let moves = super.getPotentialMovesFrom([x, y]);
getPotentialMovesFrom([x, y]) {
if (this.subTurn == 1) {
let moves = super.getPotentialMovesFrom([x, y]);
@@
-282,4
+288,5
@@
export class PocketknightRules extends ChessRules {
// Knight landing:
return "N@" + V.CoordsToSquare(move.end);
}
// Knight landing:
return "N@" + V.CoordsToSquare(move.end);
}
+
};
};