mirror of
https://github.com/gcc-mirror/gcc.git
synced 2026-05-06 23:25:24 +02:00
libstdc++-v3/ChangeLog:
* libsupc++/typeinfo: Switch to bits/version.h for
__cpp_lib_constexpr_typeinfo.
* libsupc++/new: Switch to bits/version.h for
__cpp_lib_{launder,hardware_interference_size,destroying_delete}.
(launder): Guard behind __cpp_lib_launder.
(hardware_destructive_interference_size)
(hardware_constructive_interference_size): Guard behind
__cpp_lib_hardware_interference_size.
* libsupc++/exception: Switch to bits/version.h for
__cpp_lib_uncaught_exceptions.
(uncaught_exceptions): Guard behind __cpp_lib_uncaught_exceptions.
* libsupc++/compare: Switch to bits/version.h for
__cpp_lib_three_way_comparison.
(three_way_comparable, three_way_comparable_with)
(compare_three_way, weak_order, strong_order, partial_order):
Guard behind __cpp_lib_three_way_comparison >= 201907L.
* include/std/chrono: Drop __cpp_lib_chrono definition.
* include/std/vector: Switch to bits/version.h for
__cpp_lib_erase_if.
(erase, erase_if): Guard behind __cpp_lib_erase_if.
* include/std/variant: Switch to bits/version.h for
__cpp_lib_variant. Guard whole header behind that FTM.
* include/std/utility: Switch to bits/version.h for
__cpp_lib_{exchange_function,constexpr_algorithms,as_const},
__cpp_lib_{integer_comparison_functions,to_underlying}, and
__cpp_lib_unreachable.
(exchange): Guard behind __cpp_lib_exchange_function.
(cmp_equal, cmp_not_equal, cmp_less, cmp_greater, cmp_less_equal)
(cmp_greater_equal, in_range): Guard behind
__cpp_lib_integer_comparison_functions.
(to_underlying): Guard behind __cpp_lib_to_underlying.
(unreachable): Guard behind __cpp_lib_unreachable.
* include/std/type_traits: Switch to bits/version.h for
__cpp_lib_is_{null_pointer,final,nothrow_convertible,aggregate},
__cpp_lib_is_{constant_evaluated,invocable,layout_compatible},
__cpp_lib_is_{pointer_interconvertible,scoped_enum,swappable},
__cpp_lib_{logical_traits,reference_from_temporary,remove_cvref},
__cpp_lib_{result_of_sfinae,transformation_trait_aliases},
__cpp_lib_{type_identity,type_trait_variable_templates},
__cpp_lib_{unwrap_ref,void_t,integral_constant_callable},
__cpp_lib_{bool_constant,bounded_array_traits}, and
__cpp_lib_has_unique_object_representations.
(integral_constant::operator()): Guard behind
__cpp_lib_integral_constant_callable.
(bool_constant): Guard behind __cpp_lib_bool_constant.
(conjunction, disjunction, negation, conjunction_v, disjunction_v)
(negation_v): Guard behind __cpp_lib_logical_traits.
(is_null_pointer): Guard behind __cpp_lib_is_null_pointer.
(is_final): Guard behind __cpp_lib_is_final.
(is_nothrow_convertible, is_nothrow_convertible_v): Guard behind
__cpp_lib_is_nothrow_convertible.
(remove_const_t, remove_volatile_t, remove_cv_t)
(add_const_t, add_volatile_t, add_cv_t): Guard behind
__cpp_lib_transformation_trait_aliases.
(void_t): Guard behind __cpp_lib_void_t.
(is_swappable_with_v, is_nothrow_swappable_with_v)
(is_swappable_with, is_nothrow_swappable_with): Guard behind
__cpp_lib_is_swappable.
(is_nothrow_invocable_r, is_invocable_r, invoke_result)
(is_invocable, invoke_result_t): Guard behind
__cpp_lib_is_invocable.
(alignment_of_v, extent_v, has_virtual_destructor_v)
(is_abstract_v, is_arithmetic_v, is_array_v)
(is_assignable_v, is_base_of_v, is_class_v, is_compound_v)
(is_constructible_v, is_const_v, is_convertible_v)
(is_copy_assignable_v, is_copy_constructible_v)
(is_default_constructible_v, is_destructible_v)
(is_empty_v, is_enum_v, is_final_v, is_floating_point_v)
(is_function_v, is_fundamental_v, is_integral_v)
(is_invocable_r_v, is_invocable_v, is_literal_type_v)
(is_lvalue_reference_v, is_member_function_pointer_v)
(is_member_object_pointer_v, is_member_pointer_v)
(is_move_assignable_v, is_move_constructible_v)
(is_nothrow_assignable_v, is_nothrow_constructible_v)
(is_nothrow_copy_assignable_v, is_nothrow_copy_constructible_v)
(is_nothrow_default_constructible_v, is_nothrow_destructible_v)
(is_nothrow_invocable_r_v, is_nothrow_invocable_v)
(is_nothrow_move_assignable_v, is_nothrow_move_constructible_v)
(is_null_pointer_v, is_object_v, is_pod_v, is_pointer_v)
(is_polymorphic_v, is_reference_v, is_rvalue_reference_v)
(is_same_v, is_scalar_v, is_signed_v, is_standard_layout_v)
(is_trivially_assignable_v, is_trivially_constructible_v)
(is_trivially_copyable_v, is_trivially_copy_assignable_v)
(is_trivially_copy_constructible_v)
(is_trivially_default_constructible_v)
(is_trivially_destructible_v, is_trivially_move_assignable_v)
(is_trivially_move_constructible_v, is_trivial_v, is_union_v)
(is_unsigned_v, is_void_v, is_volatile_v, rank_v, as variadic):
Guard behind __cpp_lib_type_trait_variable_templates.
(has_unique_object_representations)
(has_unique_object_representations_v): Guard behind
__cpp_lib_has_unique_object_representation.
(is_aggregate): Guard behind __cpp_lib_is_aggregate.
(remove_cvref, remove_cvref_t): Guard behind
__cpp_lib_remove_cvref.
(type_identity, type_identity_t): Guard behind
__cpp_lib_type_identity.
(unwrap_reference, unwrap_reference_t, unwrap_ref_decay)
(unwrap_ref_decay_t): Guard behind __cpp_lib_unwrap_ref.
(is_bounded_array_v, is_unbounded_array_v, is_bounded_array)
(is_unbounded_array): Guard behind __cpp_lib_bounded_array_traits.
(is_scoped_enum, is_scoped_enum_v): Guard behind
__cpp_lib_is_scoped_enum.
(reference_constructs_from_temporary)
(reference_constructs_from_temporary_v): Guard behind
__cpp_lib_reference_from_temporary.
* include/std/tuple: Switch to bits/version.h for
__cpp_lib_{constexpr_tuple,tuple_by_type,apply_make_from_tuple}.
(get<T>): Guard behind __cpp_lib_tuple_by_type.
(apply): Guard behind __cpp_lib_apply.
(make_from_tuple): Guard behind __cpp_lib_make_from_tuple.
* include/std/syncstream: Switch to bits/version.h for
__cpp_lib_syncbuf. Guard header behind that FTM.
* include/std/string_view: Switch to bits/version.h for
__cpp_lib_{string_{view,contains},constexpr_string_view} and
__cpp_lib_starts_ends_with.
(basic_string_view::starts_with, basic_string_view::ends_with):
Guard behind __cpp_lib_starts_ends_with.
[C++23 && _GLIBCXX_HOSTED && !defined(__cpp_lib_string_contains)]:
Assert as impossible ithout a bug in C++23.
* include/std/string: Switch to bits/version.h for
__cpp_lib_erase_if.
(erase, erase_if): Guard behind __cpp_lib_erase_if.
* include/std/thread: Switch to bits/version.h for
__cpp_lib_jthread.
* include/std/stop_token: Switch to bits/version.h for
__cpp_lib_jthread.
* include/std/spanstream: Switch to bits/version.h for
__cpp_lib_spanstream. Guard header behind that FTM.
* include/std/span: Switch to bits/version.h for __cpp_lib_span.
Guard header behind that FTM.
* include/std/source_location: Switch to bits/version.h for
__cpp_lib_source_location. Guard header with that FTM.
* include/std/shared_mutex: Switch to bits/version.h for
__cpp_lib_shared{,_timed}_mutex.
(shared_mutex): Guard behind __cpp_lib_shared_mutex.
* include/std/semaphore: Switch to bits/version.h for
__cpp_lib_semaphore. Guard header behind that FTM.
* include/std/ranges: Switch to bits/version.h for
__cpp_lib_ranges_{zip,chunk{,_by},slide,join_with},
__cpp_lib_ranges_{repeat_stride,cartesian_product,as_rvalue},
and __cpp_lib_ranges_{as_const,enumerate,iota}.
(ranges::zip et al, ranges::chunk et al, ranges::slide et al)
(ranges::chunk_by et al, ranges::join_with et al)
(ranges::stride et al, ranges::cartesian_product et al)
(ranges::as_rvalue et al, ranges::as_const et al)
(ranges::enumerate et al): Guard behind appropriate FTM.
* include/std/optional: Switch to bits/version.h for
__cpp_lib_optional. Guard header behind that FTM.
* include/std/numeric: Switch to bits/version.h for
__cpp_lib_{gcd{,_lcm},lcm,constexpr_numeric,interpolate}
and __cpp_lib_parallel_algorithm.
(gcd, lcm): Guard behind __cpp_lib_gcd_lcm.
(midpoint): Guard behind __cpp_lib_interpolate.
* include/std/numbers: Switch to bits/version.h for
__cpp_lib_math_constants. Guard header behind that FTM.
* include/std/mutex: Switch to bits/version.h for
__cpp_lib_scoped_lock.
(scoped_Lock): Guard behind __cpp_lib_scoped_lock.
* include/std/memory_resource: Switch to bits/version.h for
__cpp_lib_{polymorphic_allocator,memory_resource}.
(synchronized_pool_resource): Guard behind
__cpp_lib_memory_resource >= 201603L.
(polymorphic_allocator): Guard behind
__cpp_lib_polymorphic_allocator.
* include/std/memory: Switch to bits/version.h for
__cpp_lib_{parallel_algorithm,atomic_value_initialization}.
* include/std/list: Switch to bits/version.h for
__cpp_lib_erase_if.
(erase, erase_if): Guard behind __cpp_lib_erase_if.
* include/std/latch: Switch to bits/version.h for __cpp_lib_latch.
Guard header behind that FTM.
* include/std/iterator: Switch to bits/version.h for
__cpp_lib_null_iterators.
* include/std/iomanip: Switch to bits/version.h for
__cpp_lib_quoted_string_io.
(quoted): Guard behind __cpp_lib_quoted_string_io.
* include/std/functional: Switch to bits/version.h for
__cpp_lib_{invoke{,_r},constexpr_functional,bind_front} and
__cpp_lib_{not_fn,booyer_moore_searcher}.
(invoke): Guard behind __cpp_lib_invoke.
(invoke_r): Guard behind __cpp_lib_invoke_r.
(bind_front): Guard behind __cpp_lib_bind_front.
(not_fn): Guard behind __cpp_lib_not_fn.
(boyer_moore_searcher, boyer_moore_horspool_searcher): Guard
definition behind __cpp_lib_boyer_moore_searcher.
* include/std/forward_list: Switch to bits/version.h for
__cpp_lib_erase_if.
(erase, erase_if): Guard behind __cpp_lib_erase_if.
* include/std/format: Switch to bits/version.h for
__cpp_lib_format. Guard header behind that FTM.
* include/std/filesystem: Switch to bits/version.h for
__cpp_lib_filesystem. Guard header behind that FTM.
* include/std/expected: Switch to bits/version.h for
__cpp_lib_expected. Guard header behind it.
* include/std/execution: Switch to bits/version.h for
__cpp_lib_{execution,parallel_algorithm}. Guard header behind
either.
* include/std/deque: Switch to bits/version.h for
__cpp_lib_erase_if.
(erase, erase_if): Guard behind __cpp_lib_erase_if.
* include/std/coroutine: Switch to bits/version.h for
__cpp_lib_coroutine. Guard header behind that FTM.
* include/std/concepts: Switch to bits/version.h for
__cpp_lib_concepts. Guard header behind that FTM.
* include/std/complex: Switch to bits/version.h for
__cpp_lib_{complex_udls,constexpr_complex}.
(operator""if, operator""i, operator""il): Guard behind
__cpp_lib_complex_udls.
* include/std/charconv: Swtich to bits/version.h for
__cpp_lib_{to_chars,constexpr_charconv}.
* include/std/bitset: Switch to bits/version.h for
__cpp_lib_constexpr_bitset.
* include/std/bit: Switch to bits/version.h for
__cpp_lib_{bit_cast,byteswap,bitops,int_pow2,endian}.
(bit_cast): Guard behind __cpp_lib_bit_cast.
(byteswap): Guard behind __cpp_lib_byteswap.
(rotl, rotr, countl_zero, countl_one, countr_zero, countr_one)
(popcount): Guard behind __cpp_lib_bitops.
(has_single_bit, bit_ceil, bit_floor, bit_width): Guard behind
__cpp_lib_int_pow2.
(endian): Guard behind __cpp_lib_endian.
* include/std/barrier: Switch to bits/version.h for
__cpp_lib_barrier. Guard header behind that FTM.
* include/std/atomic: Switch to bits/version.h for
__cpp_lib_atomic_{is_always_lock_free,float,ref}
and __cpp_lib_lock_free_type_aliases.
(*::is_always_lock_free): Guard behind
__cpp_lib_atomic_is_always_lock_free.
(atomic<float>): Guard behind __cpp_lib_atomic_float.
(atomic_ref): Guard behind __cpp_lib_atomic_ref.
(atomic_signed_lock_free, atomic_unsigned_lock_free): Guard behind
__cpp_lib_atomic_lock_free_type_aliases.
* include/std/array: Switch to bits/version.h for
__cpp_lib_to_array.
(to_array): Guard behind __cpp_lib_to_array.
* include/std/any: Switch to bits/version.h for __cpp_lib_any.
Guard header behind that FTM.
* include/std/algorithm: Switch to bits/version.h for
__cpp_lib_parallel_algorithm.
* include/c_global/cstddef: Switch to bits/version.h for
__cpp_lib_byte.
(byte): Guard behind __cpp_lib_byte.
* include/c_global/cmath: Switch to bits/version.h for
__cpp_lib_{hypot,interpolate}.
(hypot3): Guard behind __cpp_lib_hypot.
(lerp): Guard behind __cpp_lib_interpolate.
* include/c_compatibility/stdatomic.h: Switch to
bits/stl_version.h for __cpp_lib_atomic. Guard header behind that
FTM.
* include/bits/utility.h: Switch to bits/version.h for
__cpp_lib_{tuple_element_t,integer_sequence,ranges_zip}.
(tuple_element_t): Guard behind __cpp_lib_tuple_element_t.
(integer_sequence et al): Guard behind __cpp_lib_integer_sequence.
* include/bits/uses_allocator_args.h: Switch to bits/version.h for
__cpp_lib_make_obj_using_allocator. Guard header behind that FTM.
* include/bits/unordered_map.h: Switch to bits/version.h for
__cpp_lib_unordered_map_try_emplace.
(try_emplace): Guard behind __cpp_lib_unordered_map_try_emplace.
* include/bits/unique_ptr.h: Switch to bits/version.h for
__cpp_lib_{constexpr_memory,make_unique}.
(make_unique): Guard behind __cpp_lib_make_unique.
* include/bits/stl_vector.h: Switch to bits/version.h for
__cpp_lib_constexpr_vector.
* include/bits/stl_uninitialized.h: Switch to bits/version.h for
__cpp_lib_raw_memory_algorithms.
(uninitialized_default_construct)
(uninitialized_default_construct_n, uninitialized_move)
(uninitialized_move_n, uninitialized_value_construct)
(uninitialized_value_construct_n): Guard behind
__cpp_lib_raw_memory_algorithms.
* include/bits/stl_tree.h: Switch to bits/version.h for
__cpp_lib_generic_associative_lookup.
* include/bits/stl_stack.h: Switch to bits/version.h for
__cpp_lib_adaptor_iterator_pair_constructor.
(stack): Guard iterator-pair constructor behind
__cpp_lib_adaptor_iterator_pair_constructor.
* include/bits/stl_queue.h: Switch to bits/version.h for
__cpp_lib_adaptor_iterator_pair_constructor.
(queue): Guard iterator-pair constructor behind
__cpp_lib_adaptor_iterator_pair_constructor.
* include/bits/stl_pair.h: Switch to bits/version.h for
__cpp_lib_{concepts,tuples_by_type}.
(get): Guard type-getting overloads behind
__cpp_lib_tuples_by_type.
* include/bits/stl_map.h: Switch to bits/version.h for
__cpp_lib_map_try_emplace.
(map<>::try_emplace): Guard behind __cpp_lib_map_try_emplace.
* include/bits/stl_list.h: Switch to bits/version.h for
__cpp_lib_list_remove_return_type.
(__remove_return_type, _GLIBCXX_LIST_REMOVE_RETURN_TYPE_TAG)
[C++20]: guard behind __cpp_lib_list_remove_return_type instead.
* include/bits/stl_iterator.h: Switch to bits/version.h for
__cpp_lib_{constexpr_iterator,array_constexpr} and
__cpp_lib_{make_reverse_iterator,move_iterator_concept}.
(make_reverse_iterator): Guard behind
__cpp_lib_make_reverse_iterator.
(iterator_concept et al): Guard __cpp_lib_move_iterator_concept
changes behind that FTM.
* include/bits/stl_function.h: Switch to bits/version.h for
__cpp_lib_transparent_operators.
(equal_to, not_equal_to, greater, less, greater_equal)
(less_equal, bit_and, bit_or, bit_xor, bit_not, logical_and)
(logical_or, logical_not, plus, minus, multiplies, divides)
(modulus, negate): Guard '= void' fwdecls behind
__cpp_lib_transparent_operators.
(plus<void>, minus<void>, multiplies<void>, divides<void>)
(modulus<void>, negate<void>, logical_and<void>, logical_or<void>)
(logical_not<void>, bit_and<void>, bit_or<void>, bit_xor<void>)
(equal_to<void>, not_equal_to<void>, greater<void>, less<void>)
(greater_equal<void>, less_equal<void>, bit_not<void>)
(__has_is_transparent): Guard behind
__cpp_lib_transparent_operators.
* include/bits/stl_algobase.h: Switch to bits/version.h for
__cpp_lib_robust_nonmodifying_seq_ops.
(robust equal, mismatch): Guard behind
__cpp_lib_nonmember_container_access.
* include/bits/stl_algo.h: Swtich to bits/version.h for
__cpp_lib_{clamp,sample}.
(clamp): Guard behind __cpp_lib_clamp.
(sample): Guard behind __cpp_lib_sample.
* include/bits/specfun.h: Switch to bits/version.h for
__cpp_lib_math_special_functions and __STDCPP_MATH_SPEC_FUNCS__.
* include/bits/shared_ptr_base.h: Switch to bits/version.h for
__cpp_lib_{smart_ptr_for_overwrite,shared_ptr_arrays}.
(_Sp_overwrite_tag): Guard behind
__cpp_lib_smart_ptr_for_overwrite.
* include/bits/shared_ptr_atomic.h: Switch to bits/version.h for
__cpp_lib_atomic_shared_ptr.
* include/bits/shared_ptr.h: Switch to bits/version.h for
__cpp_lib_{enable_shared_from_this,shared_ptr_weak_type}.
(shared_ptr<T>::weak_type): Guard behind
__cpp_lib_shared_ptr_weak_type.
(enable_shared_from_this<T>::weak_from_this): Guard behind
__cpp_lib_enable_shared_from_this.
* include/bits/ranges_cmp.h: Switch to bits/version.h for
__cpp_lib_ranges.
* include/bits/ranges_algo.h: Switch to bits/version.h for
__cpp_lib_{shift,ranges_{contains,find_last,fold,iota}}.
* include/bits/range_access.h: Switch to bits/version.h for
__cpp_lib_nonmember_container_access
(size, empty, data): Guard behind
__cpp_lib_nonmember_container_access.
(ssize): Guard behind __cpp_lib_ssize.
* include/bits/ptr_traits.h: Switch to bits/version.h. for
__cpp_lib_{constexpr_memory,to_address}.
(to_address): Guard behind __cpp_lib_to_address.
* include/bits/node_handle.h: Switch to bits/version.h for
__cpp_lib_node_extract. Guard header behind that FTM.
* include/bits/move_only_function.h: Switch to bits/version.h for
__cpp_lib_move_only_function. Guard header behind that FTM.
* include/bits/move.h: Switch to bits/version.h for
__cpp_lib_addressof_constexpr.
* include/bits/ios_base.h: Switch to bits/version.h for
__cpp_lib_ios_noreplace.
(noreplace): Guard with __cpp_lib_ios_noreplace.
* include/bits/hashtable.h: Switch to bits/version.h for
__cpp_lib_generic_unordered_lookup.
(_M_equal_range_tr, _M_count_tr, _M_find_tr): Guard behind
__cpp_lib_generic_unordered_lookup.
* include/bits/forward_list.h: Switch to bits/version.h for
__cpp_lib_list_remove_return_type.
(__remove_return_type): Guard behind
__cpp_lib_list_remove_return_type.
* include/bits/erase_if.h: Switch to bits/version.h for
__cpp_lib_erase_if.
* include/bits/cow_string.h: Switch to bits/version.h for
__cpp_lib_constexpr_string.
* include/bits/chrono.h: Swtich to bits/version.h for
__cpp_lib_chrono{,_udls}.
(ceil): Guard behind __cpp_lib_chrono.
(operator""ns et al): Guard behind __cpp_lib_chrono_udls.
* include/bits/char_traits.h: Switch to bits/version.h for
__cpp_lib_constexpr_char_traits.
* include/bits/basic_string.h: Switch to bits/version.h for
__cpp_lib_{constexpr_string,string_{resize_and_overwrite,udls}}.
(resize_and_overwrite): Guard behind
__cpp_lib_string_resize_and_overwrite.
(operator""s): Guard behind __cpp_lib_string_udls.
* include/bits/atomic_wait.h: Switch to bits/version.h for
__cpp_lib_atomic_wait. Guard header behind that FTM.
* include/bits/atomic_base.h: Switch to bits/version.h for
__cpp_lib_atomic_value_initialization and
__cpp_lib_atomic_flag_test.
(atomic_flag::test): Guard behind __cpp_lib_atomic_flag_test,
rather than C++20.
* include/bits/allocator.h: Switch to bits/version.h for
__cpp_lib_incomplete_container_elements.
* include/bits/alloc_traits.h: Switch to using bits/version.h for
__cpp_lib_constexpr_dynamic_alloc and
__cpp_lib_allocator_traits_is_always_equal.
* include/bits/align.h: Switch to bits/version.h for defining
__cpp_lib_assume_aligned.
(assume_aligned): Guard with __cpp_lib_assume_aligned.
* include/bits/algorithmfwd.h: Switch to bits/version.h for
defining __cpp_lib_constexpr_algorithms.
* include/std/stacktrace: Switch to bits/version.h for
__cpp_lib_stacktrace. Guard header behind that FTM.
* testsuite/23_containers/array/tuple_interface/get_neg.cc:
Update line numbers.
1442 lines
44 KiB
C++
1442 lines
44 KiB
C++
// Functor implementations -*- C++ -*-
|
|
|
|
// Copyright (C) 2001-2023 Free Software Foundation, Inc.
|
|
//
|
|
// This file is part of the GNU ISO C++ Library. This library is free
|
|
// software; you can redistribute it and/or modify it under the
|
|
// terms of the GNU General Public License as published by the
|
|
// Free Software Foundation; either version 3, or (at your option)
|
|
// any later version.
|
|
|
|
// This library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// Under Section 7 of GPL version 3, you are granted additional
|
|
// permissions described in the GCC Runtime Library Exception, version
|
|
// 3.1, as published by the Free Software Foundation.
|
|
|
|
// You should have received a copy of the GNU General Public License and
|
|
// a copy of the GCC Runtime Library Exception along with this program;
|
|
// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
|
// <http://www.gnu.org/licenses/>.
|
|
|
|
/*
|
|
*
|
|
* Copyright (c) 1994
|
|
* Hewlett-Packard Company
|
|
*
|
|
* Permission to use, copy, modify, distribute and sell this software
|
|
* and its documentation for any purpose is hereby granted without fee,
|
|
* provided that the above copyright notice appear in all copies and
|
|
* that both that copyright notice and this permission notice appear
|
|
* in supporting documentation. Hewlett-Packard Company makes no
|
|
* representations about the suitability of this software for any
|
|
* purpose. It is provided "as is" without express or implied warranty.
|
|
*
|
|
*
|
|
* Copyright (c) 1996-1998
|
|
* Silicon Graphics Computer Systems, Inc.
|
|
*
|
|
* Permission to use, copy, modify, distribute and sell this software
|
|
* and its documentation for any purpose is hereby granted without fee,
|
|
* provided that the above copyright notice appear in all copies and
|
|
* that both that copyright notice and this permission notice appear
|
|
* in supporting documentation. Silicon Graphics makes no
|
|
* representations about the suitability of this software for any
|
|
* purpose. It is provided "as is" without express or implied warranty.
|
|
*/
|
|
|
|
/** @file bits/stl_function.h
|
|
* This is an internal header file, included by other library headers.
|
|
* Do not attempt to use it directly. @headername{functional}
|
|
*/
|
|
|
|
#ifndef _STL_FUNCTION_H
|
|
#define _STL_FUNCTION_H 1
|
|
|
|
#if __cplusplus > 201103L
|
|
#include <bits/move.h>
|
|
#endif
|
|
|
|
#define __glibcxx_want_transparent_operators
|
|
#include <bits/version.h>
|
|
|
|
namespace std _GLIBCXX_VISIBILITY(default)
|
|
{
|
|
_GLIBCXX_BEGIN_NAMESPACE_VERSION
|
|
|
|
// 20.3.1 base classes
|
|
/** @defgroup functors Function Objects
|
|
* @ingroup utilities
|
|
*
|
|
* Function objects, or _functors_, are objects with an `operator()`
|
|
* defined and accessible. They can be passed as arguments to algorithm
|
|
* templates and used in place of a function pointer. Not only is the
|
|
* resulting expressiveness of the library increased, but the generated
|
|
* code can be more efficient than what you might write by hand. When we
|
|
* refer to _functors_, then, generally we include function pointers in
|
|
* the description as well.
|
|
*
|
|
* Often, functors are only created as temporaries passed to algorithm
|
|
* calls, rather than being created as named variables.
|
|
*
|
|
* Two examples taken from the standard itself follow. To perform a
|
|
* by-element addition of two vectors `a` and `b` containing `double`,
|
|
* and put the result in `a`, use
|
|
* \code
|
|
* transform (a.begin(), a.end(), b.begin(), a.begin(), plus<double>());
|
|
* \endcode
|
|
* To negate every element in `a`, use
|
|
* \code
|
|
* transform(a.begin(), a.end(), a.begin(), negate<double>());
|
|
* \endcode
|
|
* The addition and negation functions will usually be inlined directly.
|
|
*
|
|
* An _adaptable function object_ is one which provides nested typedefs
|
|
* `result_type` and either `argument_type` (for a unary function) or
|
|
* `first_argument_type` and `second_argument_type` (for a binary function).
|
|
* Those typedefs are used by function object adaptors such as `bind2nd`.
|
|
* The standard library provides two class templates, `unary_function` and
|
|
* `binary_function`, which define those typedefs and so can be used as
|
|
* base classes of adaptable function objects.
|
|
*
|
|
* Since C++11 the use of function object adaptors has been superseded by
|
|
* more powerful tools such as lambda expressions, `function<>`, and more
|
|
* powerful type deduction (using `auto` and `decltype`). The helpers for
|
|
* defining adaptable function objects are deprecated since C++11, and no
|
|
* longer part of the standard library since C++17. However, they are still
|
|
* defined and used by libstdc++ after C++17, as a conforming extension.
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* Helper for defining adaptable unary function objects.
|
|
* @deprecated Deprecated in C++11, no longer in the standard since C++17.
|
|
*/
|
|
template<typename _Arg, typename _Result>
|
|
struct unary_function
|
|
{
|
|
/// @c argument_type is the type of the argument
|
|
typedef _Arg argument_type;
|
|
|
|
/// @c result_type is the return type
|
|
typedef _Result result_type;
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/**
|
|
* Helper for defining adaptable binary function objects.
|
|
* @deprecated Deprecated in C++11, no longer in the standard since C++17.
|
|
*/
|
|
template<typename _Arg1, typename _Arg2, typename _Result>
|
|
struct binary_function
|
|
{
|
|
/// @c first_argument_type is the type of the first argument
|
|
typedef _Arg1 first_argument_type;
|
|
|
|
/// @c second_argument_type is the type of the second argument
|
|
typedef _Arg2 second_argument_type;
|
|
|
|
/// @c result_type is the return type
|
|
typedef _Result result_type;
|
|
} _GLIBCXX11_DEPRECATED;
|
|
/** @} */
|
|
|
|
// 20.3.2 arithmetic
|
|
|
|
/** @defgroup arithmetic_functors Arithmetic Function Object Classes
|
|
* @ingroup functors
|
|
*
|
|
* The library provides function objects for basic arithmetic operations.
|
|
* See the documentation for @link functors function objects @endlink
|
|
* for examples of their use.
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
#if __cpp_lib_transparent_operators // C++ >= 14
|
|
struct __is_transparent; // undefined
|
|
|
|
template<typename _Tp = void>
|
|
struct plus;
|
|
|
|
template<typename _Tp = void>
|
|
struct minus;
|
|
|
|
template<typename _Tp = void>
|
|
struct multiplies;
|
|
|
|
template<typename _Tp = void>
|
|
struct divides;
|
|
|
|
template<typename _Tp = void>
|
|
struct modulus;
|
|
|
|
template<typename _Tp = void>
|
|
struct negate;
|
|
#endif
|
|
|
|
// Ignore warnings about unary_function and binary_function.
|
|
#pragma GCC diagnostic push
|
|
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<typename _Tp>
|
|
struct plus : public binary_function<_Tp, _Tp, _Tp>
|
|
{
|
|
/// Returns the sum
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x + __y; }
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<typename _Tp>
|
|
struct minus : public binary_function<_Tp, _Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x - __y; }
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<typename _Tp>
|
|
struct multiplies : public binary_function<_Tp, _Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x * __y; }
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<typename _Tp>
|
|
struct divides : public binary_function<_Tp, _Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x / __y; }
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<typename _Tp>
|
|
struct modulus : public binary_function<_Tp, _Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x % __y; }
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<typename _Tp>
|
|
struct negate : public unary_function<_Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x) const
|
|
{ return -__x; }
|
|
};
|
|
#pragma GCC diagnostic pop
|
|
|
|
#ifdef __cpp_lib_transparent_operators // C++ >= 14
|
|
template<>
|
|
struct plus<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) + std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) + std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) + std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<>
|
|
struct minus<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) - std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) - std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) - std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<>
|
|
struct multiplies<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) * std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) * std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) * std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<>
|
|
struct divides<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) / std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) / std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) / std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<>
|
|
struct modulus<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) % std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) % std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) % std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link arithmetic_functors math functors@endlink.
|
|
template<>
|
|
struct negate<void>
|
|
{
|
|
template <typename _Tp>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t) const
|
|
noexcept(noexcept(-std::forward<_Tp>(__t)))
|
|
-> decltype(-std::forward<_Tp>(__t))
|
|
{ return -std::forward<_Tp>(__t); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
#endif
|
|
/** @} */
|
|
|
|
// 20.3.3 comparisons
|
|
/** @defgroup comparison_functors Comparison Classes
|
|
* @ingroup functors
|
|
*
|
|
* The library provides six wrapper functors for all the basic comparisons
|
|
* in C++, like @c <.
|
|
*
|
|
* @{
|
|
*/
|
|
#if __cpp_lib_transparent_operators // C++ >= 14
|
|
template<typename _Tp = void>
|
|
struct equal_to;
|
|
|
|
template<typename _Tp = void>
|
|
struct not_equal_to;
|
|
|
|
template<typename _Tp = void>
|
|
struct greater;
|
|
|
|
template<typename _Tp = void>
|
|
struct less;
|
|
|
|
template<typename _Tp = void>
|
|
struct greater_equal;
|
|
|
|
template<typename _Tp = void>
|
|
struct less_equal;
|
|
#endif
|
|
|
|
#pragma GCC diagnostic push
|
|
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<typename _Tp>
|
|
struct equal_to : public binary_function<_Tp, _Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x == __y; }
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<typename _Tp>
|
|
struct not_equal_to : public binary_function<_Tp, _Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x != __y; }
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<typename _Tp>
|
|
struct greater : public binary_function<_Tp, _Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x > __y; }
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<typename _Tp>
|
|
struct less : public binary_function<_Tp, _Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x < __y; }
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<typename _Tp>
|
|
struct greater_equal : public binary_function<_Tp, _Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x >= __y; }
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<typename _Tp>
|
|
struct less_equal : public binary_function<_Tp, _Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x <= __y; }
|
|
};
|
|
|
|
// Partial specialization of std::greater for pointers.
|
|
template<typename _Tp>
|
|
struct greater<_Tp*> : public binary_function<_Tp*, _Tp*, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR bool
|
|
operator()(_Tp* __x, _Tp* __y) const _GLIBCXX_NOTHROW
|
|
{
|
|
#if __cplusplus >= 201402L
|
|
if (std::__is_constant_evaluated())
|
|
return __x > __y;
|
|
#endif
|
|
return (__UINTPTR_TYPE__)__x > (__UINTPTR_TYPE__)__y;
|
|
}
|
|
};
|
|
|
|
// Partial specialization of std::less for pointers.
|
|
template<typename _Tp>
|
|
struct less<_Tp*> : public binary_function<_Tp*, _Tp*, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR bool
|
|
operator()(_Tp* __x, _Tp* __y) const _GLIBCXX_NOTHROW
|
|
{
|
|
#if __cplusplus >= 201402L
|
|
if (std::__is_constant_evaluated())
|
|
return __x < __y;
|
|
#endif
|
|
return (__UINTPTR_TYPE__)__x < (__UINTPTR_TYPE__)__y;
|
|
}
|
|
};
|
|
|
|
// Partial specialization of std::greater_equal for pointers.
|
|
template<typename _Tp>
|
|
struct greater_equal<_Tp*> : public binary_function<_Tp*, _Tp*, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR bool
|
|
operator()(_Tp* __x, _Tp* __y) const _GLIBCXX_NOTHROW
|
|
{
|
|
#if __cplusplus >= 201402L
|
|
if (std::__is_constant_evaluated())
|
|
return __x >= __y;
|
|
#endif
|
|
return (__UINTPTR_TYPE__)__x >= (__UINTPTR_TYPE__)__y;
|
|
}
|
|
};
|
|
|
|
// Partial specialization of std::less_equal for pointers.
|
|
template<typename _Tp>
|
|
struct less_equal<_Tp*> : public binary_function<_Tp*, _Tp*, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR bool
|
|
operator()(_Tp* __x, _Tp* __y) const _GLIBCXX_NOTHROW
|
|
{
|
|
#if __cplusplus >= 201402L
|
|
if (std::__is_constant_evaluated())
|
|
return __x <= __y;
|
|
#endif
|
|
return (__UINTPTR_TYPE__)__x <= (__UINTPTR_TYPE__)__y;
|
|
}
|
|
};
|
|
#pragma GCC diagnostic pop
|
|
|
|
#ifdef __cpp_lib_transparent_operators // C++ >= 14
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<>
|
|
struct equal_to<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
constexpr auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) == std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) == std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) == std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<>
|
|
struct not_equal_to<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
constexpr auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) != std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) != std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) != std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<>
|
|
struct greater<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
constexpr auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) > std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) > std::forward<_Up>(__u))
|
|
{
|
|
return _S_cmp(std::forward<_Tp>(__t), std::forward<_Up>(__u),
|
|
__ptr_cmp<_Tp, _Up>{});
|
|
}
|
|
|
|
template<typename _Tp, typename _Up>
|
|
constexpr bool
|
|
operator()(_Tp* __t, _Up* __u) const noexcept
|
|
{ return greater<common_type_t<_Tp*, _Up*>>{}(__t, __u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
|
|
private:
|
|
template <typename _Tp, typename _Up>
|
|
static constexpr decltype(auto)
|
|
_S_cmp(_Tp&& __t, _Up&& __u, false_type)
|
|
{ return std::forward<_Tp>(__t) > std::forward<_Up>(__u); }
|
|
|
|
template <typename _Tp, typename _Up>
|
|
static constexpr bool
|
|
_S_cmp(_Tp&& __t, _Up&& __u, true_type) noexcept
|
|
{
|
|
return greater<const volatile void*>{}(
|
|
static_cast<const volatile void*>(std::forward<_Tp>(__t)),
|
|
static_cast<const volatile void*>(std::forward<_Up>(__u)));
|
|
}
|
|
|
|
// True if there is no viable operator> member function.
|
|
template<typename _Tp, typename _Up, typename = void>
|
|
struct __not_overloaded2 : true_type { };
|
|
|
|
// False if we can call T.operator>(U)
|
|
template<typename _Tp, typename _Up>
|
|
struct __not_overloaded2<_Tp, _Up, __void_t<
|
|
decltype(std::declval<_Tp>().operator>(std::declval<_Up>()))>>
|
|
: false_type { };
|
|
|
|
// True if there is no overloaded operator> for these operands.
|
|
template<typename _Tp, typename _Up, typename = void>
|
|
struct __not_overloaded : __not_overloaded2<_Tp, _Up> { };
|
|
|
|
// False if we can call operator>(T,U)
|
|
template<typename _Tp, typename _Up>
|
|
struct __not_overloaded<_Tp, _Up, __void_t<
|
|
decltype(operator>(std::declval<_Tp>(), std::declval<_Up>()))>>
|
|
: false_type { };
|
|
|
|
template<typename _Tp, typename _Up>
|
|
using __ptr_cmp = __and_<__not_overloaded<_Tp, _Up>,
|
|
is_convertible<_Tp, const volatile void*>,
|
|
is_convertible<_Up, const volatile void*>>;
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<>
|
|
struct less<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
constexpr auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) < std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) < std::forward<_Up>(__u))
|
|
{
|
|
return _S_cmp(std::forward<_Tp>(__t), std::forward<_Up>(__u),
|
|
__ptr_cmp<_Tp, _Up>{});
|
|
}
|
|
|
|
template<typename _Tp, typename _Up>
|
|
constexpr bool
|
|
operator()(_Tp* __t, _Up* __u) const noexcept
|
|
{ return less<common_type_t<_Tp*, _Up*>>{}(__t, __u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
|
|
private:
|
|
template <typename _Tp, typename _Up>
|
|
static constexpr decltype(auto)
|
|
_S_cmp(_Tp&& __t, _Up&& __u, false_type)
|
|
{ return std::forward<_Tp>(__t) < std::forward<_Up>(__u); }
|
|
|
|
template <typename _Tp, typename _Up>
|
|
static constexpr bool
|
|
_S_cmp(_Tp&& __t, _Up&& __u, true_type) noexcept
|
|
{
|
|
return less<const volatile void*>{}(
|
|
static_cast<const volatile void*>(std::forward<_Tp>(__t)),
|
|
static_cast<const volatile void*>(std::forward<_Up>(__u)));
|
|
}
|
|
|
|
// True if there is no viable operator< member function.
|
|
template<typename _Tp, typename _Up, typename = void>
|
|
struct __not_overloaded2 : true_type { };
|
|
|
|
// False if we can call T.operator<(U)
|
|
template<typename _Tp, typename _Up>
|
|
struct __not_overloaded2<_Tp, _Up, __void_t<
|
|
decltype(std::declval<_Tp>().operator<(std::declval<_Up>()))>>
|
|
: false_type { };
|
|
|
|
// True if there is no overloaded operator< for these operands.
|
|
template<typename _Tp, typename _Up, typename = void>
|
|
struct __not_overloaded : __not_overloaded2<_Tp, _Up> { };
|
|
|
|
// False if we can call operator<(T,U)
|
|
template<typename _Tp, typename _Up>
|
|
struct __not_overloaded<_Tp, _Up, __void_t<
|
|
decltype(operator<(std::declval<_Tp>(), std::declval<_Up>()))>>
|
|
: false_type { };
|
|
|
|
template<typename _Tp, typename _Up>
|
|
using __ptr_cmp = __and_<__not_overloaded<_Tp, _Up>,
|
|
is_convertible<_Tp, const volatile void*>,
|
|
is_convertible<_Up, const volatile void*>>;
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<>
|
|
struct greater_equal<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
constexpr auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) >= std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) >= std::forward<_Up>(__u))
|
|
{
|
|
return _S_cmp(std::forward<_Tp>(__t), std::forward<_Up>(__u),
|
|
__ptr_cmp<_Tp, _Up>{});
|
|
}
|
|
|
|
template<typename _Tp, typename _Up>
|
|
constexpr bool
|
|
operator()(_Tp* __t, _Up* __u) const noexcept
|
|
{ return greater_equal<common_type_t<_Tp*, _Up*>>{}(__t, __u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
|
|
private:
|
|
template <typename _Tp, typename _Up>
|
|
static constexpr decltype(auto)
|
|
_S_cmp(_Tp&& __t, _Up&& __u, false_type)
|
|
{ return std::forward<_Tp>(__t) >= std::forward<_Up>(__u); }
|
|
|
|
template <typename _Tp, typename _Up>
|
|
static constexpr bool
|
|
_S_cmp(_Tp&& __t, _Up&& __u, true_type) noexcept
|
|
{
|
|
return greater_equal<const volatile void*>{}(
|
|
static_cast<const volatile void*>(std::forward<_Tp>(__t)),
|
|
static_cast<const volatile void*>(std::forward<_Up>(__u)));
|
|
}
|
|
|
|
// True if there is no viable operator>= member function.
|
|
template<typename _Tp, typename _Up, typename = void>
|
|
struct __not_overloaded2 : true_type { };
|
|
|
|
// False if we can call T.operator>=(U)
|
|
template<typename _Tp, typename _Up>
|
|
struct __not_overloaded2<_Tp, _Up, __void_t<
|
|
decltype(std::declval<_Tp>().operator>=(std::declval<_Up>()))>>
|
|
: false_type { };
|
|
|
|
// True if there is no overloaded operator>= for these operands.
|
|
template<typename _Tp, typename _Up, typename = void>
|
|
struct __not_overloaded : __not_overloaded2<_Tp, _Up> { };
|
|
|
|
// False if we can call operator>=(T,U)
|
|
template<typename _Tp, typename _Up>
|
|
struct __not_overloaded<_Tp, _Up, __void_t<
|
|
decltype(operator>=(std::declval<_Tp>(), std::declval<_Up>()))>>
|
|
: false_type { };
|
|
|
|
template<typename _Tp, typename _Up>
|
|
using __ptr_cmp = __and_<__not_overloaded<_Tp, _Up>,
|
|
is_convertible<_Tp, const volatile void*>,
|
|
is_convertible<_Up, const volatile void*>>;
|
|
};
|
|
|
|
/// One of the @link comparison_functors comparison functors@endlink.
|
|
template<>
|
|
struct less_equal<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
constexpr auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) <= std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) <= std::forward<_Up>(__u))
|
|
{
|
|
return _S_cmp(std::forward<_Tp>(__t), std::forward<_Up>(__u),
|
|
__ptr_cmp<_Tp, _Up>{});
|
|
}
|
|
|
|
template<typename _Tp, typename _Up>
|
|
constexpr bool
|
|
operator()(_Tp* __t, _Up* __u) const noexcept
|
|
{ return less_equal<common_type_t<_Tp*, _Up*>>{}(__t, __u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
|
|
private:
|
|
template <typename _Tp, typename _Up>
|
|
static constexpr decltype(auto)
|
|
_S_cmp(_Tp&& __t, _Up&& __u, false_type)
|
|
{ return std::forward<_Tp>(__t) <= std::forward<_Up>(__u); }
|
|
|
|
template <typename _Tp, typename _Up>
|
|
static constexpr bool
|
|
_S_cmp(_Tp&& __t, _Up&& __u, true_type) noexcept
|
|
{
|
|
return less_equal<const volatile void*>{}(
|
|
static_cast<const volatile void*>(std::forward<_Tp>(__t)),
|
|
static_cast<const volatile void*>(std::forward<_Up>(__u)));
|
|
}
|
|
|
|
// True if there is no viable operator<= member function.
|
|
template<typename _Tp, typename _Up, typename = void>
|
|
struct __not_overloaded2 : true_type { };
|
|
|
|
// False if we can call T.operator<=(U)
|
|
template<typename _Tp, typename _Up>
|
|
struct __not_overloaded2<_Tp, _Up, __void_t<
|
|
decltype(std::declval<_Tp>().operator<=(std::declval<_Up>()))>>
|
|
: false_type { };
|
|
|
|
// True if there is no overloaded operator<= for these operands.
|
|
template<typename _Tp, typename _Up, typename = void>
|
|
struct __not_overloaded : __not_overloaded2<_Tp, _Up> { };
|
|
|
|
// False if we can call operator<=(T,U)
|
|
template<typename _Tp, typename _Up>
|
|
struct __not_overloaded<_Tp, _Up, __void_t<
|
|
decltype(operator<=(std::declval<_Tp>(), std::declval<_Up>()))>>
|
|
: false_type { };
|
|
|
|
template<typename _Tp, typename _Up>
|
|
using __ptr_cmp = __and_<__not_overloaded<_Tp, _Up>,
|
|
is_convertible<_Tp, const volatile void*>,
|
|
is_convertible<_Up, const volatile void*>>;
|
|
};
|
|
#endif // __cpp_lib_transparent_operators
|
|
/** @} */
|
|
|
|
// 20.3.4 logical operations
|
|
/** @defgroup logical_functors Boolean Operations Classes
|
|
* @ingroup functors
|
|
*
|
|
* The library provides function objects for the logical operations:
|
|
* `&&`, `||`, and `!`.
|
|
*
|
|
* @{
|
|
*/
|
|
#ifdef __cpp_lib_transparent_operators // C++ >= 14
|
|
template<typename _Tp = void>
|
|
struct logical_and;
|
|
|
|
template<typename _Tp = void>
|
|
struct logical_or;
|
|
|
|
template<typename _Tp = void>
|
|
struct logical_not;
|
|
#endif
|
|
|
|
#pragma GCC diagnostic push
|
|
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
|
|
|
/// One of the @link logical_functors Boolean operations functors@endlink.
|
|
template<typename _Tp>
|
|
struct logical_and : public binary_function<_Tp, _Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x && __y; }
|
|
};
|
|
|
|
/// One of the @link logical_functors Boolean operations functors@endlink.
|
|
template<typename _Tp>
|
|
struct logical_or : public binary_function<_Tp, _Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x || __y; }
|
|
};
|
|
|
|
/// One of the @link logical_functors Boolean operations functors@endlink.
|
|
template<typename _Tp>
|
|
struct logical_not : public unary_function<_Tp, bool>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const _Tp& __x) const
|
|
{ return !__x; }
|
|
};
|
|
#pragma GCC diagnostic pop
|
|
|
|
#ifdef __cpp_lib_transparent_operators // C++ >= 14
|
|
/// One of the @link logical_functors Boolean operations functors@endlink.
|
|
template<>
|
|
struct logical_and<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) && std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) && std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) && std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link logical_functors Boolean operations functors@endlink.
|
|
template<>
|
|
struct logical_or<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) || std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) || std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) || std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
/// One of the @link logical_functors Boolean operations functors@endlink.
|
|
template<>
|
|
struct logical_not<void>
|
|
{
|
|
template <typename _Tp>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t) const
|
|
noexcept(noexcept(!std::forward<_Tp>(__t)))
|
|
-> decltype(!std::forward<_Tp>(__t))
|
|
{ return !std::forward<_Tp>(__t); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
#endif // __cpp_lib_transparent_operators
|
|
/** @} */
|
|
|
|
#ifdef __cpp_lib_transparent_operators // C++ >= 14
|
|
template<typename _Tp = void>
|
|
struct bit_and;
|
|
|
|
template<typename _Tp = void>
|
|
struct bit_or;
|
|
|
|
template<typename _Tp = void>
|
|
struct bit_xor;
|
|
|
|
template<typename _Tp = void>
|
|
struct bit_not;
|
|
#endif
|
|
|
|
#pragma GCC diagnostic push
|
|
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
|
|
|
// _GLIBCXX_RESOLVE_LIB_DEFECTS
|
|
// DR 660. Missing Bitwise Operations.
|
|
template<typename _Tp>
|
|
struct bit_and : public binary_function<_Tp, _Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x & __y; }
|
|
};
|
|
|
|
template<typename _Tp>
|
|
struct bit_or : public binary_function<_Tp, _Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x | __y; }
|
|
};
|
|
|
|
template<typename _Tp>
|
|
struct bit_xor : public binary_function<_Tp, _Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x, const _Tp& __y) const
|
|
{ return __x ^ __y; }
|
|
};
|
|
|
|
template<typename _Tp>
|
|
struct bit_not : public unary_function<_Tp, _Tp>
|
|
{
|
|
_GLIBCXX14_CONSTEXPR
|
|
_Tp
|
|
operator()(const _Tp& __x) const
|
|
{ return ~__x; }
|
|
};
|
|
#pragma GCC diagnostic pop
|
|
|
|
#ifdef __cpp_lib_transparent_operators // C++ >= 14
|
|
template <>
|
|
struct bit_and<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) & std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) & std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) & std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
template <>
|
|
struct bit_or<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) | std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) | std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) | std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
template <>
|
|
struct bit_xor<void>
|
|
{
|
|
template <typename _Tp, typename _Up>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t, _Up&& __u) const
|
|
noexcept(noexcept(std::forward<_Tp>(__t) ^ std::forward<_Up>(__u)))
|
|
-> decltype(std::forward<_Tp>(__t) ^ std::forward<_Up>(__u))
|
|
{ return std::forward<_Tp>(__t) ^ std::forward<_Up>(__u); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
|
|
template <>
|
|
struct bit_not<void>
|
|
{
|
|
template <typename _Tp>
|
|
_GLIBCXX14_CONSTEXPR
|
|
auto
|
|
operator()(_Tp&& __t) const
|
|
noexcept(noexcept(~std::forward<_Tp>(__t)))
|
|
-> decltype(~std::forward<_Tp>(__t))
|
|
{ return ~std::forward<_Tp>(__t); }
|
|
|
|
typedef __is_transparent is_transparent;
|
|
};
|
|
#endif // C++14
|
|
|
|
#pragma GCC diagnostic push
|
|
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
|
|
|
// 20.3.5 negators
|
|
/** @defgroup negators Negators
|
|
* @ingroup functors
|
|
*
|
|
* The function templates `not1` and `not2` are function object adaptors,
|
|
* which each take a predicate functor and wrap it in an instance of
|
|
* `unary_negate` or `binary_negate`, respectively. Those classes are
|
|
* functors whose `operator()` evaluates the wrapped predicate function
|
|
* and then returns the negation of the result.
|
|
*
|
|
* For example, given a vector of integers and a trivial predicate,
|
|
* \code
|
|
* struct IntGreaterThanThree
|
|
* : public std::unary_function<int, bool>
|
|
* {
|
|
* bool operator() (int x) const { return x > 3; }
|
|
* };
|
|
*
|
|
* std::find_if (v.begin(), v.end(), not1(IntGreaterThanThree()));
|
|
* \endcode
|
|
* The call to `find_if` will locate the first index (i) of `v` for which
|
|
* `!(v[i] > 3)` is true.
|
|
*
|
|
* The not1/unary_negate combination works on predicates taking a single
|
|
* argument. The not2/binary_negate combination works on predicates taking
|
|
* two arguments.
|
|
*
|
|
* @deprecated Deprecated in C++17, no longer in the standard since C++20.
|
|
* Use `not_fn` instead.
|
|
*
|
|
* @{
|
|
*/
|
|
/// One of the @link negators negation functors@endlink.
|
|
template<typename _Predicate>
|
|
class _GLIBCXX17_DEPRECATED unary_negate
|
|
: public unary_function<typename _Predicate::argument_type, bool>
|
|
{
|
|
protected:
|
|
_Predicate _M_pred;
|
|
|
|
public:
|
|
_GLIBCXX14_CONSTEXPR
|
|
explicit
|
|
unary_negate(const _Predicate& __x) : _M_pred(__x) { }
|
|
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const typename _Predicate::argument_type& __x) const
|
|
{ return !_M_pred(__x); }
|
|
};
|
|
|
|
/// One of the @link negators negation functors@endlink.
|
|
template<typename _Predicate>
|
|
_GLIBCXX17_DEPRECATED_SUGGEST("std::not_fn")
|
|
_GLIBCXX14_CONSTEXPR
|
|
inline unary_negate<_Predicate>
|
|
not1(const _Predicate& __pred)
|
|
{ return unary_negate<_Predicate>(__pred); }
|
|
|
|
/// One of the @link negators negation functors@endlink.
|
|
template<typename _Predicate>
|
|
class _GLIBCXX17_DEPRECATED binary_negate
|
|
: public binary_function<typename _Predicate::first_argument_type,
|
|
typename _Predicate::second_argument_type, bool>
|
|
{
|
|
protected:
|
|
_Predicate _M_pred;
|
|
|
|
public:
|
|
_GLIBCXX14_CONSTEXPR
|
|
explicit
|
|
binary_negate(const _Predicate& __x) : _M_pred(__x) { }
|
|
|
|
_GLIBCXX14_CONSTEXPR
|
|
bool
|
|
operator()(const typename _Predicate::first_argument_type& __x,
|
|
const typename _Predicate::second_argument_type& __y) const
|
|
{ return !_M_pred(__x, __y); }
|
|
};
|
|
|
|
/// One of the @link negators negation functors@endlink.
|
|
template<typename _Predicate>
|
|
_GLIBCXX17_DEPRECATED_SUGGEST("std::not_fn")
|
|
_GLIBCXX14_CONSTEXPR
|
|
inline binary_negate<_Predicate>
|
|
not2(const _Predicate& __pred)
|
|
{ return binary_negate<_Predicate>(__pred); }
|
|
/** @} */
|
|
|
|
// 20.3.7 adaptors pointers functions
|
|
/** @defgroup pointer_adaptors Adaptors for pointers to functions
|
|
* @ingroup functors
|
|
*
|
|
* The advantage of function objects over pointers to functions is that
|
|
* the objects in the standard library declare nested typedefs describing
|
|
* their argument and result types with uniform names (e.g., `result_type`
|
|
* from the base classes `unary_function` and `binary_function`).
|
|
* Sometimes those typedefs are required, not just optional.
|
|
*
|
|
* Adaptors are provided to turn pointers to unary (single-argument) and
|
|
* binary (double-argument) functions into function objects. The
|
|
* long-winded functor `pointer_to_unary_function` is constructed with a
|
|
* function pointer `f`, and its `operator()` called with argument `x`
|
|
* returns `f(x)`. The functor `pointer_to_binary_function` does the same
|
|
* thing, but with a double-argument `f` and `operator()`.
|
|
*
|
|
* The function `ptr_fun` takes a pointer-to-function `f` and constructs
|
|
* an instance of the appropriate functor.
|
|
*
|
|
* @deprecated Deprecated in C++11, no longer in the standard since C++17.
|
|
*
|
|
* @{
|
|
*/
|
|
/// One of the @link pointer_adaptors adaptors for function pointers@endlink.
|
|
template<typename _Arg, typename _Result>
|
|
class pointer_to_unary_function : public unary_function<_Arg, _Result>
|
|
{
|
|
protected:
|
|
_Result (*_M_ptr)(_Arg);
|
|
|
|
public:
|
|
pointer_to_unary_function() { }
|
|
|
|
explicit
|
|
pointer_to_unary_function(_Result (*__x)(_Arg))
|
|
: _M_ptr(__x) { }
|
|
|
|
_Result
|
|
operator()(_Arg __x) const
|
|
{ return _M_ptr(__x); }
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link pointer_adaptors adaptors for function pointers@endlink.
|
|
template<typename _Arg, typename _Result>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::function")
|
|
inline pointer_to_unary_function<_Arg, _Result>
|
|
ptr_fun(_Result (*__x)(_Arg))
|
|
{ return pointer_to_unary_function<_Arg, _Result>(__x); }
|
|
|
|
/// One of the @link pointer_adaptors adaptors for function pointers@endlink.
|
|
template<typename _Arg1, typename _Arg2, typename _Result>
|
|
class pointer_to_binary_function
|
|
: public binary_function<_Arg1, _Arg2, _Result>
|
|
{
|
|
protected:
|
|
_Result (*_M_ptr)(_Arg1, _Arg2);
|
|
|
|
public:
|
|
pointer_to_binary_function() { }
|
|
|
|
explicit
|
|
pointer_to_binary_function(_Result (*__x)(_Arg1, _Arg2))
|
|
: _M_ptr(__x) { }
|
|
|
|
_Result
|
|
operator()(_Arg1 __x, _Arg2 __y) const
|
|
{ return _M_ptr(__x, __y); }
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link pointer_adaptors adaptors for function pointers@endlink.
|
|
template<typename _Arg1, typename _Arg2, typename _Result>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::function")
|
|
inline pointer_to_binary_function<_Arg1, _Arg2, _Result>
|
|
ptr_fun(_Result (*__x)(_Arg1, _Arg2))
|
|
{ return pointer_to_binary_function<_Arg1, _Arg2, _Result>(__x); }
|
|
/** @} */
|
|
|
|
template<typename _Tp>
|
|
struct _Identity
|
|
: public unary_function<_Tp, _Tp>
|
|
{
|
|
_Tp&
|
|
operator()(_Tp& __x) const
|
|
{ return __x; }
|
|
|
|
const _Tp&
|
|
operator()(const _Tp& __x) const
|
|
{ return __x; }
|
|
};
|
|
|
|
// Partial specialization, avoids confusing errors in e.g. std::set<const T>.
|
|
template<typename _Tp> struct _Identity<const _Tp> : _Identity<_Tp> { };
|
|
|
|
template<typename _Pair>
|
|
struct _Select1st
|
|
: public unary_function<_Pair, typename _Pair::first_type>
|
|
{
|
|
typename _Pair::first_type&
|
|
operator()(_Pair& __x) const
|
|
{ return __x.first; }
|
|
|
|
const typename _Pair::first_type&
|
|
operator()(const _Pair& __x) const
|
|
{ return __x.first; }
|
|
|
|
#if __cplusplus >= 201103L
|
|
template<typename _Pair2>
|
|
typename _Pair2::first_type&
|
|
operator()(_Pair2& __x) const
|
|
{ return __x.first; }
|
|
|
|
template<typename _Pair2>
|
|
const typename _Pair2::first_type&
|
|
operator()(const _Pair2& __x) const
|
|
{ return __x.first; }
|
|
#endif
|
|
};
|
|
|
|
template<typename _Pair>
|
|
struct _Select2nd
|
|
: public unary_function<_Pair, typename _Pair::second_type>
|
|
{
|
|
typename _Pair::second_type&
|
|
operator()(_Pair& __x) const
|
|
{ return __x.second; }
|
|
|
|
const typename _Pair::second_type&
|
|
operator()(const _Pair& __x) const
|
|
{ return __x.second; }
|
|
};
|
|
|
|
// 20.3.8 adaptors pointers members
|
|
/** @defgroup ptrmem_adaptors Adaptors for pointers to members
|
|
* @ingroup functors
|
|
*
|
|
* There are a total of 8 = 2^3 function objects in this family.
|
|
* (1) Member functions taking no arguments vs member functions taking
|
|
* one argument.
|
|
* (2) Call through pointer vs call through reference.
|
|
* (3) Const vs non-const member function.
|
|
*
|
|
* All of this complexity is in the function objects themselves. You can
|
|
* ignore it by using the helper function `mem_fun` and `mem_fun_ref`,
|
|
* which create whichever type of adaptor is appropriate.
|
|
*
|
|
* @deprecated Deprecated in C++11, no longer in the standard since C++17.
|
|
* Use `mem_fn` instead.
|
|
*
|
|
* @{
|
|
*/
|
|
/// One of the @link ptrmem_adaptors adaptors for member pointers@endlink.
|
|
template<typename _Ret, typename _Tp>
|
|
class mem_fun_t : public unary_function<_Tp*, _Ret>
|
|
{
|
|
public:
|
|
explicit
|
|
mem_fun_t(_Ret (_Tp::*__pf)())
|
|
: _M_f(__pf) { }
|
|
|
|
_Ret
|
|
operator()(_Tp* __p) const
|
|
{ return (__p->*_M_f)(); }
|
|
|
|
private:
|
|
_Ret (_Tp::*_M_f)();
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link ptrmem_adaptors adaptors for member pointers@endlink.
|
|
template<typename _Ret, typename _Tp>
|
|
class const_mem_fun_t : public unary_function<const _Tp*, _Ret>
|
|
{
|
|
public:
|
|
explicit
|
|
const_mem_fun_t(_Ret (_Tp::*__pf)() const)
|
|
: _M_f(__pf) { }
|
|
|
|
_Ret
|
|
operator()(const _Tp* __p) const
|
|
{ return (__p->*_M_f)(); }
|
|
|
|
private:
|
|
_Ret (_Tp::*_M_f)() const;
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link ptrmem_adaptors adaptors for member pointers@endlink.
|
|
template<typename _Ret, typename _Tp>
|
|
class mem_fun_ref_t : public unary_function<_Tp, _Ret>
|
|
{
|
|
public:
|
|
explicit
|
|
mem_fun_ref_t(_Ret (_Tp::*__pf)())
|
|
: _M_f(__pf) { }
|
|
|
|
_Ret
|
|
operator()(_Tp& __r) const
|
|
{ return (__r.*_M_f)(); }
|
|
|
|
private:
|
|
_Ret (_Tp::*_M_f)();
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link ptrmem_adaptors adaptors for member pointers@endlink.
|
|
template<typename _Ret, typename _Tp>
|
|
class const_mem_fun_ref_t : public unary_function<_Tp, _Ret>
|
|
{
|
|
public:
|
|
explicit
|
|
const_mem_fun_ref_t(_Ret (_Tp::*__pf)() const)
|
|
: _M_f(__pf) { }
|
|
|
|
_Ret
|
|
operator()(const _Tp& __r) const
|
|
{ return (__r.*_M_f)(); }
|
|
|
|
private:
|
|
_Ret (_Tp::*_M_f)() const;
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link ptrmem_adaptors adaptors for member pointers@endlink.
|
|
template<typename _Ret, typename _Tp, typename _Arg>
|
|
class mem_fun1_t : public binary_function<_Tp*, _Arg, _Ret>
|
|
{
|
|
public:
|
|
explicit
|
|
mem_fun1_t(_Ret (_Tp::*__pf)(_Arg))
|
|
: _M_f(__pf) { }
|
|
|
|
_Ret
|
|
operator()(_Tp* __p, _Arg __x) const
|
|
{ return (__p->*_M_f)(__x); }
|
|
|
|
private:
|
|
_Ret (_Tp::*_M_f)(_Arg);
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link ptrmem_adaptors adaptors for member pointers@endlink.
|
|
template<typename _Ret, typename _Tp, typename _Arg>
|
|
class const_mem_fun1_t : public binary_function<const _Tp*, _Arg, _Ret>
|
|
{
|
|
public:
|
|
explicit
|
|
const_mem_fun1_t(_Ret (_Tp::*__pf)(_Arg) const)
|
|
: _M_f(__pf) { }
|
|
|
|
_Ret
|
|
operator()(const _Tp* __p, _Arg __x) const
|
|
{ return (__p->*_M_f)(__x); }
|
|
|
|
private:
|
|
_Ret (_Tp::*_M_f)(_Arg) const;
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link ptrmem_adaptors adaptors for member pointers@endlink.
|
|
template<typename _Ret, typename _Tp, typename _Arg>
|
|
class mem_fun1_ref_t : public binary_function<_Tp, _Arg, _Ret>
|
|
{
|
|
public:
|
|
explicit
|
|
mem_fun1_ref_t(_Ret (_Tp::*__pf)(_Arg))
|
|
: _M_f(__pf) { }
|
|
|
|
_Ret
|
|
operator()(_Tp& __r, _Arg __x) const
|
|
{ return (__r.*_M_f)(__x); }
|
|
|
|
private:
|
|
_Ret (_Tp::*_M_f)(_Arg);
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
/// One of the @link ptrmem_adaptors adaptors for member pointers@endlink.
|
|
template<typename _Ret, typename _Tp, typename _Arg>
|
|
class const_mem_fun1_ref_t : public binary_function<_Tp, _Arg, _Ret>
|
|
{
|
|
public:
|
|
explicit
|
|
const_mem_fun1_ref_t(_Ret (_Tp::*__pf)(_Arg) const)
|
|
: _M_f(__pf) { }
|
|
|
|
_Ret
|
|
operator()(const _Tp& __r, _Arg __x) const
|
|
{ return (__r.*_M_f)(__x); }
|
|
|
|
private:
|
|
_Ret (_Tp::*_M_f)(_Arg) const;
|
|
} _GLIBCXX11_DEPRECATED;
|
|
|
|
// Mem_fun adaptor helper functions. There are only two:
|
|
// mem_fun and mem_fun_ref.
|
|
template<typename _Ret, typename _Tp>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::mem_fn")
|
|
inline mem_fun_t<_Ret, _Tp>
|
|
mem_fun(_Ret (_Tp::*__f)())
|
|
{ return mem_fun_t<_Ret, _Tp>(__f); }
|
|
|
|
template<typename _Ret, typename _Tp>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::mem_fn")
|
|
inline const_mem_fun_t<_Ret, _Tp>
|
|
mem_fun(_Ret (_Tp::*__f)() const)
|
|
{ return const_mem_fun_t<_Ret, _Tp>(__f); }
|
|
|
|
template<typename _Ret, typename _Tp>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::mem_fn")
|
|
inline mem_fun_ref_t<_Ret, _Tp>
|
|
mem_fun_ref(_Ret (_Tp::*__f)())
|
|
{ return mem_fun_ref_t<_Ret, _Tp>(__f); }
|
|
|
|
template<typename _Ret, typename _Tp>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::mem_fn")
|
|
inline const_mem_fun_ref_t<_Ret, _Tp>
|
|
mem_fun_ref(_Ret (_Tp::*__f)() const)
|
|
{ return const_mem_fun_ref_t<_Ret, _Tp>(__f); }
|
|
|
|
template<typename _Ret, typename _Tp, typename _Arg>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::mem_fn")
|
|
inline mem_fun1_t<_Ret, _Tp, _Arg>
|
|
mem_fun(_Ret (_Tp::*__f)(_Arg))
|
|
{ return mem_fun1_t<_Ret, _Tp, _Arg>(__f); }
|
|
|
|
template<typename _Ret, typename _Tp, typename _Arg>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::mem_fn")
|
|
inline const_mem_fun1_t<_Ret, _Tp, _Arg>
|
|
mem_fun(_Ret (_Tp::*__f)(_Arg) const)
|
|
{ return const_mem_fun1_t<_Ret, _Tp, _Arg>(__f); }
|
|
|
|
template<typename _Ret, typename _Tp, typename _Arg>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::mem_fn")
|
|
inline mem_fun1_ref_t<_Ret, _Tp, _Arg>
|
|
mem_fun_ref(_Ret (_Tp::*__f)(_Arg))
|
|
{ return mem_fun1_ref_t<_Ret, _Tp, _Arg>(__f); }
|
|
|
|
template<typename _Ret, typename _Tp, typename _Arg>
|
|
_GLIBCXX11_DEPRECATED_SUGGEST("std::mem_fn")
|
|
inline const_mem_fun1_ref_t<_Ret, _Tp, _Arg>
|
|
mem_fun_ref(_Ret (_Tp::*__f)(_Arg) const)
|
|
{ return const_mem_fun1_ref_t<_Ret, _Tp, _Arg>(__f); }
|
|
#pragma GCC diagnostic pop
|
|
|
|
/** @} */
|
|
|
|
#ifdef __cpp_lib_transparent_operators // C++ >= 14
|
|
template<typename _Func, typename _SfinaeType, typename = __void_t<>>
|
|
struct __has_is_transparent
|
|
{ };
|
|
|
|
template<typename _Func, typename _SfinaeType>
|
|
struct __has_is_transparent<_Func, _SfinaeType,
|
|
__void_t<typename _Func::is_transparent>>
|
|
{ typedef void type; };
|
|
|
|
template<typename _Func, typename _SfinaeType>
|
|
using __has_is_transparent_t
|
|
= typename __has_is_transparent<_Func, _SfinaeType>::type;
|
|
#endif
|
|
|
|
_GLIBCXX_END_NAMESPACE_VERSION
|
|
} // namespace
|
|
|
|
#if (__cplusplus < 201103L) || _GLIBCXX_USE_DEPRECATED
|
|
# include <backward/binders.h>
|
|
#endif
|
|
|
|
#endif /* _STL_FUNCTION_H */
|