X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmain.cpp;h=f94a322c4afc5fedca652c5e453866d35dee41e3;hp=a437f8839aface14cae7b15dede06a3cd2952d5a;hb=d39bc2efa197ba2fd55b68eced1c60bcfe2facc1;hpb=efd21679980dfd59320a5e238f44952873353829 diff --git a/src/main.cpp b/src/main.cpp index a437f883..f94a322c 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -1,7 +1,8 @@ /* Stockfish, a UCI chess playing engine derived from Glaurung 2.1 Copyright (C) 2004-2008 Tord Romstad (Glaurung author) - Copyright (C) 2008-2010 Marco Costalba, Joona Kiiski, Tord Romstad + Copyright (C) 2008-2015 Marco Costalba, Joona Kiiski, Tord Romstad + Copyright (C) 2015-2019 Marco Costalba, Joona Kiiski, Gary Linscott, 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,46 +19,36 @@ */ #include -#include #include "bitboard.h" -#include "evaluate.h" #include "position.h" -#include "thread.h" #include "search.h" -#include "ucioption.h" - -using namespace std; +#include "thread.h" +#include "tt.h" +#include "uci.h" +#include "endgame.h" +#include "syzygy/tbprobe.h" -extern void uci_loop(); -extern void benchmark(int argc, char* argv[]); -extern void kpk_bitbase_init(); +namespace PSQT { + void init(); +} int main(int argc, char* argv[]) { - init_bitboards(); + std::cout << engine_info() << std::endl; + + UCI::init(Options); + PSQT::init(); + Bitboards::init(); Position::init(); - kpk_bitbase_init(); + Bitbases::init(); + Endgames::init(); Search::init(); - Threads.init(); - - if (argc < 2) - { - cout << engine_name() << " by " << engine_authors() << endl; - - if (CpuHasPOPCNT) - cout << "Good! CPU has hardware POPCNT." << endl; - - uci_loop(); // Enter the UCI loop and wait for user input - } - else if (string(argv[1]) == "bench") - benchmark(argc, argv); + Threads.set(Options["Threads"]); + Search::clear(); // After threads are up - else - cout << "Usage: 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(); + Threads.set(0); return 0; }