X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fposition.cpp;h=80dcdd5724afab805dea2e90fe374baa08f90c71;hp=ae28805c4c6bfd4cf093d52c74bcf456ab23d22a;hb=15153a1de71d2d36c1f95eecfcf036fb76565309;hpb=b08ba446f655ba6292cb0b5a1012e790e4ad8d7d diff --git a/src/position.cpp b/src/position.cpp index ae28805c..80dcdd57 100644 --- a/src/position.cpp +++ b/src/position.cpp @@ -36,7 +36,6 @@ #include "position.h" #include "psqtab.h" #include "rkiss.h" -#include "san.h" #include "tt.h" #include "ucioption.h" @@ -777,7 +776,9 @@ bool Position::move_is_check(Move m, const CheckInfo& ci) const { /// It should be used when setting up a position on board. /// You can't undo the move. -void Position::do_setup_move(Move m, StateInfo& newSt) { +void Position::do_setup_move(Move m) { + + StateInfo newSt; do_move(m, newSt); @@ -788,6 +789,10 @@ void Position::do_setup_move(Move m, StateInfo& newSt) { // Update the number of plies played from the starting position startPosPlyCounter++; + + // Our StateInfo newSt is about going out of scope so copy + // its content inside pos before it disappears. + detach(); } /// Position::do_move() makes a move, and saves all information necessary @@ -804,6 +809,7 @@ void Position::do_move(Move m, StateInfo& newSt, const CheckInfo& ci, bool moveI assert(is_ok()); assert(move_is_ok(m)); + assert(&newSt != st); nodes++; Key key = st->key; @@ -819,8 +825,7 @@ void Position::do_move(Move m, StateInfo& newSt, const CheckInfo& ci, bool moveI Value npMaterial[2]; }; - if (&newSt != st) - memcpy(&newSt, st, sizeof(ReducedStateInfo)); + memcpy(&newSt, st, sizeof(ReducedStateInfo)); newSt.previous = st; st = &newSt; @@ -1691,7 +1696,7 @@ bool Position::is_draw() const { return true; // Draw by the 50 moves rule? - if (st->rule50 > 99 && (st->rule50 > 100 || !is_mate())) + if (st->rule50 > 99 && !is_mate()) return true; // Draw by repetition? @@ -1709,7 +1714,7 @@ bool Position::is_draw() const { bool Position::is_mate() const { MoveStack moves[MOVES_MAX]; - return is_check() && generate_moves(*this, moves) == moves; + return is_check() && generate(*this, moves) == moves; } @@ -1730,8 +1735,8 @@ bool Position::has_mate_threat() { do_null_move(st1); // Then generate pseudo-legal moves that could give check - last = generate_non_capture_checks(*this, mlist); - last = generate_captures(*this, last); + last = generate(*this, mlist); + last = generate(*this, last); // Loop through the moves, and see if one of them gives mate Bitboard pinned = pinned_pieces(sideToMove);