5#ifndef DUNE_COMMON_CONCEPT_HH
6#define DUNE_COMMON_CONCEPT_HH
51template<
class... BaseConcepts>
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>
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>
185 return std::bool_constant<Concept::Impl::models<C, T...>()>();
197template<
class C,
class Tuple>
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>
220template<
class C,
class... T,
typename std::enable_if<
models<C, T...>(),
int>
::type = 0>
228template<
class C,
class... T,
typename std::enable_if<
models<C, T...>(),
int>
::type = 0>
236template<class C, class Tuple, typename std::enable_if<tupleEntriesModel<C, Tuple>(),
int>
::type = 0>
244template<
class From,
class To,
245 typename std::enable_if< std::is_convertible<From, To>::value,
int>
::type = 0>
253template<
class To,
class From,
254 typename std::enable_if< std::is_convertible<From, To>::value,
int>
::type = 0>
272template<
class Base,
class Derived,
273 typename std::enable_if< std::is_base_of<Base, Derived>::value,
int>
::type = 0>
281template<
class Base,
class Derived,
282 typename std::enable_if< std::is_base_of<Base, Derived>::value,
int>
::type = 0>
290template<
class A,
class B,
291 typename std::enable_if< std::is_same<A, B>::value,
int>
::type = 0>
Utilities for type computations, constraining overloads, ...
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
std::tuple< MetaType< T >... > TypeList
A simple type list.
Definition typelist.hh:87
constexpr auto models()
Check if concept is modeled by given types.
Definition concept.hh:183
Dune namespace
Definition alignedallocator.hh:13
Namespace for concepts.
Definition concept.hh:33
constexpr bool requireConcept()
Definition concept.hh:221
constexpr bool requireTrue()
Definition concept.hh:214
constexpr bool requireSameType()
Definition concept.hh:292
constexpr bool requireConceptForTupleEntries()
Definition concept.hh:237
constexpr bool requireBaseOf()
Definition concept.hh:274
constexpr bool requireConvertible()
Definition concept.hh:246
constexpr auto tupleEntriesModel()
Definition concept.hh:198
constexpr bool requireType()
Definition concept.hh:265
Base class for refined concepts.
Definition concept.hh:53
TypeList< BaseConcepts... > BaseConceptList
Definition concept.hh:54
Helper class for tagging priorities.
Definition typeutilities.hh:73