X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fpiece.h;h=cf23c0288c2e79dc25bf6cdc6da720f858011532;hp=e0dcc783baa433881814deba72097cd39ab0919a;hb=a9e55d43262d11a916bdfa68cd1de0174d884cd3;hpb=f0858cd22972c0f893ab8d012a0f1783cd9faff2 diff --git a/src/piece.h b/src/piece.h index e0dcc783..cf23c028 100644 --- a/src/piece.h +++ b/src/piece.h @@ -26,7 +26,6 @@ //// #include "color.h" -#include "misc.h" #include "square.h" @@ -50,41 +49,10 @@ enum Piece { //// Constants //// -const PieceType PieceTypeMin = PAWN; -const PieceType PieceTypeMax = KING; - const int SlidingArray[18] = { 0, 0, 0, 1, 2, 3, 0, 0, 0, 0, 0, 1, 2, 3, 0, 0, 0, 0 }; -const SquareDelta Directions[16][16] = { - {DELTA_ZERO}, - {DELTA_NW, DELTA_NE, DELTA_ZERO}, - {DELTA_SSW, DELTA_SSE, DELTA_SWW, DELTA_SEE, - DELTA_NWW, DELTA_NEE, DELTA_NNW, DELTA_NNE, DELTA_ZERO}, - {DELTA_SE, DELTA_SW, DELTA_NE, DELTA_NW, DELTA_ZERO}, - {DELTA_S, DELTA_E, DELTA_W, DELTA_N, DELTA_ZERO}, - {DELTA_S, DELTA_E, DELTA_W, DELTA_N, - DELTA_SE, DELTA_SW, DELTA_NE, DELTA_NW, DELTA_ZERO}, - {DELTA_S, DELTA_E, DELTA_W, DELTA_N, - DELTA_SE, DELTA_SW, DELTA_NE, DELTA_NW, DELTA_ZERO}, - {DELTA_ZERO}, - {DELTA_ZERO}, - {DELTA_SW, DELTA_SE, DELTA_ZERO}, - {DELTA_SSW, DELTA_SSE, DELTA_SWW, DELTA_SEE, - DELTA_NWW, DELTA_NEE, DELTA_NNW, DELTA_NNE, DELTA_ZERO}, - {DELTA_SE, DELTA_SW, DELTA_NE, DELTA_NW, DELTA_ZERO}, - {DELTA_S, DELTA_E, DELTA_W, DELTA_N, DELTA_ZERO}, - {DELTA_S, DELTA_E, DELTA_W, DELTA_N, - DELTA_SE, DELTA_SW, DELTA_NE, DELTA_NW, DELTA_ZERO}, - {DELTA_S, DELTA_E, DELTA_W, DELTA_N, - DELTA_SE, DELTA_SW, DELTA_NE, DELTA_NW, DELTA_ZERO}, -}; - -const SquareDelta PawnPush[2] = { - DELTA_N, DELTA_S -}; - //// //// Inline functions @@ -111,40 +79,16 @@ inline Piece piece_of_color_and_type(Color c, PieceType pt) { return Piece((int(c) << 3) | int(pt)); } -inline Piece pawn_of_color(Color c) { - return piece_of_color_and_type(c, PAWN); -} - -inline Piece knight_of_color(Color c) { - return piece_of_color_and_type(c, KNIGHT); -} - -inline Piece bishop_of_color(Color c) { - return piece_of_color_and_type(c, BISHOP); -} - -inline Piece rook_of_color(Color c) { - return piece_of_color_and_type(c, ROOK); -} - -inline Piece queen_of_color(Color c) { - return piece_of_color_and_type(c, QUEEN); -} - -inline Piece king_of_color(Color c) { - return piece_of_color_and_type(c, KING); -} - inline int piece_is_slider(Piece p) { return SlidingArray[int(p)]; } -inline int piece_type_is_slider(PieceType pt) { +inline int piece_is_slider(PieceType pt) { return SlidingArray[int(pt)]; } inline SquareDelta pawn_push(Color c) { - return PawnPush[c]; + return (c == WHITE ? DELTA_N : DELTA_S); } inline bool piece_type_is_ok(PieceType pc) { @@ -160,7 +104,7 @@ inline bool piece_is_ok(Piece pc) { //// Prototypes //// -extern char piece_type_to_char(PieceType pt, bool upcase = false); +extern int piece_type_to_char(PieceType pt, bool upcase = false); extern PieceType piece_type_from_char(char c);