X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fposition.h;h=6351f58003557274955c7d69b7fd254c7d084c44;hp=df97ab2c35e759db06e330dd983989fd993819ff;hb=a358dfe934eeefc00ea9adb20d4a83c4cf4d4e1e;hpb=456f37b8aba74018fc532099c13a9af4e6714867 diff --git a/src/position.h b/src/position.h index df97ab2c..6351f580 100644 --- a/src/position.h +++ b/src/position.h @@ -98,11 +98,11 @@ public: // Position representation Bitboard pieces() const; - Bitboard pieces(Color c) const; Bitboard pieces(PieceType pt) const; - Bitboard pieces(PieceType pt, Color c) const; Bitboard pieces(PieceType pt1, PieceType pt2) const; - Bitboard pieces(PieceType pt1, PieceType pt2, Color c) const; + Bitboard pieces(Color c) const; + Bitboard pieces(Color c, PieceType pt) const; + Bitboard pieces(Color c, PieceType pt1, PieceType pt2) const; Piece piece_on(Square s) const; Square king_square(Color c) const; Square ep_square() const; @@ -261,24 +261,24 @@ inline Bitboard Position::pieces() const { return byTypeBB[ALL_PIECES]; } -inline Bitboard Position::pieces(Color c) const { - return byColorBB[c]; -} - inline Bitboard Position::pieces(PieceType pt) const { return byTypeBB[pt]; } -inline Bitboard Position::pieces(PieceType pt, Color c) const { - return byTypeBB[pt] & byColorBB[c]; -} - inline Bitboard Position::pieces(PieceType pt1, PieceType pt2) const { return byTypeBB[pt1] | byTypeBB[pt2]; } -inline Bitboard Position::pieces(PieceType pt1, PieceType pt2, Color c) const { - return (byTypeBB[pt1] | byTypeBB[pt2]) & byColorBB[c]; +inline Bitboard Position::pieces(Color c) const { + return byColorBB[c]; +} + +inline Bitboard Position::pieces(Color c, PieceType pt) const { + return byColorBB[c] & byTypeBB[pt]; +} + +inline Bitboard Position::pieces(Color c, PieceType pt1, PieceType pt2) const { + return byColorBB[c] & (byTypeBB[pt1] | byTypeBB[pt2]); } inline int Position::piece_count(Color c, PieceType pt) const { @@ -302,7 +302,7 @@ inline int Position::can_castle(CastleRight f) const { } inline int Position::can_castle(Color c) const { - return st->castleRights & ((WHITE_OO | WHITE_OOO) << c); + return st->castleRights & ((WHITE_OO | WHITE_OOO) << (2 * c)); } inline bool Position::castle_impeded(Color c, CastlingSide s) const { @@ -351,7 +351,7 @@ inline Bitboard Position::pinned_pieces() const { } inline bool Position::pawn_is_passed(Color c, Square s) const { - return !(pieces(PAWN, ~c) & passed_pawn_mask(c, s)); + return !(pieces(~c, PAWN) & passed_pawn_mask(c, s)); } inline Key Position::key() const { @@ -406,7 +406,7 @@ inline bool Position::bishop_pair(Color c) const { } inline bool Position::pawn_on_7th(Color c) const { - return pieces(PAWN, c) & rank_bb(relative_rank(c, RANK_7)); + return pieces(c, PAWN) & rank_bb(relative_rank(c, RANK_7)); } inline bool Position::is_chess960() const {