123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564 |
- // -*- C++ -*-
- //===----------------------------------------------------------------------===//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- #ifndef _LIBCPP_FUNCTIONAL
- #define _LIBCPP_FUNCTIONAL
- /*
- functional synopsis
- namespace std
- {
- template <class Arg, class Result>
- struct unary_function
- {
- typedef Arg argument_type;
- typedef Result result_type;
- };
- template <class Arg1, class Arg2, class Result>
- struct binary_function
- {
- typedef Arg1 first_argument_type;
- typedef Arg2 second_argument_type;
- typedef Result result_type;
- };
- template <class T>
- class reference_wrapper
- : public unary_function<T1, R> // if wrapping a unary functor
- : public binary_function<T1, T2, R> // if wrapping a binary functor
- {
- public:
- // types
- typedef T type;
- typedef see below result_type; // Not always defined
- // construct/copy/destroy
- template<class U>
- constexpr reference_wrapper(U&&); // constexpr since C++20
- constexpr reference_wrapper(const reference_wrapper<T>& x) noexcept; // constexpr since C++20
- // assignment
- constexpr reference_wrapper&
- operator=(const reference_wrapper<T>& x) noexcept; // constexpr since C++20
- // access
- constexpr operator T& () const noexcept; // constexpr since C++20
- constexpr T& get() const noexcept; // constexpr since C++20
- // invoke
- template <class... ArgTypes>
- constexpr typename result_of<T&(ArgTypes&&...)>::type // constexpr since C++20
- operator() (ArgTypes&&...) const
- noexcept(is_nothrow_invocable_v<T&, ArgTypes...>); // noexcept since C++17
- };
- template <class T>
- reference_wrapper(T&) -> reference_wrapper<T>;
- template <class T> reference_wrapper<T> ref(T& t) noexcept;
- template <class T> void ref(const T&& t) = delete;
- template <class T> reference_wrapper<T> ref(reference_wrapper<T>t) noexcept;
- template <class T> reference_wrapper<const T> cref(const T& t) noexcept;
- template <class T> void cref(const T&& t) = delete;
- template <class T> reference_wrapper<const T> cref(reference_wrapper<T> t) noexcept;
- template <class T> struct unwrap_reference; // since C++20
- template <class T> struct unwrap_ref_decay : unwrap_reference<decay_t<T>> { }; // since C++20
- template <class T> using unwrap_reference_t = typename unwrap_reference<T>::type; // since C++20
- template <class T> using unwrap_ref_decay_t = typename unwrap_ref_decay<T>::type; // since C++20
- template <class T> // <class T=void> in C++14
- struct plus {
- T operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct minus {
- T operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct multiplies {
- T operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct divides {
- T operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct modulus {
- T operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct negate {
- T operator()(const T& x) const;
- };
- template <class T> // <class T=void> in C++14
- struct equal_to {
- bool operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct not_equal_to {
- bool operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct greater {
- bool operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct less {
- bool operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct greater_equal {
- bool operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct less_equal {
- bool operator()(const T& x, const T& y) const;
- };
- // [comparisons.three.way], class compare_three_way
- struct compare_three_way;
- template <class T> // <class T=void> in C++14
- struct logical_and {
- bool operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct logical_or {
- bool operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct logical_not {
- bool operator()(const T& x) const;
- };
- template <class T> // <class T=void> in C++14
- struct bit_and {
- T operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct bit_or {
- T operator()(const T& x, const T& y) const;
- };
- template <class T> // <class T=void> in C++14
- struct bit_xor {
- T operator()(const T& x, const T& y) const;
- };
- template <class T=void> // C++14
- struct bit_not {
- T operator()(const T& x) const;
- };
- struct identity; // C++20
- template <class Predicate>
- class unary_negate // deprecated in C++17, removed in C++20
- : public unary_function<typename Predicate::argument_type, bool>
- {
- public:
- explicit unary_negate(const Predicate& pred);
- bool operator()(const typename Predicate::argument_type& x) const;
- };
- template <class Predicate> // deprecated in C++17, removed in C++20
- unary_negate<Predicate> not1(const Predicate& pred);
- template <class Predicate>
- class binary_negate // deprecated in C++17, removed in C++20
- : public binary_function<typename Predicate::first_argument_type,
- typename Predicate::second_argument_type,
- bool>
- {
- public:
- explicit binary_negate(const Predicate& pred);
- bool operator()(const typename Predicate::first_argument_type& x,
- const typename Predicate::second_argument_type& y) const;
- };
- template <class Predicate> // deprecated in C++17, removed in C++20
- binary_negate<Predicate> not2(const Predicate& pred);
- template <class F>
- constexpr unspecified not_fn(F&& f); // C++17, constexpr in C++20
- template<class T> struct is_bind_expression;
- template<class T> struct is_placeholder;
- // See C++14 20.9.9, Function object binders
- template <class T> inline constexpr bool is_bind_expression_v
- = is_bind_expression<T>::value; // C++17
- template <class T> inline constexpr int is_placeholder_v
- = is_placeholder<T>::value; // C++17
- template<class Fn, class... BoundArgs>
- constexpr unspecified bind(Fn&&, BoundArgs&&...); // constexpr in C++20
- template<class R, class Fn, class... BoundArgs>
- constexpr unspecified bind(Fn&&, BoundArgs&&...); // constexpr in C++20
- // [func.invoke]
- template<class F, class... Args>
- constexpr // constexpr in C++20
- invoke_result_t<F, Args...> invoke(F&& f, Args&&... args) // C++17
- noexcept(is_nothrow_invocable_v<F, Args...>);
- template<class R, class F, class... Args>
- constexpr R invoke_r(F&& f, Args&&... args) // C++23
- noexcept(is_nothrow_invocable_r_v<R, F, Args...>);
- namespace placeholders {
- // M is the implementation-defined number of placeholders
- extern unspecified _1;
- extern unspecified _2;
- .
- .
- .
- extern unspecified _Mp;
- }
- template <class Operation>
- class binder1st // deprecated in C++11, removed in C++17
- : public unary_function<typename Operation::second_argument_type,
- typename Operation::result_type>
- {
- protected:
- Operation op;
- typename Operation::first_argument_type value;
- public:
- binder1st(const Operation& x, const typename Operation::first_argument_type y);
- typename Operation::result_type operator()( typename Operation::second_argument_type& x) const;
- typename Operation::result_type operator()(const typename Operation::second_argument_type& x) const;
- };
- template <class Operation, class T>
- binder1st<Operation> bind1st(const Operation& op, const T& x); // deprecated in C++11, removed in C++17
- template <class Operation>
- class binder2nd // deprecated in C++11, removed in C++17
- : public unary_function<typename Operation::first_argument_type,
- typename Operation::result_type>
- {
- protected:
- Operation op;
- typename Operation::second_argument_type value;
- public:
- binder2nd(const Operation& x, const typename Operation::second_argument_type y);
- typename Operation::result_type operator()( typename Operation::first_argument_type& x) const;
- typename Operation::result_type operator()(const typename Operation::first_argument_type& x) const;
- };
- template <class Operation, class T>
- binder2nd<Operation> bind2nd(const Operation& op, const T& x); // deprecated in C++11, removed in C++17
- template <class Arg, class Result> // deprecated in C++11, removed in C++17
- class pointer_to_unary_function : public unary_function<Arg, Result>
- {
- public:
- explicit pointer_to_unary_function(Result (*f)(Arg));
- Result operator()(Arg x) const;
- };
- template <class Arg, class Result>
- pointer_to_unary_function<Arg,Result> ptr_fun(Result (*f)(Arg)); // deprecated in C++11, removed in C++17
- template <class Arg1, class Arg2, class Result> // deprecated in C++11, removed in C++17
- class pointer_to_binary_function : public binary_function<Arg1, Arg2, Result>
- {
- public:
- explicit pointer_to_binary_function(Result (*f)(Arg1, Arg2));
- Result operator()(Arg1 x, Arg2 y) const;
- };
- template <class Arg1, class Arg2, class Result>
- pointer_to_binary_function<Arg1,Arg2,Result> ptr_fun(Result (*f)(Arg1,Arg2)); // deprecated in C++11, removed in C++17
- template<class S, class T> // deprecated in C++11, removed in C++17
- class mem_fun_t : public unary_function<T*, S>
- {
- public:
- explicit mem_fun_t(S (T::*p)());
- S operator()(T* p) const;
- };
- template<class S, class T, class A>
- class mem_fun1_t : public binary_function<T*, A, S> // deprecated in C++11, removed in C++17
- {
- public:
- explicit mem_fun1_t(S (T::*p)(A));
- S operator()(T* p, A x) const;
- };
- template<class S, class T> mem_fun_t<S,T> mem_fun(S (T::*f)()); // deprecated in C++11, removed in C++17
- template<class S, class T, class A> mem_fun1_t<S,T,A> mem_fun(S (T::*f)(A)); // deprecated in C++11, removed in C++17
- template<class S, class T>
- class mem_fun_ref_t : public unary_function<T, S> // deprecated in C++11, removed in C++17
- {
- public:
- explicit mem_fun_ref_t(S (T::*p)());
- S operator()(T& p) const;
- };
- template<class S, class T, class A>
- class mem_fun1_ref_t : public binary_function<T, A, S> // deprecated in C++11, removed in C++17
- {
- public:
- explicit mem_fun1_ref_t(S (T::*p)(A));
- S operator()(T& p, A x) const;
- };
- template<class S, class T>
- mem_fun_ref_t<S,T> mem_fun_ref(S (T::*f)()); // deprecated in C++11, removed in C++17
- template<class S, class T, class A>
- mem_fun1_ref_t<S,T,A> mem_fun_ref(S (T::*f)(A)); // deprecated in C++11, removed in C++17
- template <class S, class T>
- class const_mem_fun_t : public unary_function<const T*, S> // deprecated in C++11, removed in C++17
- {
- public:
- explicit const_mem_fun_t(S (T::*p)() const);
- S operator()(const T* p) const;
- };
- template <class S, class T, class A>
- class const_mem_fun1_t : public binary_function<const T*, A, S> // deprecated in C++11, removed in C++17
- {
- public:
- explicit const_mem_fun1_t(S (T::*p)(A) const);
- S operator()(const T* p, A x) const;
- };
- template <class S, class T>
- const_mem_fun_t<S,T> mem_fun(S (T::*f)() const); // deprecated in C++11, removed in C++17
- template <class S, class T, class A>
- const_mem_fun1_t<S,T,A> mem_fun(S (T::*f)(A) const); // deprecated in C++11, removed in C++17
- template <class S, class T>
- class const_mem_fun_ref_t : public unary_function<T, S> // deprecated in C++11, removed in C++17
- {
- public:
- explicit const_mem_fun_ref_t(S (T::*p)() const);
- S operator()(const T& p) const;
- };
- template <class S, class T, class A>
- class const_mem_fun1_ref_t : public binary_function<T, A, S> // deprecated in C++11, removed in C++17
- {
- public:
- explicit const_mem_fun1_ref_t(S (T::*p)(A) const);
- S operator()(const T& p, A x) const;
- };
- template <class S, class T>
- const_mem_fun_ref_t<S,T> mem_fun_ref(S (T::*f)() const); // deprecated in C++11, removed in C++17
- template <class S, class T, class A>
- const_mem_fun1_ref_t<S,T,A> mem_fun_ref(S (T::*f)(A) const); // deprecated in C++11, removed in C++17
- template<class R, class T> constexpr unspecified mem_fn(R T::*); // constexpr in C++20
- class bad_function_call
- : public exception
- {
- };
- template<class> class function; // undefined
- template<class R, class... ArgTypes>
- class function<R(ArgTypes...)>
- : public unary_function<T1, R> // iff sizeof...(ArgTypes) == 1 and
- // ArgTypes contains T1
- : public binary_function<T1, T2, R> // iff sizeof...(ArgTypes) == 2 and
- // ArgTypes contains T1 and T2
- {
- public:
- typedef R result_type;
- // construct/copy/destroy:
- function() noexcept;
- function(nullptr_t) noexcept;
- function(const function&);
- function(function&&) noexcept;
- template<class F>
- function(F);
- template<Allocator Alloc>
- function(allocator_arg_t, const Alloc&) noexcept; // removed in C++17
- template<Allocator Alloc>
- function(allocator_arg_t, const Alloc&, nullptr_t) noexcept; // removed in C++17
- template<Allocator Alloc>
- function(allocator_arg_t, const Alloc&, const function&); // removed in C++17
- template<Allocator Alloc>
- function(allocator_arg_t, const Alloc&, function&&); // removed in C++17
- template<class F, Allocator Alloc>
- function(allocator_arg_t, const Alloc&, F); // removed in C++17
- function& operator=(const function&);
- function& operator=(function&&) noexcept;
- function& operator=(nullptr_t) noexcept;
- template<class F>
- function& operator=(F&&);
- template<class F>
- function& operator=(reference_wrapper<F>) noexcept;
- ~function();
- // function modifiers:
- void swap(function&) noexcept;
- template<class F, class Alloc>
- void assign(F&&, const Alloc&); // Removed in C++17
- // function capacity:
- explicit operator bool() const noexcept;
- // function invocation:
- R operator()(ArgTypes...) const;
- // function target access:
- const std::type_info& target_type() const noexcept;
- template <typename T> T* target() noexcept;
- template <typename T> const T* target() const noexcept;
- };
- // Deduction guides
- template<class R, class ...Args>
- function(R(*)(Args...)) -> function<R(Args...)>; // since C++17
- template<class F>
- function(F) -> function<see-below>; // since C++17
- // Null pointer comparisons:
- template <class R, class ... ArgTypes>
- bool operator==(const function<R(ArgTypes...)>&, nullptr_t) noexcept;
- template <class R, class ... ArgTypes>
- bool operator==(nullptr_t, const function<R(ArgTypes...)>&) noexcept; // removed in C++20
- template <class R, class ... ArgTypes>
- bool operator!=(const function<R(ArgTypes...)>&, nullptr_t) noexcept; // removed in C++20
- template <class R, class ... ArgTypes>
- bool operator!=(nullptr_t, const function<R(ArgTypes...)>&) noexcept; // removed in C++20
- // specialized algorithms:
- template <class R, class ... ArgTypes>
- void swap(function<R(ArgTypes...)>&, function<R(ArgTypes...)>&) noexcept;
- template <class T> struct hash;
- template <> struct hash<bool>;
- template <> struct hash<char>;
- template <> struct hash<signed char>;
- template <> struct hash<unsigned char>;
- template <> struct hash<char8_t>; // since C++20
- template <> struct hash<char16_t>;
- template <> struct hash<char32_t>;
- template <> struct hash<wchar_t>;
- template <> struct hash<short>;
- template <> struct hash<unsigned short>;
- template <> struct hash<int>;
- template <> struct hash<unsigned int>;
- template <> struct hash<long>;
- template <> struct hash<long long>;
- template <> struct hash<unsigned long>;
- template <> struct hash<unsigned long long>;
- template <> struct hash<float>;
- template <> struct hash<double>;
- template <> struct hash<long double>;
- template<class T> struct hash<T*>;
- template <> struct hash<nullptr_t>; // C++17
- namespace ranges {
- // [range.cmp], concept-constrained comparisons
- struct equal_to;
- struct not_equal_to;
- struct greater;
- struct less;
- struct greater_equal;
- struct less_equal;
- }
- } // std
- POLICY: For non-variadic implementations, the number of arguments is limited
- to 3. It is hoped that the need for non-variadic implementations
- will be minimal.
- */
- #include <__algorithm/search.h>
- #include <__compare/compare_three_way.h>
- #include <__config>
- #include <__functional/binary_function.h>
- #include <__functional/binary_negate.h>
- #include <__functional/bind.h>
- #include <__functional/bind_back.h>
- #include <__functional/bind_front.h>
- #include <__functional/binder1st.h>
- #include <__functional/binder2nd.h>
- #include <__functional/boyer_moore_searcher.h>
- #include <__functional/compose.h>
- #include <__functional/default_searcher.h>
- #include <__functional/function.h>
- #include <__functional/hash.h>
- #include <__functional/identity.h>
- #include <__functional/invoke.h>
- #include <__functional/mem_fn.h> // TODO: deprecate
- #include <__functional/mem_fun_ref.h>
- #include <__functional/not_fn.h>
- #include <__functional/operations.h>
- #include <__functional/pointer_to_binary_function.h>
- #include <__functional/pointer_to_unary_function.h>
- #include <__functional/ranges_operations.h>
- #include <__functional/reference_wrapper.h>
- #include <__functional/unary_function.h>
- #include <__functional/unary_negate.h>
- #include <__type_traits/unwrap_ref.h>
- #include <__utility/forward.h>
- #include <version>
- #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
- # pragma GCC system_header
- #endif
- #if !defined(_LIBCPP_REMOVE_TRANSITIVE_INCLUDES) && _LIBCPP_STD_VER <= 20
- # include <atomic>
- # include <concepts>
- # include <cstdlib>
- # include <exception>
- # include <iosfwd>
- # include <memory>
- # include <stdexcept>
- # include <tuple>
- # include <type_traits>
- # include <typeinfo>
- # include <utility>
- #endif
- #endif // _LIBCPP_FUNCTIONAL
|