X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmovegen.cpp;h=9b4cc130b2268fb0e6029b9bf2b547741ac46bf9;hb=e5077dc11e8047eb8ce32a166a73e433a7e19b15;hp=3d736b255952537f26515f97b5118116b9b1fce9;hpb=c2a4856f9e9aad8122f2386acdacf7aa385cfc1b;p=stockfish diff --git a/src/movegen.cpp b/src/movegen.cpp index 3d736b25..9b4cc130 100644 --- a/src/movegen.cpp +++ b/src/movegen.cpp @@ -157,7 +157,7 @@ MoveStack* generate(const Position& pos, MoveStack* mlist) { Bitboard target; if (Type == MV_CAPTURE || Type == MV_NON_EVASION) - target = pos.pieces_of_color(opposite_color(us)); + target = pos.pieces(opposite_color(us)); else if (Type == MV_NON_CAPTURE) target = pos.empty_squares(); else @@ -289,7 +289,7 @@ MoveStack* generate(const Position& pos, MoveStack* mlist) { } while (b); // Generate evasions for king, capture and non capture moves - b = pos.attacks_from(ksq) & ~pos.pieces_of_color(us) & ~sliderAttacks; + b = pos.attacks_from(ksq) & ~pos.pieces(us) & ~sliderAttacks; from = ksq; SERIALIZE_MOVES(b); @@ -411,7 +411,7 @@ namespace { Bitboard b1, b2, dc1, dc2, pawnPushes, emptySquares; Bitboard pawns = pos.pieces(PAWN, Us); Bitboard pawnsOn7 = pawns & TRank7BB; - Bitboard enemyPieces = (Type == MV_CAPTURE ? target : pos.pieces_of_color(Them)); + Bitboard enemyPieces = (Type == MV_CAPTURE ? target : pos.pieces(Them)); // Pre-calculate pawn pushes before changing emptySquares definition if (Type != MV_CAPTURE) @@ -517,12 +517,12 @@ namespace { // It is a bit complicated to correctly handle Chess960 for (s = Min(ksq, s1); s <= Max(ksq, s1); s++) - if ( (s != ksq && s != rsq && pos.square_is_occupied(s)) - ||(pos.attackers_to(s) & pos.pieces_of_color(them))) + if ( (s != ksq && s != rsq && !pos.square_is_empty(s)) + ||(pos.attackers_to(s) & pos.pieces(them))) illegal = true; for (s = Min(rsq, s2); s <= Max(rsq, s2); s++) - if (s != ksq && s != rsq && pos.square_is_occupied(s)) + if (s != ksq && s != rsq && !pos.square_is_empty(s)) illegal = true; if ( Side == QUEEN_SIDE