| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- //
- // accumulate.h
- // stream
- //
- // Created by Sam Jaffe on 3/29/23.
- //
- #pragma once
- #include <optional>
- #include <stream/detail/identity.h>
- #include <stream/detail/traits.h>
- #define FWD(x) std::forward<decltype(x)>(x)
- namespace stream::ranges {
- template <typename It, typename S, typename T, typename F>
- auto fold_left(It it, S end, T init, F reduce) {
- for (; it != end; ++it) {
- init = reduce(init, *it);
- }
- return init;
- }
- template <typename Stream, typename T, typename F>
- auto fold_left(Stream && stream, T init, F reduce) {
- for (auto && elem : FWD(stream)) {
- init = reduce(init, FWD(elem));
- }
- return init;
- }
- template <typename Stream, typename F>
- auto fold_left_with_first(Stream && stream, F reduce)
- -> std::optional<traits::value_type<Stream>> {
- if (stream.empty()) { return std::nullopt; }
- return fold_left(++stream.begin(), stream.end(), *stream.begin(), reduce);
- }
- template <typename Stream>
- auto first(Stream && stream) -> std::optional<traits::value_type<Stream>> {
- return stream.empty() ? std::nullopt : std::optional(*stream.begin());
- }
- template <typename It, typename S, typename Pred,
- typename Proj = detail::identity>
- bool any_of(It it, S end, Pred pred, Proj proj = {}) {
- for (; it != end; ++it) {
- if (pred(proj(*it))) { return true; }
- }
- return false;
- }
- template <typename Stream, typename Pred, typename Proj = detail::identity>
- bool any_of(Stream const & stream, Pred pred, Proj proj = {}) {
- return any_of(stream.begin(), stream.end(), pred, proj);
- }
- template <typename It, typename S, typename Pred,
- typename Proj = detail::identity>
- bool none_of(It it, S end, Pred pred, Proj proj = {}) {
- return !any_of(it, end, pred, proj);
- }
- template <typename Stream, typename Pred, typename Proj = detail::identity>
- bool none_of(Stream const & stream, Pred pred, Proj proj = {}) {
- return none_of(stream.begin(), stream.end(), pred, proj);
- }
- template <typename It, typename S, typename Pred,
- typename Proj = detail::identity>
- bool all_of(It it, S end, Pred pred, Proj proj = {}) {
- for (; it != end; ++it) {
- if (!pred(proj(*it))) { return false; }
- }
- return true;
- }
- template <typename Stream, typename Pred, typename Proj = detail::identity>
- bool all_of(Stream const & stream, Pred pred, Proj proj = {}) {
- return all_of(stream.begin(), stream.end(), pred, proj);
- }
- }
- #undef FWD
|