Use Heinz's RKiss instead of marsenne
[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-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
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 "misc.h"
31 #include "movepick.h"
32 #include "position.h"
33 #include "search.h"
34 #include "thread.h"
35 #include "ucioption.h"
36
37
38 /// Application class is in charge of initializing global resources
39 /// at startup and cleanly releases them when program terminates.
40
41 Application::Application() {
42
43     init_direction_table();
44     init_bitboards();
45     init_uci_options();
46     Position::init_zobrist();
47     Position::init_piece_square_tables();
48     init_eval(1);
49     init_bitbases();
50     init_search();
51     init_threads();
52 }
53
54 void Application::initialize() {
55
56   // A static Application object is allocated
57   // once only when this function is called.
58   static Application singleton;
59 }
60
61 void Application::free_resources() {
62
63   // Warning, following functions reference global objects that
64   // must be still alive when free_resources() is called.
65   exit_threads();
66   quit_eval();
67 }
68
69 void Application::exit_with_failure() {
70
71   exit(EXIT_FAILURE);
72 }