X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fposition.h;h=173de0c081c59396996b1d6b1d244e38bc1747d0;hb=f637ddc1e87c9e825ce63f66974348347439f493;hp=ae750697aa894b423fa52e15f5fb4a7d8f93f0eb;hpb=da7a62852ab5e96d24bb4fd2f062d488684738b1;p=stockfish diff --git a/src/position.h b/src/position.h index ae750697..173de0c0 100644 --- a/src/position.h +++ b/src/position.h @@ -79,14 +79,15 @@ enum CastleRights { /// must be passed as a parameter. struct StateInfo { - Bitboard pinners[2], pinned[2], dcCandidates[2], checkersBB; Key key, pawnKey, materialKey; int castleRights, rule50; Square epSquare; Value mgValue, egValue; + PieceType capture; - StateInfo* previous; + Bitboard checkersBB; Move lastMove; + StateInfo* previous; }; @@ -219,7 +220,9 @@ public: // Properties of moves bool pl_move_is_legal(Move m) const; + bool pl_move_is_legal(Move m, Bitboard pinned) const; bool move_is_check(Move m) const; + bool move_is_check(Move m, Bitboard dcCandidates) const; bool move_is_capture(Move m) const; bool move_is_deep_pawn_push(Move m) const; bool move_is_pawn_push_to_7th(Move m) const; @@ -240,7 +243,9 @@ public: bool square_is_weak(Square s, Color c) const; // Doing and undoing moves + void setStartState(const StateInfo& st); void do_move(Move m, StateInfo& st); + void do_move(Move m, StateInfo& st, Bitboard dcCandidates); void undo_move(Move m); void do_null_move(StateInfo& st); void undo_null_move(); @@ -287,6 +292,7 @@ public: static void init_piece_square_tables(); private: + // Initialization helper functions (used while setting up a position) void clear(); void put_piece(Piece p, Square s); @@ -294,7 +300,6 @@ private: void allow_ooo(Color c); // Helper functions for doing and undoing moves - void init_new_state(StateInfo& newSt); void do_capture_move(Move m, PieceType capture, Color them, Square to); void do_castle_move(Move m); void do_promotion_move(Move m); @@ -303,13 +308,12 @@ private: void undo_promotion_move(Move m); void undo_ep_move(Move m); void find_checkers(); - void find_pinned(); template void update_checkers(Bitboard* pCheckersBB, Square ksq, Square from, Square to, Bitboard dcCandidates); - template - Bitboard hidden_checks(Color c, Square ksq, Bitboard& pinners) const; + template + Bitboard hidden_checkers(Color c) const; // Computing hash keys from scratch (for initialization and debugging) Key compute_key() const; @@ -558,19 +562,6 @@ inline Bitboard Position::piece_attacks(Square s) const { return StepAttackBB[KING][s]; } -inline Bitboard Position::pinned_pieces(Color c) const { - return st->pinned[c]; -} - -inline Bitboard Position::pinned_pieces(Color c, Bitboard& p) const { - p = st->pinners[c]; - return st->pinned[c]; -} - -inline Bitboard Position::discovered_check_candidates(Color c) const { - return st->dcCandidates[c]; -} - inline Bitboard Position::checkers() const { return st->checkersBB; }