X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fbook.h;h=fcbce65b16f55f12802e0d273fe5277078e99a6e;hp=38804f9acf572b3518d105955d96539f04726c6e;hb=55df3fa2d7631ed67e46f9433aa7f3a71c18e5e7;hpb=de58594b0f95115109d0c8aeb56a6c5c85b94b9f diff --git a/src/book.h b/src/book.h index 38804f9a..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 first_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)