#pragma once #include "utils/iterator/composable.hpp" #include "utils/iterator/iterator_base.hpp" namespace iter { // Wraps lambda into interator with next(). // T - type of return value // F - type of wraped lambda template class LambdaIterator : public IteratorBase, public Composable> { public: LambdaIterator(F &&f, size_t count) : func(std::move(f)), _count(count) {} LambdaIterator(LambdaIterator &&other) : func(std::move(other.func)), _count(other._count) { } ~LambdaIterator() final {} Option next() final { _count = _count > 0 ? _count - 1 : 0; return func(); } Count count() final { return Count(_count); } private: F func; size_t _count; }; // Wraps lambda which returns options as an iterator. template auto make_iterator(F &&f) { return make_iterator(std::move(f), ~((size_t)0)); } // Wraps lambda which returns options as an iterator. template auto make_iterator(F &&f, size_t count) { // Because function isn't receving or in any way using type T from // FunctionIterator compiler can't deduce it thats way there is decltype in // construction of FunctionIterator. Resoulting type of iter.next().take() // is T. return LambdaIterator(std::move(f), count); } }