X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fposition.cpp;h=2b6e2b4c07a5e84640d839cd6aca37b77abf9f6d;hp=1350ddf97a5923e33c3f677bdef398df79154ea3;hb=84ec1f7331f402f4ab2e2201b72b3ee378cce659;hpb=b1ac6c69a077c95c122a82d5b757adf9470fb308 diff --git a/src/position.cpp b/src/position.cpp index 1350ddf9..2b6e2b4c 100644 --- a/src/position.cpp +++ b/src/position.cpp @@ -76,15 +76,52 @@ CheckInfo::CheckInfo(const Position& pos) { checkSq[KING] = EmptyBoardBB; } + +/// Position c'tors. Here we always create a slower but safer copy of +/// the original position or the FEN string, we want the new born Position +/// object do not depend on any external data. Instead if we know what we +/// are doing and we need speed we can create a position with default +/// c'tor Position() and then use just fast_copy(). + +Position::Position() {} + Position::Position(const Position& pos) { - copy(pos); + + fast_copy(pos); + detach(); // Always detach() in copy c'tor to avoid surprises } Position::Position(const string& fen) { + from_fen(fen); } +/// Position::fast_copy() creates a partial copy of the given position, +/// only data that changes with a do_move() / undo_move() cycle is copied, +/// in particular for stateInfo are copied only the pointers, so that the +/// actual data remains stored in the parent Position. This is not a problem +/// if the parent Position is known not to be destroyed while we are still alive, +/// as is the common case, see detach() otherwise. + +void Position::fast_copy(const Position& pos) { + + memcpy(this, &pos, sizeof(Position)); +} + + +/// Position::detach() copies the content of the current state and castling +/// masks inside the position itself. This is needed when the st pointee could +/// become stale, as example because the caller is about to going out of scope. + +void Position::detach() { + + startState = *st; + st = &startState; + st->previous = NULL; // as a safe guard +} + + /// Position::from_fen() initializes the position object with the given FEN /// string. This function is not very robust - make sure that input FENs are /// correct (this is assumed to be the responsibility of the GUI). @@ -345,15 +382,6 @@ void Position::print(Move m) const { } -/// Position::copy() creates a copy of the input position. - -void Position::copy(const Position& pos) { - - memcpy(this, &pos, sizeof(Position)); - saveState(); // detach and copy state info -} - - /// Position:hidden_checkers<>() returns a bitboard of all pinned (against the /// king) pieces for the given color and for the given pinner type. Or, when /// template parameter FindPinned is false, the pieces of the given color @@ -1443,19 +1471,6 @@ int Position::see(Square from, Square to) const { } -/// Position::saveState() copies the content of the current state -/// inside startState and makes st point to it. This is needed -/// when the st pointee could become stale, as example because -/// the caller is about to going out of scope. - -void Position::saveState() { - - startState = *st; - st = &startState; - st->previous = NULL; // as a safe guard -} - - /// Position::clear() erases the position object to a pristine state, with an /// empty board, white to move, and no castling rights.