/* This file is part of Telegram Desktop, the official desktop version of Telegram messaging app, see https://telegram.org Telegram Desktop is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. It is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. In addition, as a special exception, the copyright holders give permission to link the code of portions of this program with the OpenSSL library. Full license: https://github.com/telegramdesktop/tdesktop/blob/master/LICENSE Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org */ #pragma once #include namespace rpl { template inline producer, Error> single(Value &&value) { using consumer_t = consumer, Error>; return [value = std::forward(value)]( const consumer_t &consumer) mutable { consumer.put_next(std::move(value)); consumer.put_done(); return lifetime(); }; } template inline producer single() { return [](const consumer &consumer) { consumer.put_next({}); consumer.put_done(); return lifetime(); }; } template inline producer vector(std::vector &&values) { return [values = std::move(values)]( const consumer &consumer) mutable { for (auto &value : values) { consumer.put_next(std::move(value)); } consumer.put_done(); return lifetime(); }; } template inline producer vector(std::vector &&values) { return [values = std::move(values)]( const consumer &consumer) mutable { for (auto value : values) { consumer.put_next_copy(value); } consumer.put_done(); return lifetime(); }; } template inline producer range(Range &&range) { return vector(std::vector( std::begin(range), std::end(range))); } inline producer ints(int from, int till) { Expects(from <= till); return [from, till](const consumer &consumer) { for (auto i = from; i != till; ++i) { consumer.put_next_copy(i); } consumer.put_done(); return lifetime(); }; } inline producer ints(int count) { return ints(0, count); } } // namespace rpl