X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmovegen.h;h=62a121d7d291629e37aeebe32afe32fbc29776c6;hp=c844efcd5742e69ea79219509af96369926e658e;hb=950c8436edc50857b83eb3e0cbaca06407764655;hpb=7c267587fc7f454182b4d527607bcf8fdbd8c41c diff --git a/src/movegen.h b/src/movegen.h index c844efcd..62a121d7 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 Marco Costalba + Copyright (C) 2008-2015 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,27 +17,51 @@ along with this program. If not, see . */ - -#if !defined(MOVEGEN_H_INCLUDED) +#ifndef MOVEGEN_H_INCLUDED #define MOVEGEN_H_INCLUDED -//// -//// Includes -//// +#include "types.h" + +class Position; + +enum GenType { + CAPTURES, + QUIETS, + QUIET_CHECKS, + EVASIONS, + NON_EVASIONS, + LEGAL +}; + +struct ExtMove { + Move move; + Value value; +}; -#include "position.h" +inline bool operator<(const ExtMove& f, const ExtMove& s) { + return f.value < s.value; +} +template +ExtMove* generate(const Position& pos, ExtMove* moveList); -//// -//// Prototypes -//// +/// The MoveList struct is a simple wrapper around generate(). It sometimes comes +/// in handy to use this class instead of the low level generate() function. +template +struct MoveList { -extern int generate_captures(const Position& pos, MoveStack* mlist); -extern int generate_noncaptures(const Position& pos, MoveStack* mlist); -extern int generate_non_capture_checks(const Position& pos, MoveStack* mlist, Bitboard dc); -extern int generate_evasions(const Position& pos, MoveStack* mlist, Bitboard pinned); -extern int generate_legal_moves(const Position& pos, MoveStack* mlist); -extern bool move_is_legal(const Position& pos, const Move m, Bitboard pinned); + explicit MoveList(const Position& pos) : cur(moveList), last(generate(pos, moveList)) { last->move = MOVE_NONE; } + void operator++() { ++cur; } + Move operator*() const { return cur->move; } + size_t size() const { return last - moveList; } + bool contains(Move m) const { + for (const ExtMove* it(moveList); it != last; ++it) if (it->move == m) return true; + return false; + } +private: + ExtMove moveList[MAX_MOVES]; + ExtMove *cur, *last; +}; -#endif // !defined(MOVEGEN_H_INCLUDED) +#endif // #ifndef MOVEGEN_H_INCLUDED