mirror of
https://github.com/boostorg/callable_traits.git
synced 2026-02-10 11:22:13 +00:00
documentation and examples
This commit is contained in:
88
example/is_constexpr_function_object.cpp
Normal file
88
example/is_constexpr_function_object.cpp
Normal file
@@ -0,0 +1,88 @@
|
||||
/*<-
|
||||
Copyright Barrett Adair 2016
|
||||
Distributed under the Boost Software License, Version 1.0.
|
||||
(See accompanying file LICENSE.md or copy at http ://boost.org/LICENSE_1_0.txt)
|
||||
->*/
|
||||
|
||||
//[ is_constexpr_function_object
|
||||
/*`[warning When compiling in MSVC, `is_constexpr` always returns
|
||||
`std::false_type`, because MSVC cannot compile the logic that normally determines
|
||||
this.]*/
|
||||
|
||||
#include <type_traits>
|
||||
#include <callable_traits/callable_traits.hpp>
|
||||
|
||||
namespace ct = callable_traits;
|
||||
|
||||
//this is a constexpr function object (non-templated)
|
||||
struct zero {
|
||||
|
||||
constexpr auto operator()() const {
|
||||
return 0;
|
||||
}
|
||||
};
|
||||
|
||||
static_assert(ct::is_constexpr<zero>(), "");
|
||||
static_assert(ct::is_constexpr(zero{}), "");
|
||||
|
||||
|
||||
|
||||
//this is a constexpr function object (templated)
|
||||
struct subtract {
|
||||
|
||||
// For callable_traits::is_constexpr, generic function objects
|
||||
// only need to be SFINAE-friendly if the body of the operator()
|
||||
// function accesses member names besides "type" and "value".
|
||||
// Unary/binary operators and constructor calls are okay to use.
|
||||
template<typename T1, typename T2>
|
||||
constexpr auto operator()(T1, T2) const {
|
||||
return T1{} - T2{};
|
||||
}
|
||||
};
|
||||
|
||||
static_assert(ct::is_constexpr<subtract>(), "");
|
||||
static_assert(ct::is_constexpr(subtract{}), "");
|
||||
|
||||
|
||||
|
||||
//this is NOT a constexpr function object
|
||||
struct add {
|
||||
template<typename T1, typename T2>
|
||||
auto operator()(T1, T2) const {
|
||||
return T1{} + T2{};
|
||||
}
|
||||
};
|
||||
|
||||
static_assert(!ct::is_constexpr<add>(), "");
|
||||
static_assert(!ct::is_constexpr(add{}), "");
|
||||
|
||||
auto multiply = [](auto t1, auto t2) -> decltype(t1.value * t2.value) {
|
||||
return t1.value * t2.value;
|
||||
};
|
||||
|
||||
static_assert(!ct::is_constexpr<decltype(multiply)>(), "");
|
||||
static_assert(!ct::is_constexpr(multiply), "");
|
||||
|
||||
|
||||
// is_constexpr will always return std::false_type when the argument
|
||||
// is either not a literal type, or is not default constructible. Below,
|
||||
// divide is not default constructible, so is_constexpr returns
|
||||
// std::false_type. For literal types that are default constructible, a
|
||||
// constexpr default constructor is assumed.
|
||||
|
||||
struct divide {
|
||||
|
||||
divide() = delete;
|
||||
constexpr divide(int){};
|
||||
|
||||
template<typename T1, typename T2>
|
||||
constexpr auto operator()(T1, T2) const {
|
||||
return T1{} / T2{};
|
||||
}
|
||||
};
|
||||
|
||||
static_assert(!ct::is_constexpr<divide>(), "");
|
||||
static_assert(!ct::is_constexpr(divide{0}), "");
|
||||
|
||||
int main() {}
|
||||
//]
|
||||
Reference in New Issue
Block a user