/*
Stockfish, a UCI chess playing engine derived from Glaurung 2.1
- Copyright (C) 2004-2008 Tord Romstad (Glaurung author)
- Copyright (C) 2008-2015 Marco Costalba, Joona Kiiski, Tord Romstad
- Copyright (C) 2015-2019 Marco Costalba, Joona Kiiski, Gary Linscott, Tord Romstad
+ Copyright (C) 2004-2021 The Stockfish developers (see AUTHORS file)
Stockfish is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
#include <thread>
#include "bitboard.h"
+#include "endgame.h"
#include "position.h"
+#include "psqt.h"
#include "search.h"
+#include "syzygy/tbprobe.h"
#include "thread.h"
#include "tt.h"
#include "uci.h"
-#include "syzygy/tbprobe.h"
#include <grpc/grpc.h>
#include <grpc++/server.h>
using grpc::Status;
using grpc::StatusCode;
using namespace hashprobe;
+using namespace Stockfish;
Status HashProbeImpl::Probe(ServerContext* context,
const HashProbeRequest* request,
pretty = "O-O-O";
}
} else if (type_of(moved_piece) == PAWN) {
- if (type_of(move) == ENPASSANT || pos->piece_on(to) != NO_PIECE) {
+ if (type_of(move) == EN_PASSANT || pos->piece_on(to) != NO_PIECE) {
// Capture.
pretty = char('a' + file_of(from));
pretty += "x";
// Remove all illegal moves to disambiguate.
Bitboard att_copy = attackers;
while (att_copy) {
- Square s = pop_lsb(&att_copy);
+ Square s = pop_lsb(att_copy);
Move m = make_move(s, to);
if (!pos->pseudo_legal(m) || !pos->legal(m)) {
attackers &= ~SquareBB[s];
}
}
- if (type_of(move) == ENPASSANT || pos->piece_on(to) != NO_PIECE) {
+ if (type_of(move) == EN_PASSANT || pos->piece_on(to) != NO_PIECE) {
pretty += "x";
}
server->Shutdown();
}
-namespace PSQT {
- void init();
-}
-
int main(int argc, char* argv[]) {
std::cout << engine_info() << std::endl;
+ CommandLine::init(argc, argv);
UCI::init(Options);
+ Tune::init();
PSQT::init();
Bitboards::init();
Position::init();
Bitbases::init();
- Search::init();
- Pawns::init();
- Threads.set(Options["Threads"]);
+ Endgames::init();
+ Threads.set(size_t(Options["Threads"]));
Search::clear(); // After threads are up
+ Eval::NNUE::init();
UCI::loop(argc, argv);