X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmain.cpp;h=1a8309700555bfd61ef916fad97619d48d50386f;hb=07f3f0384a95a6de8a4a6a066e1ec81de24b41f1;hp=0e1690440dc1e498febec0d769519af4406a37c9;hpb=fecefbb99cb0147f37d6895765a315f34c935786;p=stockfish
diff --git a/src/main.cpp b/src/main.cpp
index 0e169044..1a830970 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -17,10 +17,6 @@
along with this program. If not, see .
*/
-// To profile with callgrind uncomment following line
-//#define USE_CALLGRIND
-
-#include
#include
#include
@@ -31,57 +27,37 @@
#include "search.h"
#include "ucioption.h"
-#ifdef USE_CALLGRIND
-#include
-#endif
-
using namespace std;
-extern bool execute_uci_command(const string& cmd);
+extern void uci_loop();
extern void benchmark(int argc, char* argv[]);
-extern void init_kpk_bitbase();
+extern void kpk_bitbase_init();
int main(int argc, char* argv[]) {
- // Disable IO buffering for C and C++ standard libraries
- setvbuf(stdin, NULL, _IONBF, 0);
- setvbuf(stdout, NULL, _IONBF, 0);
- cout.rdbuf()->pubsetbuf(NULL, 0);
- cin.rdbuf()->pubsetbuf(NULL, 0);
-
- // Startup initializations
- init_bitboards();
- Position::init_zobrist();
- Position::init_piece_square_tables();
- init_kpk_bitbase();
- init_search();
- ThreadsMgr.init_threads();
-
-#ifdef USE_CALLGRIND
- CALLGRIND_START_INSTRUMENTATION;
-#endif
+ bitboards_init();
+ Position::init();
+ kpk_bitbase_init();
+ Search::init();
+ Threads.init();
if (argc < 2)
{
- // Print copyright notice
cout << engine_name() << " by " << engine_authors() << endl;
if (CpuHasPOPCNT)
cout << "Good! CPU has hardware POPCNT." << endl;
- // Wait for a command from the user, and passes this command to
- // execute_uci_command() and also intercepts EOF from stdin to
- // ensure that we exit gracefully if the GUI dies unexpectedly.
- string cmd;
- while (getline(cin, cmd) && execute_uci_command(cmd)) {}
+ uci_loop(); // Enter the UCI loop and wait for user input
}
- else if (string(argv[1]) == "bench" && argc < 8)
+ else if (string(argv[1]) == "bench")
benchmark(argc, argv);
+
else
cout << "Usage: stockfish bench [hash size = 128] [threads = 1] "
<< "[limit = 12] [fen positions file = default] "
- << "[depth, time, perft or node limited = depth]" << endl;
+ << "[limited by depth, time, nodes or perft = depth]" << endl;
- ThreadsMgr.exit_threads();
+ Threads.exit();
return 0;
}