projects
/
vchess.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix rules implementation and translations for Allmate1
[vchess.git]
/
client
/
src
/
variants
/
Allmate2.js
diff --git
a/client/src/variants/Allmate2.js
b/client/src/variants/Allmate2.js
index
31d41be
..
9b60a5f
100644
(file)
--- a/
client/src/variants/Allmate2.js
+++ b/
client/src/variants/Allmate2.js
@@
-61,11
+61,16
@@
export class Allmate2Rules extends ChessRules {
oppMoves = this.getPotentialQueenMoves([i, j]);
break;
case V.KING:
oppMoves = this.getPotentialQueenMoves([i, j]);
break;
case V.KING:
- oppMoves = this.getPotentialKingMoves([i, j]);
+ // Do not allow castling to escape from check
+ oppMoves = super.getSlideNJumpMoves(
+ [x, y],
+ V.steps[V.ROOK].concat(V.steps[V.BISHOP]),
+ "oneStep"
+ );
break;
}
for (let om of oppMoves) {
break;
}
for (let om of oppMoves) {
- if (om.vanish.length == 2
&& om.appear.length == 1
)
+ if (om.vanish.length == 2)
// Skip captures: forbidden in this mode
continue;
V.PlayOnBoard(this.board, om);
// Skip captures: forbidden in this mode
continue;
V.PlayOnBoard(this.board, om);
@@
-85,6
+90,7
@@
export class Allmate2Rules extends ChessRules {
}
}
}
}
}
}
+ this.undo(m);
// 3) Add mate-captures:
Object.values(attacked).forEach(sq => {
// 3) Add mate-captures:
Object.values(attacked).forEach(sq => {
@@
-95,8
+101,6
@@
export class Allmate2Rules extends ChessRules {
p: this.getPiece(sq[0], sq[1])
}));
});
p: this.getPiece(sq[0], sq[1])
}));
});
-
- this.undo(m);
});
return moves;
});
return moves;