#ifndef INCLUDED_SRC_UTILS_CPP_CONCEPTS_HPP #define INCLUDED_SRC_UTILS_CPP_CONCEPTS_HPP #include #include // TODO(modernize): remove this once std::derived_from is shipped with libcxx template concept derived_from = std::is_base_of_v&& std::is_convertible_v; // TODO(modernize): remove this once std::same_as is shipped with libcxx template concept same_as = std::is_same_vand std::is_same_v; template concept ContainsString = requires { typename T::value_type; } and std::is_same_v; template concept HasSize = requires(T const c) { { c.size() } ->same_as; // TODO(modernize): replace by std::same_as }; template concept HasToString = requires(T const t) { { t.ToString() } ->same_as; // TODO(modernize): replace by std::same_as }; template concept InputIterableContainer = requires(T const c) { { c.begin() } ->same_as; // TODO(modernize): replace by // std::input_iterator { c.end() } ->same_as; // TODO(modernize): replace by // std::input_iterator }; template concept OutputIterableContainer = InputIterableContainerand requires(T c) { { std::inserter(c, c.begin()) } ->same_as>; // TODO(modernize): replace by // std::output_iterator }; template concept InputIterableStringContainer = InputIterableContainerand ContainsString; #endif // INCLUDED_SRC_UTILS_CPP_CONCEPTS_HPP