5#ifndef DUNE_COMMON_CONCEPT_HH
6#define DUNE_COMMON_CONCEPT_HH
13#include <dune/common/typelist.hh>
14#include <dune/common/indices.hh>
51template<
class... BaseConcepts>
54 typedef TypeList<BaseConcepts...> BaseConceptList;
68 template<
class C,
class... T>
85 template<
class C,
class... T,
86 decltype(std::declval<C>().require(std::declval<T>()...), 0) =0>
93 template<
class C,
class... T>
94 constexpr std::false_type matchesRequirement(PriorityTag<0>)
101 constexpr bool modelsConceptList(TypeList<>)
107 template<
class...T,
class C0,
class... CC>
108 constexpr bool modelsConceptList(TypeList<C0, CC...>)
109 {
return models<C0, T...>() and modelsConceptList<T...>(TypeList<CC...>()); }
115 template<
class C,
class... T>
116 constexpr bool modelsConcept(PriorityTag<0>)
117 {
return matchesRequirement<C, T...>(PriorityTag<42>()); }
125 template<
class C,
class... T,
126 decltype(
typename C::BaseConceptList(), 0) = 0>
127 constexpr bool modelsConcept(PriorityTag<1>)
128 {
return matchesRequirement<C, T...>(PriorityTag<42>()) and modelsConceptList<T...>(
typename C::BaseConceptList()); }
139 template<
class C,
class... T>
142 return modelsConcept<C, T...>(PriorityTag<42>());
182template<
class C,
class... T>
197template<
class C,
class Tuple>
198constexpr auto tupleEntriesModel()
201 return std::conjunction<
decltype(
Dune::models<C, std::tuple_element_t<
decltype(i)::value, Tuple>>())...>();
202 }, std::make_index_sequence<std::tuple_size_v<Tuple>>());
213template<bool b, typename std::enable_if<b, int>::type = 0>
214constexpr bool requireTrue()
220template<
class C,
class... T,
typename std::enable_if<
models<C, T...>(),
int>::type = 0>
221constexpr bool requireConcept()
228template<
class C,
class... T,
typename std::enable_if<
models<C, T...>(),
int>::type = 0>
229constexpr bool requireConcept(T&&... )
236template<class C, class Tuple, typename std::enable_if<tupleEntriesModel<C, Tuple>(),
int>::type = 0>
237constexpr bool requireConceptForTupleEntries()
244template<
class From,
class To,
245 typename std::enable_if< std::is_convertible<From, To>::value,
int>::type = 0>
246constexpr bool requireConvertible()
253template<
class To,
class From,
254 typename std::enable_if< std::is_convertible<From, To>::value,
int>::type = 0>
255constexpr bool requireConvertible(
const From&)
265constexpr bool requireType()
272template<
class Base,
class Derived,
273 typename std::enable_if< std::is_base_of<Base, Derived>::value,
int>::type = 0>
274constexpr bool requireBaseOf()
281template<
class Base,
class Derived,
282 typename std::enable_if< std::is_base_of<Base, Derived>::value,
int>::type = 0>
283constexpr bool requireBaseOf(
const Derived&)
290template<
class A,
class B,
291 typename std::enable_if< std::is_same<A, B>::value,
int>::type = 0>
292constexpr bool requireSameType()
decltype(auto) constexpr unpackIntegerSequence(F &&f, std::integer_sequence< I, i... > sequence)
Unpack an std::integer_sequence<I,i...> to std::integral_constant<I,i>...
Definition: indices.hh:124
constexpr auto models()
Check if concept is modeled by given types.
Definition: concept.hh:183
std::tuple< MetaType< T >... > TypeList
A simple type list.
Definition: typelist.hh:87
Dune namespace
Definition: alignedallocator.hh:13
Base class for refined concepts.
Definition: concept.hh:53
Helper class for tagging priorities.
Definition: typeutilities.hh:73
Utilities for type computations, constraining overloads, ...