X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmovegen.h;h=fdac5d0ba00856ac489b66220d3164fb0f3a005e;hb=95d9687d95e5aa540c58e673300ef911164c90e0;hp=35fda92abe49350255bbd3be3d19a0ff5398908f;hpb=57b3ca916fdf12ad4ad3dfdcd215379e908b12be;p=stockfish diff --git a/src/movegen.h b/src/movegen.h index 35fda92a..fdac5d0b 100644 --- a/src/movegen.h +++ b/src/movegen.h @@ -17,10 +17,10 @@ along with this program. If not, see . */ - #if !defined(MOVEGEN_H_INCLUDED) #define MOVEGEN_H_INCLUDED +#include "move.h" #include "position.h" enum MoveType { @@ -30,14 +30,24 @@ 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); -extern bool move_is_legal(const Position& pos, const Move m, Bitboard pinned); -extern bool move_is_legal(const Position& pos, const Move m); +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)