X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmovegen.h;h=9db23dd407c1d23e35d03cb4874040005c3b931b;hp=7b7c4e91bb4857094e7a21cb667452e72ad3cb8d;hb=8ceef922662c75c33d105d99732475c125b01081;hpb=9e4befe3f1ea324bece88aee2e97b38659411c52 diff --git a/src/movegen.h b/src/movegen.h index 7b7c4e91..9db23dd4 100644 --- a/src/movegen.h +++ b/src/movegen.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-2009 Marco Costalba + 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 @@ -17,28 +17,43 @@ along with this program. If not, see . */ - #if !defined(MOVEGEN_H_INCLUDED) #define MOVEGEN_H_INCLUDED -//// -//// Includes -//// - -#include "position.h" - - -//// -//// Prototypes -//// - -extern MoveStack* generate_captures(const Position& pos, MoveStack* mlist); -extern MoveStack* generate_noncaptures(const Position& pos, MoveStack* mlist); -extern MoveStack* generate_non_capture_checks(const Position& pos, MoveStack* mlist, Bitboard dc); -extern MoveStack* generate_evasions(const Position& pos, MoveStack* mlist, Bitboard pinned); -extern MoveStack* generate_legal_moves(const Position& pos, MoveStack* mlist); -extern bool move_is_legal(const Position& pos, const Move m, Bitboard pinned); -extern bool move_is_legal(const Position& pos, const Move m); - +#include "types.h" + +enum GenType { + CAPTURES, + QUIETS, + QUIET_CHECKS, + EVASIONS, + NON_EVASIONS, + LEGAL +}; + +class Position; + +template +MoveStack* generate(const Position& pos, MoveStack* mlist); + +/// The MoveList struct is a simple wrapper around generate(), sometimes comes +/// handy to use this class instead of the low level generate() function. +template +struct MoveList { + + explicit MoveList(const Position& pos) : cur(mlist), last(generate(pos, mlist)) {} + void operator++() { cur++; } + Move operator*() const { return cur->move; } + bool end() const { return cur == last; } + size_t size() const { return last - mlist; } + bool contains(Move m) const { + for (const MoveStack* it(mlist); it != last; ++it) if (it->move == m) return true; + return false; + } + +private: + MoveStack mlist[MAX_MOVES]; + MoveStack *cur, *last; +}; #endif // !defined(MOVEGEN_H_INCLUDED)