X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmovepick.cpp;h=35f9d25e5cc0cdf1cea5d0ea4ac804e0b4306b4c;hp=51d85192a7c4df8b9c0cfdd0ea0c3adfb7b9ff13;hb=ebb3e7df65b48b8c66c9853983865aefa02e6b59;hpb=2ec36f8ae8089bf1d687951c1d26c3a6a9e9eb01 diff --git a/src/movepick.cpp b/src/movepick.cpp index 51d85192..35f9d25e 100644 --- a/src/movepick.cpp +++ b/src/movepick.cpp @@ -25,7 +25,7 @@ namespace { enum Stages { - MAIN_SEARCH, CAPTURES_INIT, GOOD_CAPTURES, KILLERS, COUNTERMOVE, QUIET_INIT, QUIET, BAD_CAPTURES, + MAIN_SEARCH, CAPTURES_INIT, GOOD_CAPTURES, KILLER0, KILLER1, COUNTERMOVE, QUIET_INIT, QUIET, BAD_CAPTURES, EVASION, EVASIONS_INIT, ALL_EVASIONS, PROBCUT, PROBCUT_CAPTURES_INIT, PROBCUT_CAPTURES, QSEARCH, QCAPTURES_INIT, QCAPTURES, QCHECKS, QSEARCH_RECAPTURES, QRECAPTURES @@ -185,24 +185,20 @@ Move MovePicker::next_move(bool skipQuiets) { *endBadCaptures++ = move; } } - ++stage; - move = killers[0]; // First killer move - if ( move != MOVE_NONE - && move != ttMove - && pos.pseudo_legal(move) - && !pos.capture(move)) - return move; /* fallthrough */ - case KILLERS: - ++stage; - move = killers[1]; // Second killer move - if ( move != MOVE_NONE - && move != ttMove - && pos.pseudo_legal(move) - && !pos.capture(move)) - return move; + case KILLER0: + case KILLER1: + do + { + move = killers[++stage - KILLER1]; + if ( move != MOVE_NONE + && move != ttMove + && pos.pseudo_legal(move) + && !pos.capture(move)) + return move; + } while (stage <= KILLER1); /* fallthrough */ case COUNTERMOVE: