X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmovegen.cpp;h=e1e6a54b72aa718c55c9c51bc38416f0d13a4e25;hb=8f51f09de7813ebc0f5f3efb9d0c142b884faeb3;hp=f38d42261ccfbdf827cdc5d9ad1c813f812a4aff;hpb=4dc7ba16191bd1ded7c8257afd2a3b9194cebca8;p=stockfish diff --git a/src/movegen.cpp b/src/movegen.cpp index f38d4226..e1e6a54b 100644 --- a/src/movegen.cpp +++ b/src/movegen.cpp @@ -304,16 +304,7 @@ MoveStack* generate(const Position& pos, MoveStack* mlist) { } -/// generate computes a complete list of legal -/// or pseudo-legal moves in the current position. -template<> -MoveStack* generate(const Position& pos, MoveStack* mlist) { - - assert(pos.is_ok()); - - return pos.in_check() ? generate(pos, mlist) - : generate(pos, mlist); -} +/// generate computes a complete list of legal moves in the current position template<> MoveStack* generate(const Position& pos, MoveStack* mlist) { @@ -323,7 +314,8 @@ MoveStack* generate(const Position& pos, MoveStack* mlist) { MoveStack *last, *cur = mlist; Bitboard pinned = pos.pinned_pieces(pos.side_to_move()); - last = generate(pos, mlist); + last = pos.in_check() ? generate(pos, mlist) + : generate(pos, mlist); // Remove illegal moves from the list while (cur != last) @@ -451,7 +443,7 @@ namespace { // Single and double pawn pushes if (Type != MV_CAPTURE) { - b1 = pawnPushes & emptySquares; + b1 = (Type != MV_EVASION ? pawnPushes : pawnPushes & emptySquares); b2 = move_pawns(pawnPushes & TRank3BB) & emptySquares; if (Type == MV_CHECK)