X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fuci.cpp;h=1b7705065cd5de4dc6fefca0b2a1f9912cb07dd9;hp=987da9c1f879ec7304184092ffa14028c5dab396;hb=cc2b3ece5c5d8d1183f8526fbb0ee4e1ea7a69fe;hpb=3aa471f2a9cb1cccd37c27906dd386b9724e32ab diff --git a/src/uci.cpp b/src/uci.cpp index 987da9c1..1b770506 100644 --- a/src/uci.cpp +++ b/src/uci.cpp @@ -69,7 +69,9 @@ void uci_loop() { if (token == "quit" || token == "stop") { Search::Signals.stop = true; - Threads.wait_for_search_finished(); // Cannot quit while threads are running + + if (token == "quit") // Cannot quit while threads are still running + Threads.wait_for_search_finished(); } else if (token == "ponderhit") @@ -80,10 +82,7 @@ void uci_loop() { Search::Limits.ponder = false; if (Search::Signals.stopOnPonderhit) - { Search::Signals.stop = true; - Threads.wait_for_search_finished(); - } } else if (token == "go") @@ -190,46 +189,42 @@ namespace { // go() is called when engine receives the "go" UCI command. The function sets // the thinking time and other parameters from the input string, and then starts - // the main searching thread. + // the search. void go(Position& pos, istringstream& is) { - string token; Search::LimitsType limits; std::set searchMoves; - int time[] = { 0, 0 }, inc[] = { 0, 0 }; + string token; while (is >> token) { - if (token == "infinite") - limits.infinite = true; - else if (token == "ponder") - limits.ponder = true; - else if (token == "wtime") - is >> time[WHITE]; + if (token == "wtime") + is >> limits.times[WHITE]; else if (token == "btime") - is >> time[BLACK]; + is >> limits.times[BLACK]; else if (token == "winc") - is >> inc[WHITE]; + is >> limits.incs[WHITE]; else if (token == "binc") - is >> inc[BLACK]; + is >> limits.incs[BLACK]; else if (token == "movestogo") - is >> limits.movesToGo; + is >> limits.movestogo; else if (token == "depth") - is >> limits.maxDepth; + is >> limits.depth; else if (token == "nodes") - is >> limits.maxNodes; + is >> limits.nodes; else if (token == "movetime") - is >> limits.maxTime; + is >> limits.movetime; + else if (token == "infinite") + limits.infinite = true; + else if (token == "ponder") + limits.ponder = true; else if (token == "searchmoves") while (is >> token) searchMoves.insert(move_from_uci(pos, token)); } - limits.time = time[pos.side_to_move()]; - limits.increment = inc[pos.side_to_move()]; - - Threads.start_searching(pos, limits, searchMoves, true); + Threads.start_searching(pos, limits, searchMoves); }