X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fbook.h;h=ed446636c8a45359489b61c345fe00aeb9b9fec2;hp=947e323ab26820abff41cc266ddc781e71c344f2;hb=203fdc9ac1b0ad5e5820b450a0cffdffb917e069;hpb=8307da0de77c9c7bbf7c56a7d9c8a688ff4dfb4e diff --git a/src/book.h b/src/book.h index 947e323a..ed446636 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-2012 Marco Costalba, Joona Kiiski, Tord Romstad + Copyright (C) 2008-2013 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 @@ -26,36 +26,20 @@ #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 probe(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(Key key); - RKISS RKiss; - std::ifstream bookFile; - std::string bookName; - int bookSize; + RKISS rkiss; + std::string fileName; }; #endif // !defined(BOOK_H_INCLUDED)