X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fbook.h;h=24fa9f2daf45b2e1c087bf644ecf053f1cdcf449;hp=55d212a88634b03e00ebad286ad2f5a3aa868b4f;hb=c47a74ec62c8c4fdacf6d16eef068b62634122f1;hpb=04108d45414c70c796d9378b247207b574e22414 diff --git a/src/book.h b/src/book.h index 55d212a8..24fa9f2d 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,14 +23,13 @@ #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. +/// 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; @@ -38,35 +37,22 @@ struct BookEntry { uint32_t learn; }; -class Book { + +class Book : 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; } + Move probe(const Position& pos, const std::string& fName, bool pickBest); private: - // read n chars from the file stream and converts them in an - // integer number. Integers are stored with highest byte first. - template uint64_t get_int(); - - template - Book& operator>>(T& n) { n = (T)get_int(); return *this; } + template Book& operator>>(T& n); - BookEntry read_entry(int idx); - int find_entry(uint64_t key); + bool open(const char* fName); + void binary_search(uint64_t key); - std::ifstream bookFile; - std::string bookName; - int bookSize; RKISS RKiss; + std::string fileName; + size_t size; }; -// Yes, we indulge a bit here ;-) -template inline uint64_t Book::get_int() { return 256 * get_int() + bookFile.get(); } -template<> inline uint64_t Book::get_int<1>() { return bookFile.get(); } - - #endif // !defined(BOOK_H_INCLUDED)