X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmovegen.h;h=0c781a6ba1c3aaa576628049652ea8e00ad609d1;hp=f14558e7ed4ea66a0b5ed9a3fea968d6fb7898ff;hb=f5e434c2d91cf1a43ee64dfc68318024ffaf7656;hpb=54f1c383d36f461a740eeaa93856b408e8d3faa3 diff --git a/src/movegen.h b/src/movegen.h index f14558e7..0c781a6b 100644 --- a/src/movegen.h +++ b/src/movegen.h @@ -20,6 +20,7 @@ #if !defined(MOVEGEN_H_INCLUDED) #define MOVEGEN_H_INCLUDED +#include "move.h" #include "position.h" enum MoveType { @@ -29,11 +30,26 @@ enum MoveType { MV_NON_CAPTURE_CHECK, MV_EVASION, MV_NON_EVASION, - MV_LEGAL, - MV_PSEUDO_LEGAL + MV_LEGAL }; -template +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++; } + bool end() const { return cur == last; } + Move move() const { return cur->move; } + int size() const { return int(last - mlist); } + +private: + MoveStack mlist[MAX_MOVES]; + MoveStack *cur, *last; +}; + #endif // !defined(MOVEGEN_H_INCLUDED)