fcb7e40c25118bf81f35a2361fd77d4d69840d33
[stockfish] / src / main.cpp
1 /*
2   Stockfish, a UCI chess playing engine derived from Glaurung 2.1
3   Copyright (C) 2004-2008 Tord Romstad (Glaurung author)
4   Copyright (C) 2008-2010 Marco Costalba, Joona Kiiski, Tord Romstad
5
6   Stockfish is free software: you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation, either version 3 of the License, or
9   (at your option) any later version.
10
11   Stockfish is distributed in the hope that it will be useful,
12   but WITHOUT ANY WARRANTY; without even the implied warranty of
13   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14   GNU General Public License for more details.
15
16   You should have received a copy of the GNU General Public License
17   along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include <cstdio>
21 #include <iostream>
22 #include <string>
23
24 #include "bitboard.h"
25 #include "evaluate.h"
26 #include "position.h"
27 #include "thread.h"
28 #include "search.h"
29 #include "ucioption.h"
30
31 using namespace std;
32
33 extern void uci_loop();
34 extern void benchmark(int argc, char* argv[]);
35 extern void kpk_bitbase_init();
36
37 int main(int argc, char* argv[]) {
38
39   // Disable output buffering: printf() does not work correctly otherwise
40   setvbuf(stdout, NULL, _IONBF, 0);
41
42   bitboards_init();
43   Position::init();
44   kpk_bitbase_init();
45   Search::init();
46   Threads.init();
47
48   if (argc < 2)
49   {
50       cout << engine_name() << " by " << engine_authors() << endl;
51
52       if (CpuHasPOPCNT)
53           cout << "Good! CPU has hardware POPCNT." << endl;
54
55       uci_loop(); // Enter the UCI loop and wait for user input
56   }
57   else if (string(argv[1]) == "bench")
58       benchmark(argc, argv);
59
60   else
61       cout << "Usage: stockfish bench [hash size = 128] [threads = 1] "
62            << "[limit = 12] [fen positions file = default] "
63            << "[limited by depth, time, nodes or perft = depth]" << endl;
64
65   Threads.exit();
66   return 0;
67 }