// Matrix Construct // // Copyright (C) Matrix Construct Developers, Authors & Contributors // Copyright (C) 2016-2018 Jason Volk <jason@zemos.net> // // Permission to use, copy, modify, and/or distribute this software for any // purpose with or without fee is hereby granted, provided that the above // copyright notice and this permission notice is present in all copies. The // full license for this software is available in the LICENSE file. #pragma once #define HAVE_IRCD_JSON_TUPLE_FOR_EACH_H namespace ircd { namespace json { template<class tuple, class function> inline enable_if_tuple<tuple, bool> for_each(const tuple &t, function&& f) { return util::for_each(t, [&f] (const auto &prop) { return f(prop.key, prop.value); }); } template<class tuple, class function> inline enable_if_tuple<tuple, bool> for_each(tuple &t, function&& f) { return util::for_each(t, [&f] (auto &prop) { return f(prop.key, prop.value); }); } template<class tuple, class function> inline void for_each(const tuple &t, const vector_view<const string_view> &mask, function&& f) { std::for_each(std::begin(mask), std::end(mask), [&t, &f] (const auto &key) { at(t, key, [&f, &key] (auto&& val) { f(key, val); }); }); } template<class tuple, class function> inline void for_each(tuple &t, const vector_view<const string_view> &mask, function&& f) { std::for_each(std::begin(mask), std::end(mask), [&t, &f] (const auto &key) { at(t, key, [&f, &key] (auto&& val) { f(key, val); }); }); } } // namespace json } // namespace ircd