X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fbook.h;h=fcbce65b16f55f12802e0d273fe5277078e99a6e;hp=0101bcf2c655f083c1f5083795826186623d9db4;hb=55df3fa2d7631ed67e46f9433aa7f3a71c18e5e7;hpb=d5f0b91c0622b843d8cc79774ce0b4caf9e8a0dd diff --git a/src/book.h b/src/book.h index 0101bcf2..fcbce65b 100644 --- a/src/book.h +++ b/src/book.h @@ -1,7 +1,7 @@ /* Stockfish, a UCI chess playing engine derived from Glaurung 2.1 Copyright (C) 2004-2008 Tord Romstad (Glaurung author) - Copyright (C) 2008-2010 Marco Costalba, Joona Kiiski, Tord Romstad + Copyright (C) 2008-2012 Marco Costalba, Joona Kiiski, Tord Romstad Stockfish is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -23,40 +23,23 @@ #include #include -#include "move.h" #include "position.h" #include "rkiss.h" - -// A Polyglot book is a series of "entries" of 16 bytes. All integers are -// stored highest byte first (regardless of size). The entries are ordered -// according to key. Lowest key first. -struct BookEntry { - uint64_t key; - uint16_t move; - uint16_t count; - uint32_t learn; -}; - -class Book { +class PolyglotBook : private std::ifstream { public: - Book(); - ~Book(); - void open(const std::string& fileName); - void close(); - Move get_move(const Position& pos, bool findBestMove); - const std::string name() const { return bookName; } + PolyglotBook(); + ~PolyglotBook(); + Move probe(const Position& pos, const std::string& fName, bool pickBest); private: - template Book& operator>>(T& n); + template PolyglotBook& operator>>(T& n); - BookEntry read_entry(int idx); - int find_entry(uint64_t key); + bool open(const char* fName); + size_t find_first(uint64_t key); - std::ifstream bookFile; - std::string bookName; - int bookSize; RKISS RKiss; + std::string fileName; }; #endif // !defined(BOOK_H_INCLUDED)