std::not_fn - cppreference.com (original) (raw)
Creates a forwarding call wrapper that returns the negation of the callable object it holds.
Creates a forwarding call wrapper that returns the negation of the statically determined callable target. The program is ill-formed if
ConstFnis a null pointer or null pointer-to-member.
Contents
[edit] Parameters
| f | - | the object from which the Callable object held by the wrapper is constructed |
|---|---|---|
| Type requirements | ||
| -std::decay_t<F> must meet the requirements of Callable and MoveConstructible. | ||
| -std::is_constructible_v<std::decay_t<F>, F> is required to be true. |
[edit] Return value
A function object of unspecified type
T. It has the following members.A value of the following type.
std::not_fn stateless return type
The return type is a CopyConstructible stateless class. It is unspecified whether the return type is assignable.
Member function operator()
| template< class... Args > constexpr auto operator()( Args&&... args ) const noexcept(/* see below */) -> decltype((ConstFn, std::declval<Args>()...)); | | (since C++26) |
| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | ------------- |
Expression-equivalent to (ConstFn, std::forward<Args>(args)...).
[edit] Exceptions
- Throws no exceptions, unless the construction of fd throws.
[edit] Possible implementation
| (1) not_fn |
|---|
| namespace detail { template<class V, class F, class... Args> constexpr bool negate_invocable_impl = false; template<class F, class... Args> constexpr bool negate_invocable_impl<std::void_t<decltype( |
| (2) not_fn |
| namespace detail { template<auto ConstFn> struct stateless_not_fn { template<class... Args> constexpr auto operator()(Args&&... args) const noexcept(noexcept( |
[edit] Notes
std::not_fn is intended to replace the C++03-era negators std::not1 and std::not2.
| Feature-test macro | Value | Std | Feature |
|---|---|---|---|
| __cpp_lib_not_fn | 201603L | (C++17) | std::not_fn(), (1) |
| 202306L | (C++26) | Allow passing callable objects as constant template arguments to std::not_fn, (2) |
[edit] Example
#include #include bool is_same(int a, int b) noexcept { return a == b; } struct S { int val; bool is_same(int arg) const noexcept { return val == arg; } }; int main() { // Using with a free function: auto is_differ = std::not_fn(is_same); assert(is_differ(8, 8) == false); // equivalent to: !is_same(8, 8) == false assert(is_differ(6, 9) == true); // equivalent to: !is_same(8, 0) == true // Using with a member function: auto member_differ = std::not_fn(&S::is_same); assert(member_differ(S{3}, 3) == false); //: S tmp{6}; !tmp.is_same(6) == false // Noexcept-specification is preserved: static_assert(noexcept(is_differ) == noexcept(is_same)); static_assert(noexcept(member_differ) == noexcept(&S::is_same)); // Using with a function object: auto same = [](int a, int b) { return a == b; }; auto differ = std::not_fn(same); assert(differ(1, 2) == true); //: !same(1, 2) == true assert(differ(2, 2) == false); //: !same(2, 2) == false #if __cpp_lib_not_fn >= 202306L auto is_differ_cpp26 = std::not_fn(); assert(is_differ_cpp26(8, 8) == false); assert(is_differ_cpp26(6, 9) == true); auto member_differ_cpp26 = std::not_fn<&S::is_same>(); assert(member_differ_cpp26(S{3}, 3) == false); auto differ_cpp26 = std::not_fn(); static_assert(differ_cpp26(1, 2) == true); static_assert(differ_cpp26(2, 2) == false); #endif }