X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmain.cpp;h=56af9932a049e30b2977a0f730bcc943c0d14299;hp=1b2fdf9dec5efff93d657b46ff042b31ef516254;hb=ed72a1e9ba37a9fa2674da8f46bb0597a1721c2d;hpb=9934b8ec31483ceb98c19dfe4fface14fe384b32 diff --git a/src/main.cpp b/src/main.cpp index 1b2fdf9d..56af9932 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -1,7 +1,7 @@ /* Stockfish, a UCI chess playing engine derived from Glaurung 2.1 Copyright (C) 2004-2008 Tord Romstad (Glaurung author) - Copyright (C) 2008-2012 Marco Costalba, Joona Kiiski, Tord Romstad + Copyright (C) 2008-2015 Marco Costalba, Joona Kiiski, Tord Romstad Stockfish is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -18,48 +18,34 @@ */ #include -#include #include "bitboard.h" #include "evaluate.h" #include "position.h" #include "search.h" #include "thread.h" -#include "ucioption.h" - -using namespace std; - -extern void uci_loop(); -extern void benchmark(int argc, char* argv[]); -extern void kpk_bitbase_init(); +#include "tt.h" +#include "uci.h" +#include "syzygy/tbprobe.h" int main(int argc, char* argv[]) { - bitboards_init(); + std::cout << engine_info() << std::endl; + + UCI::init(Options); + PSQT::init(); + Bitboards::init(); Position::init(); - kpk_bitbase_init(); + Bitbases::init(); Search::init(); - Threads.init(); Eval::init(); - TT.set_size(Options["Hash"]); - - // Don't sync with C library I/O buffers, faster but now using printf() - // or scanf() could yield to issues because buffers are independent. - cout.sync_with_stdio(false); - cin.sync_with_stdio(false); - - cout << engine_info() << endl; - - if (argc == 1) - uci_loop(); - - else if (string(argv[1]) == "bench") - benchmark(argc, argv); + Pawns::init(); + Threads.init(); + Tablebases::init(Options["SyzygyPath"]); + TT.resize(Options["Hash"]); - 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; + UCI::loop(argc, argv); Threads.exit(); + return 0; }