std::not_fn (3) - Linux Manuals
std::not_fn: std::not_fn
NAME
Synopsis
Defined in header <functional>
template< class F> (since C++17)
/*unspecified*/ not_fn( F&& f );
Creates a forwarding call wrapper that returns the negation of the callable object it holds.
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
Return value
A function object of unspecified type T. It has the following members:
std::not_fn return type
Member objects
The return type of std::not_fn holds a member object of type std::decay_t<F>.
Constructors
explicit T(F&& f); (1)
T(T&& f) = default; (2)
T(const T& f) = default;
1) The constructor initializes the member object (of type std::decay_t<F>) from std::forward<F>(f). Throws any exception thrown by the constructor selected
2) Because std::decay_t<F> is required to be MoveConstructible, the returned call wrapper is always MoveConstructible, and is CopyConstructible if std::decay_t<F> is CopyConstructible.
Member function operator()
template<class... Args> auto operator()(Args&&... args) &
-> decltype(!std::declval<std::invoke_result_t<std::decay_t<F>&, Args...>>()); (1)
template<class... Args> auto operator()(Args&&... args) const&
-> decltype(!std::declval<std::invoke_result_t<std::decay_t<F> const&, Args...>>());
template<class... Args> auto operator()(Args&&... args) &&
-> decltype(!std::declval<std::invoke_result_t<std::decay_t<F>, Args...>>()); (2)
template<class... Args> auto operator()(Args&&... args) const&&
-> decltype(!std::declval<std::invoke_result_t<std::decay_t<F> const, Args...>>());
1) Equivalent to return !std::invoke(fd, std::forward<Args>(args)...)
2) Equivalent to return !std::invoke(std::move(fd), std::forward<Args>(args)...)
where fd is the member object of type std::decay_t<F>
Exceptions
Throws no exceptions, unless the construction of fd throws.
Notes
not_fn is intended to replace the C++03-era negators std::not1 and std::not2.
See also
not1 constructs custom std::unary_negate object
(deprecated in C++17)
(removed in C++20)
not2 constructs custom std::binary_negate object
(deprecated in C++17)
(removed in C++20)