X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=src%2Fuci.cpp;h=0057881b010a812404e1e7d94c87166805f8a007;hb=d11a52990459601e46e02a8759616737dc045f74;hp=ed370483435366e62e459ea00a985b3a288ed8f0;hpb=7c8a8e038f0acd48a30ec7e3971c7d0efcfbf25d;p=stockfish diff --git a/src/uci.cpp b/src/uci.cpp index ed370483..0057881b 100644 --- a/src/uci.cpp +++ b/src/uci.cpp @@ -67,7 +67,12 @@ void uci_loop() { is >> skipws >> token; if (token == "quit" || token == "stop") - Threads.stop_thinking(); + { + Search::Signals.stop = true; + + if (token == "quit") // Cannot quit while threads are still running + Threads.wait_for_search_finished(); + } else if (token == "ponderhit") { @@ -77,7 +82,7 @@ void uci_loop() { Search::Limits.ponder = false; if (Search::Signals.stopOnPonderhit) - Threads.stop_thinking(); + Search::Signals.stop = true; } else if (token == "go") @@ -175,14 +180,10 @@ namespace { while (is >> token) value += string(" ", !value.empty()) + token; - if (!Options.count(name)) - cout << "No such option: " << name << endl; - - else if (value.empty()) // UCI buttons don't have a value - Options[name] = true; - - else + if (Options.count(name)) Options[name] = value; + else + cout << "No such option: " << name << endl; } @@ -227,7 +228,7 @@ namespace { limits.time = time[pos.side_to_move()]; limits.increment = inc[pos.side_to_move()]; - Threads.start_thinking(pos, limits, searchMoves, true); + Threads.start_searching(pos, limits, searchMoves, true); }