Clean killers handling in movepicker
[stockfish] / src / application.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-2009 Marco Costalba
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
21 ////
22 //// Includes
23 ////
24
25 #include "bitboard.h"
26 #include "direction.h"
27 #include "endgame.h"
28 #include "evaluate.h"
29 #include "material.h"
30 #include "mersenne.h"
31 #include "misc.h"
32 #include "movepick.h"
33 #include "position.h"
34 #include "search.h"
35 #include "thread.h"
36 #include "ucioption.h"
37
38
39 /// Application class is in charge of initializing global resources
40 /// at startup and cleanly releases them when program terminates.
41
42 Application::Application() {
43
44     init_mersenne();
45     init_direction_table();
46     init_bitboards();
47     init_uci_options();
48     Position::init_zobrist();
49     Position::init_piece_square_tables();
50     init_eval(1);
51     init_bitbases();
52     init_threads();
53
54     // Make random number generation less deterministic, for book moves
55     for (int i = abs(get_system_time() % 10000); i > 0; i--)
56         genrand_int32();
57 }
58
59 Application::~Application() {
60
61   stop_threads();
62   quit_eval();
63 }
64
65 void Application::initialize() {
66
67   // A static Application object is allocated
68   // once only when this function is called.
69   static Application singleton;
70 }
71
72 void Application::exit_with_failure() {
73
74   exit(EXIT_FAILURE); // d'tor will be called automatically
75 }