]> git.sesse.net Git - stockfish/blob - src/main.cpp
Restore std::cout instead of printf()
[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 <iostream>
21 #include <string>
22
23 #include "bitboard.h"
24 #include "evaluate.h"
25 #include "position.h"
26 #include "thread.h"
27 #include "search.h"
28 #include "ucioption.h"
29
30 using namespace std;
31
32 extern void uci_loop();
33 extern void benchmark(int argc, char* argv[]);
34 extern void kpk_bitbase_init();
35
36 int main(int argc, char* argv[]) {
37
38   bitboards_init();
39   Position::init();
40   kpk_bitbase_init();
41   Search::init();
42   Threads.init();
43
44   if (argc < 2)
45   {
46       cout << engine_name() << " by " << engine_authors() << endl;
47
48       if (CpuHasPOPCNT)
49           cout << "Good! CPU has hardware POPCNT." << endl;
50
51       uci_loop(); // Enter the UCI loop and wait for user input
52   }
53   else if (string(argv[1]) == "bench")
54       benchmark(argc, argv);
55
56   else
57       cout << "Usage: stockfish bench [hash size = 128] [threads = 1] "
58            << "[limit = 12] [fen positions file = default] "
59            << "[limited by depth, time, nodes or perft = depth]" << endl;
60
61   Threads.exit();
62   return 0;
63 }