projects
/
xogo.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix last refactoring. Ready to add variants
[xogo.git]
/
variants
/
Suction
/
class.js
diff --git
a/variants/Suction/class.js
b/variants/Suction/class.js
index
db10e58
..
a66855d
100644
(file)
--- a/
variants/Suction/class.js
+++ b/
variants/Suction/class.js
@@
-42,18
+42,21
@@
export default class SuctionRules extends ChessRules {
}
genRandInitFen(seed) {
}
genRandInitFen(seed) {
- const gr = new GiveawayRules(
- {mode: "suicide", options: this.options, genFenOnly: true});
+ const options = Object.assign({mode: "suicide"}, this.options);
+ const gr = new GiveawayRules({options: options, genFenOnly: true});
+ const baseFen = gr.genRandInitFen(seed);
// Add empty cmove:
// Add empty cmove:
- return (
- gr.genRandInitFen(seed).slice(0, -17) + '{"enpassant":"-","cmove":"-"}');
+ const fenParts = baseFen.split(" ");
+ let others = JSON.parse(fenParts[3]);
+ others["cmove"] = "-";
+ return fenParts.slice(0, 3).join(" ") + " " + JSON.stringify(others);
}
getFen() {
const cmoveFen = !this.cmove
? "-"
: C.CoordsToSquare(this.cmove.start) + C.CoordsToSquare(this.cmove.end);
}
getFen() {
const cmoveFen = !this.cmove
? "-"
: C.CoordsToSquare(this.cmove.start) + C.CoordsToSquare(this.cmove.end);
- return super.getFen().slice(0, -1) + ',"' + cmoveFen + '"}';
+ return super.getFen().slice(0, -1) + ',"
cmove":"
' + cmoveFen + '"}';
}
getBasicMove([sx, sy], [ex, ey]) {
}
getBasicMove([sx, sy], [ex, ey]) {
@@
-110,4
+113,13
@@
export default class SuctionRules extends ChessRules {
return "*";
}
return "*";
}
+ // Better animation for swaps
+ customAnimate(move, segments, cb) {
+ if (move.vanish.length < 2)
+ return 0;
+ super.animateMoving(move.end, move.start, null,
+ segments.reverse().map(s => s.reverse()), cb);
+ return 1;
+ }
+
};
};