X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fposition.h;h=a051ec382f49fe15a0d3ee55238e97a48c1158ac;hb=21850536d54c3f142f1907e31ac0bfab8f4a8862;hp=c9088438a23f9bc7be5561a6f17ae5f258109dd5;hpb=dd80b9abaf8aa880c5aa2db10066d4c81e8d7205;p=stockfish diff --git a/src/position.h b/src/position.h index c9088438..a051ec38 100644 --- a/src/position.h +++ b/src/position.h @@ -196,9 +196,9 @@ public: // Information about attacks to or from a given square Bitboard attackers_to(Square s) const; - Bitboard piece_attacks_from(Piece p, Square s) const; - Bitboard pawn_attacks_from(Square s, Color c) const; - template Bitboard piece_attacks_from(Square s) const; + Bitboard attacks_from(Piece p, Square s) const; + template Bitboard attacks_from(Square s) const; + template Bitboard attacks_from(Square s, Color c) const; // Properties of moves bool pl_move_is_legal(Move m) const; @@ -431,33 +431,29 @@ inline Square Position::initial_qr_square(Color c) const { return relative_square(c, make_square(initialQRFile, RANK_1)); } -inline Bitboard Position::pawn_attacks_from(Square s, Color c) const { +template<> +inline Bitboard Position::attacks_from(Square s, Color c) const { return StepAttackBB[piece_of_color_and_type(c, PAWN)][s]; } -template // Knight and King -inline Bitboard Position::piece_attacks_from(Square s) const { +template // Knight and King and white pawns +inline Bitboard Position::attacks_from(Square s) const { return StepAttackBB[Piece][s]; } template<> -inline Bitboard Position::piece_attacks_from(Square s) const { - return StepAttackBB[WP][s] | StepAttackBB[BP][s]; -} - -template<> -inline Bitboard Position::piece_attacks_from(Square s) const { +inline Bitboard Position::attacks_from(Square s) const { return bishop_attacks_bb(s, occupied_squares()); } template<> -inline Bitboard Position::piece_attacks_from(Square s) const { +inline Bitboard Position::attacks_from(Square s) const { return rook_attacks_bb(s, occupied_squares()); } template<> -inline Bitboard Position::piece_attacks_from(Square s) const { - return piece_attacks_from(s) | piece_attacks_from(s); +inline Bitboard Position::attacks_from(Square s) const { + return attacks_from(s) | attacks_from(s); } inline Bitboard Position::checkers() const {