X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmain.cpp;h=765cd2caa52b93d52ff9c7bbe0fb984b43d0676b;hp=e83c2cc5f94422dec45f4d77d1c0bf99a55190e0;hb=ad43ce143664953087b44dd3b4324f77c212bd46;hpb=660378d10e99f435df347f317878d7d2d9eade16 diff --git a/src/main.cpp b/src/main.cpp index e83c2cc5..765cd2ca 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -17,68 +17,41 @@ along with this program. If not, see . */ -// To profile with callgrind uncomment following line -//#define USE_CALLGRIND - - -//// -//// Includes -//// - #include #include -#include "bitcount.h" +#include "bitboard.h" #include "misc.h" - -#ifdef USE_CALLGRIND -#include -#endif +#include "position.h" +#include "search.h" +#include "thread.h" using namespace std; -extern void uci_main_loop(); +extern void uci_loop(); extern void benchmark(int argc, char* argv[]); - -//// -//// Functions -//// +extern void kpk_bitbase_init(); int main(int argc, char* argv[]) { - // Disable IO buffering - cout.rdbuf()->pubsetbuf(NULL, 0); - cin.rdbuf()->pubsetbuf(NULL, 0); - - // Initialization through global resources manager - Application::initialize(); + bitboards_init(); + Position::init(); + kpk_bitbase_init(); + Search::init(); + Threads.init(); -#ifdef USE_CALLGRIND - CALLGRIND_START_INSTRUMENTATION; -#endif + cout << engine_info() << endl; - if (argc <= 1) - { - // Print copyright notice - cout << engine_name() - << " by Tord Romstad, Marco Costalba, Joona Kiiski" << endl; + if (argc == 1) + uci_loop(); - if (CpuHasPOPCNT) - cout << "Good! CPU has hardware POPCNT." << endl; + else if (string(argv[1]) == "bench") + benchmark(argc, argv); - // Enter UCI mode - uci_main_loop(); - } - else // Process command line arguments - { - if (string(argv[1]) != "bench" || argc > 7) - cout << "Usage: stockfish bench [hash size = 128] [threads = 1] " - << "[limit = 12] [fen positions file = default] " - << "[depth, time, perft or node limited = depth]" << endl; - else - benchmark(argc, argv); - } + else + cerr << "\nUsage: stockfish bench [hash size = 128] [threads = 1] " + << "[limit = 12] [fen positions file = default] " + << "[limited by depth, time, nodes or perft = depth]" << endl; - Application::free_resources(); - return 0; + Threads.exit(); }