mirror of
https://github.com/sockspls/badfish
synced 2025-05-02 09:39:36 +00:00
Move args parsing to UCI::loop
This leaves a very clean main.cpp No functional change.
This commit is contained in:
parent
ada55c5d0a
commit
b2c0634d48
3 changed files with 9 additions and 12 deletions
|
@ -18,7 +18,6 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <string>
|
|
||||||
|
|
||||||
#include "bitboard.h"
|
#include "bitboard.h"
|
||||||
#include "evaluate.h"
|
#include "evaluate.h"
|
||||||
|
@ -42,12 +41,7 @@ int main(int argc, char* argv[]) {
|
||||||
Threads.init();
|
Threads.init();
|
||||||
TT.resize(Options["Hash"]);
|
TT.resize(Options["Hash"]);
|
||||||
|
|
||||||
std::string args;
|
UCI::loop(argc, argv);
|
||||||
|
|
||||||
for (int i = 1; i < argc; ++i)
|
|
||||||
args += std::string(argv[i]) + " ";
|
|
||||||
|
|
||||||
UCI::loop(args);
|
|
||||||
|
|
||||||
Threads.exit();
|
Threads.exit();
|
||||||
}
|
}
|
||||||
|
|
11
src/uci.cpp
11
src/uci.cpp
|
@ -143,13 +143,16 @@ namespace {
|
||||||
/// that we exit gracefully if the GUI dies unexpectedly. In addition to the UCI
|
/// that we exit gracefully if the GUI dies unexpectedly. In addition to the UCI
|
||||||
/// commands, the function also supports a few debug commands.
|
/// commands, the function also supports a few debug commands.
|
||||||
|
|
||||||
void UCI::loop(const string& args) {
|
void UCI::loop(int argc, char* argv[]) {
|
||||||
|
|
||||||
Position pos(StartFEN, false, Threads.main()); // The root position
|
Position pos(StartFEN, false, Threads.main()); // The root position
|
||||||
string token, cmd = args;
|
string token, cmd;
|
||||||
|
|
||||||
|
for (int i = 1; i < argc; ++i)
|
||||||
|
cmd += std::string(argv[i]) + " ";
|
||||||
|
|
||||||
do {
|
do {
|
||||||
if (args.empty() && !getline(cin, cmd)) // Block here waiting for input
|
if (argc == 1 && !getline(cin, cmd)) // Block here waiting for input
|
||||||
cmd = "quit";
|
cmd = "quit";
|
||||||
|
|
||||||
istringstream is(cmd);
|
istringstream is(cmd);
|
||||||
|
@ -208,7 +211,7 @@ void UCI::loop(const string& args) {
|
||||||
else
|
else
|
||||||
sync_cout << "Unknown command: " << cmd << sync_endl;
|
sync_cout << "Unknown command: " << cmd << sync_endl;
|
||||||
|
|
||||||
} while (token != "quit" && args.empty()); // Args have one-shot behaviour
|
} while (token != "quit" && argc == 1); // Passed args have one-shot behaviour
|
||||||
|
|
||||||
Threads.wait_for_think_finished(); // Cannot quit whilst the search is running
|
Threads.wait_for_think_finished(); // Cannot quit whilst the search is running
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,7 +61,7 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
void init(OptionsMap&);
|
void init(OptionsMap&);
|
||||||
void loop(const std::string&);
|
void loop(int argc, char* argv[]);
|
||||||
|
|
||||||
} // namespace UCI
|
} // namespace UCI
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue