libstdc++
Utilities
Collaboration diagram for Utilities:

Modules

 Concepts
 
 Function Objects
 
 Memory
 
 Metaprogramming
 
 Rational Arithmetic
 
 Time
 

Classes

struct  std::_Optional_base< _Tp, bool, bool >
 
struct  std::_Tuple_impl< _Idx, _Elements >
 
struct  std::_Tuple_impl< _Idx, _Head, _Tail... >
 
class  std::any
 
struct  std::array< _Tp, _Nm >
 
class  std::bad_any_cast
 
class  std::bad_optional_access
 
class  std::bitset< _Nb >
 
struct  std::nullopt_t
 
class  std::optional< _Tp >
 
struct  std::pair< _T1, _T2 >
 
struct  std::piecewise_construct_t
 
class  std::tuple< _Elements >
 
class  std::tuple< _T1, _T2 >
 
struct  std::tuple_element< __i, tuple< _Types... > >
 
struct  std::tuple_size< tuple< _Elements... > >
 
struct  std::type_index
 
struct  std::uses_allocator< tuple< _Types... >, _Alloc >
 

Macros

#define __cpp_lib_addressof_constexpr
 
#define __cpp_lib_any
 
#define __cpp_lib_apply
 
#define __cpp_lib_make_from_tuple
 
#define __cpp_lib_optional
 
#define __cpp_lib_tuples_by_type
 

Typedefs

template<typename _Tp , typename _Up >
using std::__assigns_from_optional = __or_< is_assignable< _Tp &, const optional< _Up > & >, is_assignable< _Tp &, optional< _Up > & >, is_assignable< _Tp &, const optional< _Up > && >, is_assignable< _Tp &, optional< _Up > && > >
 
template<typename _Tp , typename _Up >
using std::__converts_from_optional = __or_< is_constructible< _Tp, const optional< _Up > & >, is_constructible< _Tp, optional< _Up > & >, is_constructible< _Tp, const optional< _Up > && >, is_constructible< _Tp, optional< _Up > && >, is_convertible< const optional< _Up > &, _Tp >, is_convertible< optional< _Up > &, _Tp >, is_convertible< const optional< _Up > &&, _Tp >, is_convertible< optional< _Up > &&, _Tp > >
 
template<typename _Tp >
using std::__empty_not_final = __conditional_t< __is_final(_Tp), false_type, __is_empty_non_tuple< _Tp > >
 
template<typename _Tp , typename _Up >
using std::__optional_eq_t = __optional_relop_t< decltype(std::declval< const _Tp & >()==std::declval< const _Up & >()) >
 
template<typename _Tp , typename _Up >
using std::__optional_ge_t = __optional_relop_t< decltype(std::declval< const _Tp & >() >=std::declval< const _Up & >()) >
 
template<typename _Tp , typename _Up >
using std::__optional_gt_t = __optional_relop_t< decltype(std::declval< const _Tp & >() > std::declval< const _Up & >()) >
 
template<typename _Tp , typename _Up >
using std::__optional_le_t = __optional_relop_t< decltype(std::declval< const _Tp & >()<=std::declval< const _Up & >()) >
 
template<typename _Tp , typename _Up >
using std::__optional_lt_t = __optional_relop_t< decltype(std::declval< const _Tp & >()< std::declval< const _Up & >()) >
 
template<typename _Tp , typename _Up >
using std::__optional_ne_t = __optional_relop_t< decltype(std::declval< const _Tp & >() !=std::declval< const _Up & >()) >
 
template<typename _Tp >
using std::__optional_relop_t = enable_if_t< is_convertible< _Tp, bool >::value, bool >
 

Functions

template<typename... _Args1, typename... _Args2>
constexpr std::pair< _T1, _T2 >::pair (piecewise_construct_t, tuple< _Args1... >, tuple< _Args2... >)
 
template<typename _Tp >
constexpr _Tp * std::__addressof (_Tp &__r) noexcept
 
template<typename _Fn , typename _Tuple , size_t... _Idx>
constexpr decltype(auto) std::__apply_impl (_Fn &&__f, _Tuple &&__t, index_sequence< _Idx... >)
 
template<typename _Tp , typename _Up = _Tp>
constexpr _Tp std::__exchange (_Tp &__obj, _Up &&__new_val)
 
template<size_t __i, typename _Head , typename... _Tail>
constexpr _Head & std::__get_helper (_Tuple_impl< __i, _Head, _Tail... > &__t) noexcept
 
template<size_t __i, typename _Head , typename... _Tail>
constexpr const _Head & std::__get_helper (const _Tuple_impl< __i, _Head, _Tail... > &__t) noexcept
 
template<size_t __i, typename... _Types>
__enable_if_t<(__i >=sizeof...(_Types))> std::__get_helper (const tuple< _Types... > &)=delete
 
template<typename _Tp , typename _Up = typename __inv_unwrap<_Tp>::type>
constexpr _Up && std::__invfwd (typename remove_reference< _Tp >::type &__t) noexcept
 
template<typename _Callable , typename... _Args>
constexpr __invoke_result< _Callable, _Args... >::type std::__invoke (_Callable &&__fn, _Args &&... __args) noexcept(__is_nothrow_invocable< _Callable, _Args... >::value)
 
template<typename _Res , typename _MemFun , typename _Tp , typename... _Args>
constexpr _Res std::__invoke_impl (__invoke_memfun_deref, _MemFun &&__f, _Tp &&__t, _Args &&... __args)
 
template<typename _Res , typename _MemFun , typename _Tp , typename... _Args>
constexpr _Res std::__invoke_impl (__invoke_memfun_ref, _MemFun &&__f, _Tp &&__t, _Args &&... __args)
 
template<typename _Res , typename _MemPtr , typename _Tp >
constexpr _Res std::__invoke_impl (__invoke_memobj_deref, _MemPtr &&__f, _Tp &&__t)
 
template<typename _Res , typename _MemPtr , typename _Tp >
constexpr _Res std::__invoke_impl (__invoke_memobj_ref, _MemPtr &&__f, _Tp &&__t)
 
template<typename _Res , typename _Fn , typename... _Args>
constexpr _Res std::__invoke_impl (__invoke_other, _Fn &&__f, _Args &&... __args)
 
template<typename _Res , typename _Callable , typename... _Args>
constexpr enable_if_t< is_invocable_r_v< _Res, _Callable, _Args... >, _Res > std::__invoke_r (_Callable &&__fn, _Args &&... __args) noexcept(is_nothrow_invocable_r_v< _Res, _Callable, _Args... >)
 
template<typename _Tp , typename _Tuple , size_t... _Idx>
constexpr _Tp std::__make_from_tuple_impl (_Tuple &&__t, index_sequence< _Idx... >)
 
void std::__throw_bad_any_cast ()
 
void std::__throw_bad_optional_access ()
 
static void std::any::_Manager_internal< _Tp >::_S_manage (_Op __which, const any *__anyp, _Arg *__arg)
 
static void std::any::_Manager_external< _Tp >::_S_manage (_Op __which, const any *__anyp, _Arg *__arg)
 
template<typename _Tp >
constexpr _Tp * std::addressof (_Tp &__r) noexcept
 
template<typename _Tp >
const _Tp * std::addressof (const _Tp &&)=delete
 
template<typename _ValueType >
_ValueType std::any_cast (const any &__any)
 
template<typename _Fn , typename _Tuple >
constexpr decltype(auto) std::apply (_Fn &&__f, _Tuple &&__t) noexcept(__unpack_std_tuple< is_nothrow_invocable, _Fn, _Tuple >)
 
template<typename _Tp >
auto std::declval () noexcept -> decltype(__declval< _Tp >(0))
 
template<typename _Tp >
constexpr _Tp && std::forward (typename std::remove_reference< _Tp >::type &&__t) noexcept
 
template<typename _Tp >
constexpr _Tp && std::forward (typename std::remove_reference< _Tp >::type &__t) noexcept
 
template<typename... _Elements>
constexpr tuple< _Elements &&... > std::forward_as_tuple (_Elements &&... __args) noexcept
 
template<std::size_t _Int, typename _Tp , std::size_t _Nm>
constexpr _Tp && std::get (array< _Tp, _Nm > &&__arr) noexcept
 
template<std::size_t _Int, typename _Tp , std::size_t _Nm>
constexpr _Tp & std::get (array< _Tp, _Nm > &__arr) noexcept
 
template<std::size_t _Int, typename _Tp , std::size_t _Nm>
constexpr const _Tp && std::get (const array< _Tp, _Nm > &&__arr) noexcept
 
template<std::size_t _Int, typename _Tp , std::size_t _Nm>
constexpr const _Tp & std::get (const array< _Tp, _Nm > &__arr) noexcept
 
template<size_t __i, typename... _Elements>
constexpr const __tuple_element_t< __i, tuple< _Elements... > > && std::get (const tuple< _Elements... > &&__t) noexcept
 
template<size_t __i, typename... _Elements>
constexpr const __tuple_element_t< __i, tuple< _Elements... > > & std::get (const tuple< _Elements... > &__t) noexcept
 
template<typename _Tp , typename... _Types>
constexpr const _Tp && std::get (const tuple< _Types... > &&__t) noexcept
 
template<typename _Tp , typename... _Types>
constexpr const _Tp & std::get (const tuple< _Types... > &__t) noexcept
 
template<size_t __i, typename... _Elements>
constexpr __tuple_element_t< __i, tuple< _Elements... > > && std::get (tuple< _Elements... > &&__t) noexcept
 
template<size_t __i, typename... _Elements>
constexpr __tuple_element_t< __i, tuple< _Elements... > > & std::get (tuple< _Elements... > &__t) noexcept
 
template<typename _Tp , typename... _Types>
constexpr _Tp && std::get (tuple< _Types... > &&__t) noexcept
 
template<typename _Tp , typename... _Types>
constexpr _Tp & std::get (tuple< _Types... > &__t) noexcept
 
template<typename _Tp , typename... _Args>
enable_if_t< is_constructible_v< any, in_place_type_t< _Tp >, _Args... >, anystd::make_any (_Args &&... __args)
 
template<typename _Tp , typename _Up , typename... _Args>
enable_if_t< is_constructible_v< any, in_place_type_t< _Tp >, initializer_list< _Up > &, _Args... >, anystd::make_any (initializer_list< _Up > __il, _Args &&... __args)
 
template<typename _Tp , typename _Tuple >
constexpr _Tp std::make_from_tuple (_Tuple &&__t) noexcept(__unpack_std_tuple< is_nothrow_constructible, _Tp, _Tuple >)
 
template<typename _Tp , typename... _Args>
constexpr enable_if_t< is_constructible_v< _Tp, _Args... >, optional< _Tp > > std::make_optional (_Args &&... __args) noexcept(is_nothrow_constructible_v< _Tp, _Args... >)
 
template<typename _Tp >
constexpr enable_if_t< is_constructible_v< decay_t< _Tp >, _Tp >, optional< decay_t< _Tp > > > std::make_optional (_Tp &&__t) noexcept(is_nothrow_constructible_v< optional< decay_t< _Tp > >, _Tp >)
 
template<typename _Tp , typename _Up , typename... _Args>
constexpr enable_if_t< is_constructible_v< _Tp, initializer_list< _Up > &, _Args... >, optional< _Tp > > std::make_optional (initializer_list< _Up > __il, _Args &&... __args) noexcept(is_nothrow_constructible_v< _Tp, initializer_list< _Up > &, _Args... >)
 
template<typename _T1 , typename _T2 >
constexpr pair< typename __decay_and_strip< _T1 >::__type, typename __decay_and_strip< _T2 >::__type > make_pair (_T1 &&__x, _T2 &&__y)
 
template<typename... _Elements>
constexpr tuple< typename __decay_and_strip< _Elements >::__type... > std::make_tuple (_Elements &&... __args)
 
template<typename _Tp >
constexpr std::remove_reference< _Tp >::type && std::move (_Tp &&__t) noexcept
 
template<typename _Tp >
constexpr __conditional_t< __move_if_noexcept_cond< _Tp >::value, const _Tp &, _Tp && > std::move_if_noexcept (_Tp &__x) noexcept
 
template<typename _Tp , typename _Up >
constexpr auto std::operator!= (const _Up &__lhs, const optional< _Tp > &__rhs) -> __optional_ne_t< _Up, _Tp >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator!= (const optional< _Tp > &__lhs, const _Up &__rhs) -> __optional_ne_t< _Tp, _Up >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator!= (const optional< _Tp > &__lhs, const optional< _Up > &__rhs) -> __optional_ne_t< _Tp, _Up >
 
template<typename _Tp >
constexpr bool std::operator!= (const optional< _Tp > &__lhs, nullopt_t) noexcept
 
template<typename... _TElements, typename... _UElements>
constexpr bool std::operator!= (const tuple< _TElements... > &__t, const tuple< _UElements... > &__u)
 
template<typename _Tp >
constexpr bool std::operator!= (nullopt_t, const optional< _Tp > &__rhs) noexcept
 
template<typename _Tp , typename _Up >
constexpr auto std::operator< (const _Up &__lhs, const optional< _Tp > &__rhs) -> __optional_lt_t< _Up, _Tp >
 
template<typename _Tp >
constexpr bool std::operator< (const optional< _Tp > &, nullopt_t) noexcept
 
template<typename _Tp , typename _Up >
constexpr auto std::operator< (const optional< _Tp > &__lhs, const _Up &__rhs) -> __optional_lt_t< _Tp, _Up >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator< (const optional< _Tp > &__lhs, const optional< _Up > &__rhs) -> __optional_lt_t< _Tp, _Up >
 
template<typename... _TElements, typename... _UElements>
constexpr bool std::operator< (const tuple< _TElements... > &__t, const tuple< _UElements... > &__u)
 
template<typename _Tp >
constexpr bool std::operator< (nullopt_t, const optional< _Tp > &__rhs) noexcept
 
template<typename _Tp , typename _Up >
constexpr auto std::operator<= (const _Up &__lhs, const optional< _Tp > &__rhs) -> __optional_le_t< _Up, _Tp >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator<= (const optional< _Tp > &__lhs, const _Up &__rhs) -> __optional_le_t< _Tp, _Up >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator<= (const optional< _Tp > &__lhs, const optional< _Up > &__rhs) -> __optional_le_t< _Tp, _Up >
 
template<typename _Tp >
constexpr bool std::operator<= (const optional< _Tp > &__lhs, nullopt_t) noexcept
 
template<typename... _TElements, typename... _UElements>
constexpr bool std::operator<= (const tuple< _TElements... > &__t, const tuple< _UElements... > &__u)
 
template<typename _Tp >
constexpr bool std::operator<= (nullopt_t, const optional< _Tp > &) noexcept
 
template<typename _Tp , typename _Up >
constexpr auto std::operator== (const _Up &__lhs, const optional< _Tp > &__rhs) -> __optional_eq_t< _Up, _Tp >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator== (const optional< _Tp > &__lhs, const _Up &__rhs) -> __optional_eq_t< _Tp, _Up >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator== (const optional< _Tp > &__lhs, const optional< _Up > &__rhs) -> __optional_eq_t< _Tp, _Up >
 
template<typename _Tp >
constexpr bool std::operator== (const optional< _Tp > &__lhs, nullopt_t) noexcept
 
template<typename... _TElements, typename... _UElements>
constexpr bool std::operator== (const tuple< _TElements... > &__t, const tuple< _UElements... > &__u)
 
template<typename _Tp >
constexpr bool std::operator== (nullopt_t, const optional< _Tp > &__rhs) noexcept
 
template<typename _Tp , typename _Up >
constexpr auto std::operator> (const _Up &__lhs, const optional< _Tp > &__rhs) -> __optional_gt_t< _Up, _Tp >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator> (const optional< _Tp > &__lhs, const _Up &__rhs) -> __optional_gt_t< _Tp, _Up >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator> (const optional< _Tp > &__lhs, const optional< _Up > &__rhs) -> __optional_gt_t< _Tp, _Up >
 
template<typename _Tp >
constexpr bool std::operator> (const optional< _Tp > &__lhs, nullopt_t) noexcept
 
template<typename... _TElements, typename... _UElements>
constexpr bool std::operator> (const tuple< _TElements... > &__t, const tuple< _UElements... > &__u)
 
template<typename _Tp >
constexpr bool std::operator> (nullopt_t, const optional< _Tp > &) noexcept
 
template<typename _Tp , typename _Up >
constexpr auto std::operator>= (const _Up &__lhs, const optional< _Tp > &__rhs) -> __optional_ge_t< _Up, _Tp >
 
template<typename _Tp >
constexpr bool std::operator>= (const optional< _Tp > &, nullopt_t) noexcept
 
template<typename _Tp , typename _Up >
constexpr auto std::operator>= (const optional< _Tp > &__lhs, const _Up &__rhs) -> __optional_ge_t< _Tp, _Up >
 
template<typename _Tp , typename _Up >
constexpr auto std::operator>= (const optional< _Tp > &__lhs, const optional< _Up > &__rhs) -> __optional_ge_t< _Tp, _Up >
 
template<typename... _TElements, typename... _UElements>
constexpr bool std::operator>= (const tuple< _TElements... > &__t, const tuple< _UElements... > &__u)
 
template<typename _Tp >
constexpr bool std::operator>= (nullopt_t, const optional< _Tp > &__rhs) noexcept
 
template<typename _Tp >
constexpr enable_if< __and_< __not_< __is_tuple_like< _Tp > >, is_move_constructible< _Tp >, is_move_assignable< _Tp > >::value >::type std::swap (_Tp &__a, _Tp &__b) noexcept(/*conditional */) is_nothrow_move_assignable< _Tp > >
 
template<typename _Tp , size_t _Nm>
constexpr enable_if< __is_swappable< _Tp >::value >::type std::swap (_Tp(&__a)[_Nm], _Tp(&__b)[_Nm]) noexcept(/*conditional */)
 
void std::swap (any &__x, any &__y) noexcept
 
template<typename _Tp >
constexpr enable_if_t< is_move_constructible_v< _Tp > &&is_swappable_v< _Tp > > std::swap (optional< _Tp > &__lhs, optional< _Tp > &__rhs) noexcept(noexcept(__lhs.swap(__rhs)))
 
template<typename... _Elements>
constexpr enable_if< __and_< __is_swappable< _Elements >... >::value >::type std::swap (tuple< _Elements... > &__x, tuple< _Elements... > &__y) noexcept(noexcept(__x.swap(__y)))
 
template<typename... _Elements>
constexpr tuple< _Elements &... > std::tie (_Elements &... __args) noexcept
 
template<typename... _UTypes>
 std::tuple (_UTypes...) -> tuple< _UTypes... >
 
template<typename _Alloc , typename... _UTypes>
 std::tuple (allocator_arg_t, _Alloc, _UTypes...) -> tuple< _UTypes... >
 
template<typename _Alloc , typename _T1 , typename _T2 >
 std::tuple (allocator_arg_t, _Alloc, pair< _T1, _T2 >) -> tuple< _T1, _T2 >
 
template<typename _Alloc , typename... _UTypes>
 std::tuple (allocator_arg_t, _Alloc, tuple< _UTypes... >) -> tuple< _UTypes... >
 
template<typename _T1 , typename _T2 >
 std::tuple (pair< _T1, _T2 >) -> tuple< _T1, _T2 >
 
template<typename... _Tpls, typename = typename enable_if<__and_<__is_tuple_like<_Tpls>...>::value>::type>
constexpr auto std::tuple_cat (_Tpls &&... __tpls) -> typename __tuple_cat_result< _Tpls... >::__type
 

Variables

template<typename _Tp >
constexpr bool std::__is_optional_v
 
template<typename _Tp >
constexpr bool std::__is_optional_v< optional< _Tp > >
 
template<template< typename... > class _Trait, typename _Tp , typename _Tuple >
constexpr bool std::__unpack_std_tuple
 
template<template< typename... > class _Trait, typename _Tp , typename... _Up>
constexpr bool std::__unpack_std_tuple< _Trait, _Tp, const tuple< _Up... > & >
 
template<template< typename... > class _Trait, typename _Tp , typename... _Up>
constexpr bool std::__unpack_std_tuple< _Trait, _Tp, const tuple< _Up... > >
 
template<template< typename... > class _Trait, typename _Tp , typename... _Up>
constexpr bool std::__unpack_std_tuple< _Trait, _Tp, tuple< _Up... > & >
 
template<template< typename... > class _Trait, typename _Tp , typename... _Up>
constexpr bool std::__unpack_std_tuple< _Trait, _Tp, tuple< _Up... > >
 
constexpr _Swallow_assign std::ignore
 
constexpr nullopt_t std::nullopt
 
constexpr piecewise_construct_t std::piecewise_construct
 
template<typename... _Types>
constexpr size_t std::tuple_size_v< const tuple< _Types... > >
 
template<typename... _Types>
constexpr size_t std::tuple_size_v< tuple< _Types... > >
 
template<typename _ValueType >
_ValueType std::any_cast (any &__any)
 
template<typename _ValueType >
_ValueType std::any_cast (any &&__any)
 
template<typename _ValueType >
const _ValueType * std::any_cast (const any *__any) noexcept
 
template<typename _ValueType >
_ValueType * std::any_cast (any *__any) noexcept
 
template<typename _T1 , typename _T2 >
 pair (_T1, _T2) -> pair< _T1, _T2 >
 
template<typename _T1 , typename _T2 >
constexpr bool operator== (const pair< _T1, _T2 > &__x, const pair< _T1, _T2 > &__y)
 
template<typename _T1 , typename _T2 >
constexpr bool operator< (const pair< _T1, _T2 > &__x, const pair< _T1, _T2 > &__y)
 
template<typename _T1 , typename _T2 >
constexpr bool operator!= (const pair< _T1, _T2 > &__x, const pair< _T1, _T2 > &__y)
 
template<typename _T1 , typename _T2 >
constexpr bool operator> (const pair< _T1, _T2 > &__x, const pair< _T1, _T2 > &__y)
 
template<typename _T1 , typename _T2 >
constexpr bool operator<= (const pair< _T1, _T2 > &__x, const pair< _T1, _T2 > &__y)
 
template<typename _T1 , typename _T2 >
constexpr bool operator>= (const pair< _T1, _T2 > &__x, const pair< _T1, _T2 > &__y)
 
template<typename _T1 , typename _T2 >
constexpr enable_if< __and_< __is_swappable< _T1 >, __is_swappable< _T2 > >::value >::type swap (pair< _T1, _T2 > &__x, pair< _T1, _T2 > &__y) noexcept(noexcept(__x.swap(__y)))
 

Detailed Description

Basic function and class templates used with the rest of the library. Includes pair, swap, forward/move helpers, declval, integer_sequence.

Macro Definition Documentation

◆ __cpp_lib_addressof_constexpr

#define __cpp_lib_addressof_constexpr

Definition at line 133 of file move.h.

◆ __cpp_lib_any

#define __cpp_lib_any

Definition at line 70 of file any.

◆ __cpp_lib_apply

#define __cpp_lib_apply

Definition at line 2263 of file tuple.

◆ __cpp_lib_make_from_tuple

#define __cpp_lib_make_from_tuple

Definition at line 2285 of file tuple.

◆ __cpp_lib_optional

#define __cpp_lib_optional

Definition at line 66 of file optional.

◆ __cpp_lib_tuples_by_type

#define __cpp_lib_tuples_by_type

Definition at line 1824 of file tuple.

Typedef Documentation

◆ __assigns_from_optional

template<typename _Tp , typename _Up >
using std::__assigns_from_optional = typedef __or_<is_assignable<_Tp&, const optional<_Up>&>, is_assignable<_Tp&, optional<_Up>&>, is_assignable<_Tp&, const optional<_Up>&&>, is_assignable<_Tp&, optional<_Up>&&> >

Definition at line 695 of file optional.

◆ __converts_from_optional

template<typename _Tp , typename _Up >
using std::__converts_from_optional = typedef __or_<is_constructible<_Tp, const optional<_Up>&>, is_constructible<_Tp, optional<_Up>&>, is_constructible<_Tp, const optional<_Up>&&>, is_constructible<_Tp, optional<_Up>&&>, is_convertible<const optional<_Up>&, _Tp>, is_convertible<optional<_Up>&, _Tp>, is_convertible<const optional<_Up>&&, _Tp>, is_convertible<optional<_Up>&&, _Tp> >

Definition at line 684 of file optional.

◆ __empty_not_final

template<typename _Tp >
using std::__empty_not_final = typedef __conditional_t<__is_final(_Tp), false_type, __is_empty_non_tuple<_Tp> >

Definition at line 68 of file tuple.

◆ __optional_eq_t

template<typename _Tp , typename _Up >
using std::__optional_eq_t = typedef __optional_relop_t< decltype(std::declval<const _Tp&>() == std::declval<const _Up&>()) >

Definition at line 1190 of file optional.

◆ __optional_ge_t

template<typename _Tp , typename _Up >
using std::__optional_ge_t = typedef __optional_relop_t< decltype(std::declval<const _Tp&>() >= std::declval<const _Up&>()) >

Definition at line 1215 of file optional.

◆ __optional_gt_t

template<typename _Tp , typename _Up >
using std::__optional_gt_t = typedef __optional_relop_t< decltype(std::declval<const _Tp&>() > std::declval<const _Up&>()) >

Definition at line 1205 of file optional.

◆ __optional_le_t

template<typename _Tp , typename _Up >
using std::__optional_le_t = typedef __optional_relop_t< decltype(std::declval<const _Tp&>() <= std::declval<const _Up&>()) >

Definition at line 1210 of file optional.

◆ __optional_lt_t

template<typename _Tp , typename _Up >
using std::__optional_lt_t = typedef __optional_relop_t< decltype(std::declval<const _Tp&>() < std::declval<const _Up&>()) >

Definition at line 1200 of file optional.

◆ __optional_ne_t

template<typename _Tp , typename _Up >
using std::__optional_ne_t = typedef __optional_relop_t< decltype(std::declval<const _Tp&>() != std::declval<const _Up&>()) >

Definition at line 1195 of file optional.

◆ __optional_relop_t

template<typename _Tp >
using std::__optional_relop_t = typedef enable_if_t<is_convertible<_Tp, bool>::value, bool>

Definition at line 1186 of file optional.

Function Documentation

◆ pair() [1/2]

template<typename _T1 , typename _T2 >
pair ( _T1  ,
_T2   
) -> pair< _T1, _T2 >
related

Two pairs of the same type are equal iff their members are equal.

◆ pair() [2/2]

template<class _T1 , class _T2 >
template<typename... _Args1, typename... _Args2>
constexpr std::pair< _T1, _T2 >::pair ( piecewise_construct_t  ,
tuple< _Args1... >  __first,
tuple< _Args2... >  __second 
)
inlineconstexpr

"piecewise construction" using a tuple of arguments for each member.

Parameters
__firstArguments for the first member of the pair.
__secondArguments for the second member of the pair.

The elements of each tuple will be used as the constructor arguments for the data members of the pair.

Definition at line 2219 of file tuple.

◆ __addressof()

◆ __apply_impl()

template<typename _Fn , typename _Tuple , size_t... _Idx>
constexpr decltype(auto) std::__apply_impl ( _Fn &&  __f,
_Tuple &&  __t,
index_sequence< _Idx... >   
)
constexpr

Definition at line 2267 of file tuple.

◆ __exchange()

template<typename _Tp , typename _Up = _Tp>
constexpr _Tp std::__exchange ( _Tp &  __obj,
_Up &&  __new_val 
)
inlineconstexpr

Definition at line 157 of file move.h.

◆ __get_helper() [1/2]

template<size_t __i, typename _Head , typename... _Tail>
constexpr _Head & std::__get_helper ( _Tuple_impl< __i, _Head, _Tail... > &  __t)
constexprnoexcept

Definition at line 1772 of file tuple.

◆ __get_helper() [2/2]

template<size_t __i, typename _Head , typename... _Tail>
constexpr const _Head & std::__get_helper ( const _Tuple_impl< __i, _Head, _Tail... > &  __t)
constexprnoexcept

Definition at line 1777 of file tuple.

◆ __invfwd()

template<typename _Tp , typename _Up = typename __inv_unwrap<_Tp>::type>
constexpr _Up && std::__invfwd ( typename remove_reference< _Tp >::type &  __t)
constexprnoexcept

Definition at line 55 of file invoke.h.

◆ __invoke()

template<typename _Callable , typename... _Args>
constexpr __invoke_result< _Callable, _Args... >::type std::__invoke ( _Callable &&  __fn,
_Args &&...  __args 
)
constexprnoexcept

Invoke a callable object.

Definition at line 90 of file invoke.h.

Referenced by std::invoke().

◆ __invoke_impl() [1/5]

template<typename _Res , typename _MemFun , typename _Tp , typename... _Args>
constexpr _Res std::__invoke_impl ( __invoke_memfun_deref  ,
_MemFun &&  __f,
_Tp &&  __t,
_Args &&...  __args 
)
constexpr

Definition at line 71 of file invoke.h.

◆ __invoke_impl() [2/5]

template<typename _Res , typename _MemFun , typename _Tp , typename... _Args>
constexpr _Res std::__invoke_impl ( __invoke_memfun_ref  ,
_MemFun &&  __f,
_Tp &&  __t,
_Args &&...  __args 
)
constexpr

Definition at line 65 of file invoke.h.

◆ __invoke_impl() [3/5]

template<typename _Res , typename _MemPtr , typename _Tp >
constexpr _Res std::__invoke_impl ( __invoke_memobj_deref  ,
_MemPtr &&  __f,
_Tp &&  __t 
)
constexpr

Definition at line 84 of file invoke.h.

◆ __invoke_impl() [4/5]

template<typename _Res , typename _MemPtr , typename _Tp >
constexpr _Res std::__invoke_impl ( __invoke_memobj_ref  ,
_MemPtr &&  __f,
_Tp &&  __t 
)
constexpr

Definition at line 79 of file invoke.h.

◆ __invoke_impl() [5/5]

template<typename _Res , typename _Fn , typename... _Args>
constexpr _Res std::__invoke_impl ( __invoke_other  ,
_Fn &&  __f,
_Args &&...  __args 
)
constexpr

Definition at line 60 of file invoke.h.

◆ __invoke_r()

template<typename _Res , typename _Callable , typename... _Args>
constexpr enable_if_t< is_invocable_r_v< _Res, _Callable, _Args... >, _Res > std::__invoke_r ( _Callable &&  __fn,
_Args &&...  __args 
)
constexprnoexcept

Definition at line 104 of file invoke.h.

◆ __make_from_tuple_impl()

template<typename _Tp , typename _Tuple , size_t... _Idx>
constexpr _Tp std::__make_from_tuple_impl ( _Tuple &&  __t,
index_sequence< _Idx... >   
)
constexpr

Definition at line 2289 of file tuple.

◆ __throw_bad_any_cast()

void std::__throw_bad_any_cast ( )
inline

Definition at line 61 of file any.

◆ __throw_bad_optional_access()

void std::__throw_bad_optional_access ( )
inline

Definition at line 110 of file optional.

◆ _S_manage() [1/2]

template<typename _Tp >
void std::any::_Manager_internal< _Tp >::_S_manage ( _Op  __which,
const any __anyp,
_Arg *  __arg 
)
static

Definition at line 574 of file any.

◆ _S_manage() [2/2]

template<typename _Tp >
void std::any::_Manager_external< _Tp >::_S_manage ( _Op  __which,
const any __anyp,
_Arg *  __arg 
)
static

Definition at line 608 of file any.

◆ addressof()

template<typename _Tp >
constexpr _Tp * std::addressof ( _Tp &  __r)
inlineconstexprnoexcept

Returns the actual address of the object or function referenced by r, even in the presence of an overloaded operator&.

Parameters
__rReference to an object or function.
Returns
The actual address.

Definition at line 145 of file move.h.

References std::__addressof().

◆ any_cast() [1/5]

template<typename _ValueType >
_ValueType std::any_cast ( any &&  __any)
inline

Access the contained object.

Template Parameters
_ValueTypeA reference or CopyConstructible type.
Parameters
__anyThe object to access.
Returns
The contained object.
Exceptions
bad_any_castIf __any.type() != typeid(remove_reference_t<_ValueType>)

Definition at line 501 of file any.

References std::move().

◆ any_cast() [2/5]

template<typename _ValueType >
_ValueType std::any_cast ( any __any)
inline

Access the contained object.

Template Parameters
_ValueTypeA reference or CopyConstructible type.
Parameters
__anyThe object to access.
Returns
The contained object.
Exceptions
bad_any_castIf __any.type() != typeid(remove_reference_t<_ValueType>)

Definition at line 487 of file any.

◆ any_cast() [3/5]

template<typename _ValueType >
_ValueType * std::any_cast ( any __any)
inlinenoexcept

Access the contained object.

Template Parameters
_ValueTypeThe type of the contained object.
Parameters
__anyA pointer to the object to access.
Returns
The address of the contained object if __any != nullptr && __any.type() == typeid(_ValueType) , otherwise a null pointer.

Definition at line 563 of file any.

◆ any_cast() [4/5]

template<typename _ValueType >
_ValueType std::any_cast ( const any __any)
inline

Access the contained object.

Template Parameters
_ValueTypeA const-reference or CopyConstructible type.
Parameters
__anyThe object to access.
Returns
The contained object.
Exceptions
bad_any_castIf __any.type() != typeid(remove_reference_t<_ValueType>)

Definition at line 461 of file any.

◆ any_cast() [5/5]

template<typename _ValueType >
const _ValueType * std::any_cast ( const any __any)
inlinenoexcept

Access the contained object.

Template Parameters
_ValueTypeThe type of the contained object.
Parameters
__anyA pointer to the object to access.
Returns
The address of the contained object if __any != nullptr && __any.type() == typeid(_ValueType) , otherwise a null pointer.

Definition at line 554 of file any.

◆ apply()

template<typename _Fn , typename _Tuple >
constexpr decltype(auto) std::apply ( _Fn &&  __f,
_Tuple &&  __t 
)
constexprnoexcept

Definition at line 2275 of file tuple.

◆ declval()

template<typename _Tp >
auto std::declval ( ) -> decltype(__declval< _Tp >(0))
noexcept

Utility to simplify expressions used in unevaluated operands

Since
C++11

Definition at line 2327 of file type_traits.

◆ forward() [1/2]

template<typename _Tp >
constexpr _Tp && std::forward ( typename std::remove_reference< _Tp >::type &&  __t)
constexprnoexcept

Forward an rvalue.

Returns
The parameter cast to the specified type.

This function is used to implement "perfect forwarding".

Definition at line 89 of file move.h.

◆ forward() [2/2]

template<typename _Tp >
constexpr _Tp && std::forward ( typename std::remove_reference< _Tp >::type &  __t)
constexprnoexcept

Forward an lvalue.

Returns
The parameter cast to the specified type.

This function is used to implement "perfect forwarding".

Definition at line 77 of file move.h.

◆ forward_as_tuple()

template<typename... _Elements>
constexpr tuple< _Elements &&... > std::forward_as_tuple ( _Elements &&...  __args)
constexprnoexcept

◆ get() [1/12]

template<std::size_t _Int, typename _Tp , std::size_t _Nm>
constexpr _Tp && std::get ( array< _Tp, _Nm > &&  __arr)
constexprnoexcept

Definition at line 393 of file array.

◆ get() [2/12]

template<std::size_t _Int, typename _Tp , std::size_t _Nm>
constexpr _Tp & std::get ( array< _Tp, _Nm > &  __arr)
constexprnoexcept

Definition at line 384 of file array.

◆ get() [3/12]

template<std::size_t _Int, typename _Tp , std::size_t _Nm>
constexpr const _Tp && std::get ( const array< _Tp, _Nm > &&  __arr)
constexprnoexcept

Definition at line 411 of file array.

◆ get() [4/12]

template<std::size_t _Int, typename _Tp , std::size_t _Nm>
constexpr const _Tp & std::get ( const array< _Tp, _Nm > &  __arr)
constexprnoexcept

Definition at line 402 of file array.

◆ get() [5/12]

template<size_t __i, typename... _Elements>
constexpr const __tuple_element_t< __i, tuple< _Elements... > > && std::get ( const tuple< _Elements... > &&  __t)
constexprnoexcept

Return a const rvalue reference to the ith element of a const tuple rvalue.

Definition at line 1809 of file tuple.

◆ get() [6/12]

template<size_t __i, typename... _Elements>
constexpr const __tuple_element_t< __i, tuple< _Elements... > > & std::get ( const tuple< _Elements... > &  __t)
constexprnoexcept

Return a const reference to the ith element of a const tuple.

Definition at line 1794 of file tuple.

◆ get() [7/12]

template<typename _Tp , typename... _Types>
constexpr const _Tp && std::get ( const tuple< _Types... > &&  __t)
constexprnoexcept

Return a const reference to the unique element of type _Tp of a const tuple rvalue.

Definition at line 1863 of file tuple.

◆ get() [8/12]

template<typename _Tp , typename... _Types>
constexpr const _Tp & std::get ( const tuple< _Types... > &  __t)
constexprnoexcept

Return a const reference to the unique element of type _Tp of a tuple.

Definition at line 1851 of file tuple.

◆ get() [9/12]

template<size_t __i, typename... _Elements>
constexpr __tuple_element_t< __i, tuple< _Elements... > > && std::get ( tuple< _Elements... > &&  __t)
constexprnoexcept

Return an rvalue reference to the ith element of a tuple rvalue.

Definition at line 1800 of file tuple.

◆ get() [10/12]

template<size_t __i, typename... _Elements>
constexpr __tuple_element_t< __i, tuple< _Elements... > > & std::get ( tuple< _Elements... > &  __t)
constexprnoexcept

Return a reference to the ith element of a tuple.

Definition at line 1788 of file tuple.

◆ get() [11/12]

template<typename _Tp , typename... _Types>
constexpr _Tp && std::get ( tuple< _Types... > &&  __t)
constexprnoexcept

Return a reference to the unique element of type _Tp of a tuple rvalue.

Definition at line 1840 of file tuple.

◆ get() [12/12]

template<typename _Tp , typename... _Types>
constexpr _Tp & std::get ( tuple< _Types... > &  __t)
constexprnoexcept

Return a reference to the unique element of type _Tp of a tuple.

Definition at line 1829 of file tuple.

◆ make_any() [1/2]

template<typename _Tp , typename... _Args>
enable_if_t< is_constructible_v< any, in_place_type_t< _Tp >, _Args... >, any > std::make_any ( _Args &&...  __args)
inline

Create an any holding a _Tp constructed from __args....

Definition at line 435 of file any.

◆ make_any() [2/2]

template<typename _Tp , typename _Up , typename... _Args>
enable_if_t< is_constructible_v< any, in_place_type_t< _Tp >, initializer_list< _Up > &, _Args... >, any > std::make_any ( initializer_list< _Up >  __il,
_Args &&...  __args 
)
inline

Create an any holding a _Tp constructed from __il and __args....

Definition at line 445 of file any.

◆ make_from_tuple()

template<typename _Tp , typename _Tuple >
constexpr _Tp std::make_from_tuple ( _Tuple &&  __t)
constexprnoexcept

Definition at line 2294 of file tuple.

◆ make_optional() [1/3]

template<typename _Tp , typename... _Args>
constexpr enable_if_t< is_constructible_v< _Tp, _Args... >, optional< _Tp > > std::make_optional ( _Args &&...  __args)
constexprnoexcept

Definition at line 1456 of file optional.

◆ make_optional() [2/3]

template<typename _Tp >
constexpr enable_if_t< is_constructible_v< decay_t< _Tp >, _Tp >, optional< decay_t< _Tp > > > std::make_optional ( _Tp &&  __t)
constexprnoexcept

Definition at line 1448 of file optional.

◆ make_optional() [3/3]

template<typename _Tp , typename _Up , typename... _Args>
constexpr enable_if_t< is_constructible_v< _Tp, initializer_list< _Up > &, _Args... >, optional< _Tp > > std::make_optional ( initializer_list< _Up >  __il,
_Args &&...  __args 
)
constexprnoexcept

Definition at line 1464 of file optional.

◆ make_pair()

template<typename _T1 , typename _T2 >
constexpr pair< typename __decay_and_strip< _T1 >::__type, typename __decay_and_strip< _T2 >::__type > make_pair ( _T1 &&  __x,
_T2 &&  __y 
)
related

A convenience wrapper for creating a pair from two objects.

Parameters
__xThe first object.
__yThe second object.
Returns
A newly-constructed pair<> object of the appropriate type.

The C++98 standard says the objects are passed by reference-to-const, but C++03 says they are passed by value (this was LWG issue #181).

Since C++11 they have been passed by forwarding reference and then forwarded to the new members of the pair. To create a pair with a member of reference type, pass a reference_wrapper to this function.

Definition at line 840 of file stl_pair.h.

◆ make_tuple()

template<typename... _Elements>
constexpr tuple< typename __decay_and_strip< _Elements >::__type... > std::make_tuple ( _Elements &&...  __args)
constexpr

Definition at line 1985 of file tuple.

◆ move()

template<typename _Tp >
constexpr std::remove_reference< _Tp >::type && std::move ( _Tp &&  __t)
constexprnoexcept

Convert a value to an rvalue.

Parameters
__tA thing of arbitrary type.
Returns
The parameter cast to an rvalue-reference to allow moving it.

Definition at line 104 of file move.h.

Referenced by std::unique_ptr< _Tp, _Dp >::~unique_ptr(), std::any_cast(), std::experimental::any_cast(), std::basic_regex< _Ch_type, _Rx_traits >::assign(), std::atomic_compare_exchange_strong(), std::atomic_compare_exchange_strong_explicit(), std::atomic_compare_exchange_weak(), std::atomic_compare_exchange_weak_explicit(), std::atomic_exchange(), std::atomic_store(), std::shared_ptr< _Tp >::const_pointer_cast(), std::shared_ptr< _Tp >::dynamic_pointer_cast(), std::exclusive_scan(), std::for_each_n(), std::future< _Res >::get(), std::get(), std::inclusive_scan(), std::deque< _Tp, _Alloc >::insert(), std::list< _Tp, _Alloc >::insert(), std::vector< _Tp, _Alloc >::insert(), std::map< _Key, _Tp, _Compare, _Alloc >::insert(), std::multiset< _Key, _Compare, _Alloc >::insert(), std::set< _Key, _Compare, _Alloc >::insert(), std::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::insert(), std::multimap< _Key, _Tp, _Compare, _Alloc >::insert(), std::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::insert(), std::unordered_set< _Value, _Hash, _Pred, _Alloc >::insert(), std::unordered_multiset< _Value, _Hash, _Pred, _Alloc >::insert(), std::experimental::make_boyer_moore_horspool_searcher(), std::experimental::make_boyer_moore_searcher(), std::forward_list< _Tp, _Alloc >::merge(), std::move_if_noexcept(), std::tr2::dynamic_bitset< _WordT, _Alloc >::operator&=(), std::deque< _Tp, _Alloc >::operator=(), std::forward_list< _Tp, _Alloc >::operator=(), std::function< _Res(_ArgTypes...)>::operator=(), std::list< _Tp, _Alloc >::operator=(), std::vector< _Tp, _Alloc >::operator=(), std::operator>>(), std::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::operator[](), std::reduce(), std::shared_ptr< _Tp >::reinterpret_pointer_cast(), std::unique_ptr< _Tp[], _Dp >::reset(), std::unique_ptr< _Tp, _Dp >::reset(), std::list< _Tp, _Alloc >::splice(), std::shared_ptr< _Tp >::static_pointer_cast(), std::transform_exclusive_scan(), std::transform_inclusive_scan(), and std::transform_reduce().

◆ move_if_noexcept()

template<typename _Tp >
constexpr __conditional_t< __move_if_noexcept_cond< _Tp >::value, const _Tp &, _Tp && > std::move_if_noexcept ( _Tp &  __x)
constexprnoexcept

Conditionally convert a value to an rvalue.

Parameters
__xA thing of arbitrary type.
Returns
The parameter, possibly cast to an rvalue-reference.

Same as std::move unless the type's move constructor could throw and the type is copyable, in which case an lvalue-reference is returned instead.

Definition at line 125 of file move.h.

References std::move().

◆ operator!=() [1/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator!= ( const _Up &  __lhs,
const optional< _Tp > &  __rhs 
) -> __optional_ne_t<_Up, _Tp>
constexpr

Definition at line 1368 of file optional.

◆ operator!=() [2/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator!= ( const optional< _Tp > &  __lhs,
const _Up &  __rhs 
) -> __optional_ne_t<_Tp, _Up>
constexpr

Definition at line 1362 of file optional.

◆ operator!=() [3/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator!= ( const optional< _Tp > &  __lhs,
const optional< _Up > &  __rhs 
) -> __optional_ne_t<_Tp, _Up>
constexpr

Definition at line 1231 of file optional.

◆ operator!=() [4/7]

template<typename _Tp >
constexpr bool std::operator!= ( const optional< _Tp > &  __lhs,
nullopt_t   
)
constexprnoexcept

Definition at line 1298 of file optional.

◆ operator!=() [5/7]

template<typename _T1 , typename _T2 >
constexpr bool operator!= ( const pair< _T1, _T2 > &  __x,
const pair< _T1, _T2 > &  __y 
)
related

Uses operator== to find the result.

Definition at line 760 of file stl_pair.h.

◆ operator!=() [6/7]

template<typename... _TElements, typename... _UElements>
constexpr bool std::operator!= ( const tuple< _TElements... > &  __t,
const tuple< _UElements... > &  __u 
)
constexpr

Definition at line 1959 of file tuple.

◆ operator!=() [7/7]

template<typename _Tp >
constexpr bool std::operator!= ( nullopt_t  ,
const optional< _Tp > &  __rhs 
)
constexprnoexcept

Definition at line 1303 of file optional.

◆ operator<() [1/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator< ( const _Up &  __lhs,
const optional< _Tp > &  __rhs 
) -> __optional_lt_t<_Up, _Tp>
constexpr

Definition at line 1379 of file optional.

◆ operator<() [2/7]

template<typename _Tp >
constexpr bool std::operator< ( const optional< _Tp > &  ,
nullopt_t   
)
constexprnoexcept

Definition at line 1307 of file optional.

◆ operator<() [3/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator< ( const optional< _Tp > &  __lhs,
const _Up &  __rhs 
) -> __optional_lt_t<_Tp, _Up>
constexpr

Definition at line 1373 of file optional.

◆ operator<() [4/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator< ( const optional< _Tp > &  __lhs,
const optional< _Up > &  __rhs 
) -> __optional_lt_t<_Tp, _Up>
constexpr

Definition at line 1239 of file optional.

◆ operator<() [5/7]

template<typename _T1 , typename _T2 >
constexpr bool operator< ( const pair< _T1, _T2 > &  __x,
const pair< _T1, _T2 > &  __y 
)
related

Defines a lexicographical order for pairs.

For two pairs of the same type, P is ordered before Q if P.first is less than Q.first, or if P.first and Q.first are equivalent (neither is less than the other) and P.second is less than Q.second.

Definition at line 752 of file stl_pair.h.

References std::pair< _T1, _T2 >::first, and std::pair< _T1, _T2 >::second.

◆ operator<() [6/7]

template<typename... _TElements, typename... _UElements>
constexpr bool std::operator< ( const tuple< _TElements... > &  __t,
const tuple< _UElements... > &  __u 
)
constexpr

Definition at line 1945 of file tuple.

◆ operator<() [7/7]

template<typename _Tp >
constexpr bool std::operator< ( nullopt_t  ,
const optional< _Tp > &  __rhs 
)
constexprnoexcept

Definition at line 1312 of file optional.

◆ operator<=() [1/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator<= ( const _Up &  __lhs,
const optional< _Tp > &  __rhs 
) -> __optional_le_t<_Up, _Tp>
constexpr

Definition at line 1403 of file optional.

◆ operator<=() [2/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator<= ( const optional< _Tp > &  __lhs,
const _Up &  __rhs 
) -> __optional_le_t<_Tp, _Up>
constexpr

Definition at line 1397 of file optional.

◆ operator<=() [3/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator<= ( const optional< _Tp > &  __lhs,
const optional< _Up > &  __rhs 
) -> __optional_le_t<_Tp, _Up>
constexpr

Definition at line 1255 of file optional.

◆ operator<=() [4/7]

template<typename _Tp >
constexpr bool std::operator<= ( const optional< _Tp > &  __lhs,
nullopt_t   
)
constexprnoexcept

Definition at line 1327 of file optional.

◆ operator<=() [5/7]

template<typename _T1 , typename _T2 >
constexpr bool operator<= ( const pair< _T1, _T2 > &  __x,
const pair< _T1, _T2 > &  __y 
)
related

Uses operator< to find the result.

Definition at line 771 of file stl_pair.h.

◆ operator<=() [6/7]

template<typename... _TElements, typename... _UElements>
constexpr bool std::operator<= ( const tuple< _TElements... > &  __t,
const tuple< _UElements... > &  __u 
)
constexpr

Definition at line 1970 of file tuple.

◆ operator<=() [7/7]

template<typename _Tp >
constexpr bool std::operator<= ( nullopt_t  ,
const optional< _Tp > &   
)
constexprnoexcept

Definition at line 1332 of file optional.

◆ operator==() [1/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator== ( const _Up &  __lhs,
const optional< _Tp > &  __rhs 
) -> __optional_eq_t<_Up, _Tp>
constexpr

Definition at line 1356 of file optional.

◆ operator==() [2/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator== ( const optional< _Tp > &  __lhs,
const _Up &  __rhs 
) -> __optional_eq_t<_Tp, _Up>
constexpr

Definition at line 1350 of file optional.

◆ operator==() [3/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator== ( const optional< _Tp > &  __lhs,
const optional< _Up > &  __rhs 
) -> __optional_eq_t<_Tp, _Up>
constexpr

Definition at line 1222 of file optional.

◆ operator==() [4/7]

template<typename _Tp >
constexpr bool std::operator== ( const optional< _Tp > &  __lhs,
nullopt_t   
)
constexprnoexcept

Definition at line 1282 of file optional.

◆ operator==() [5/7]

template<typename _T1 , typename _T2 >
constexpr bool operator== ( const pair< _T1, _T2 > &  __x,
const pair< _T1, _T2 > &  __y 
)
related

Two pairs of the same type are equal iff their members are equal.

Definition at line 730 of file stl_pair.h.

References std::pair< _T1, _T2 >::first, and std::pair< _T1, _T2 >::second.

◆ operator==() [6/7]

template<typename... _TElements, typename... _UElements>
constexpr bool std::operator== ( const tuple< _TElements... > &  __t,
const tuple< _UElements... > &  __u 
)
constexpr

Definition at line 1904 of file tuple.

◆ operator==() [7/7]

template<typename _Tp >
constexpr bool std::operator== ( nullopt_t  ,
const optional< _Tp > &  __rhs 
)
constexprnoexcept

Definition at line 1293 of file optional.

◆ operator>() [1/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator> ( const _Up &  __lhs,
const optional< _Tp > &  __rhs 
) -> __optional_gt_t<_Up, _Tp>
constexpr

Definition at line 1392 of file optional.

◆ operator>() [2/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator> ( const optional< _Tp > &  __lhs,
const _Up &  __rhs 
) -> __optional_gt_t<_Tp, _Up>
constexpr

Definition at line 1386 of file optional.

◆ operator>() [3/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator> ( const optional< _Tp > &  __lhs,
const optional< _Up > &  __rhs 
) -> __optional_gt_t<_Tp, _Up>
constexpr

Definition at line 1248 of file optional.

◆ operator>() [4/7]

template<typename _Tp >
constexpr bool std::operator> ( const optional< _Tp > &  __lhs,
nullopt_t   
)
constexprnoexcept

Definition at line 1318 of file optional.

◆ operator>() [5/7]

template<typename _T1 , typename _T2 >
constexpr bool operator> ( const pair< _T1, _T2 > &  __x,
const pair< _T1, _T2 > &  __y 
)
related

Uses operator< to find the result.

Definition at line 766 of file stl_pair.h.

◆ operator>() [6/7]

template<typename... _TElements, typename... _UElements>
constexpr bool std::operator> ( const tuple< _TElements... > &  __t,
const tuple< _UElements... > &  __u 
)
constexpr

Definition at line 1965 of file tuple.

◆ operator>() [7/7]

template<typename _Tp >
constexpr bool std::operator> ( nullopt_t  ,
const optional< _Tp > &   
)
constexprnoexcept

Definition at line 1323 of file optional.

◆ operator>=() [1/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator>= ( const _Up &  __lhs,
const optional< _Tp > &  __rhs 
) -> __optional_ge_t<_Up, _Tp>
constexpr

Definition at line 1416 of file optional.

◆ operator>=() [2/7]

template<typename _Tp >
constexpr bool std::operator>= ( const optional< _Tp > &  ,
nullopt_t   
)
constexprnoexcept

Definition at line 1338 of file optional.

◆ operator>=() [3/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator>= ( const optional< _Tp > &  __lhs,
const _Up &  __rhs 
) -> __optional_ge_t<_Tp, _Up>
constexpr

Definition at line 1410 of file optional.

◆ operator>=() [4/7]

template<typename _Tp , typename _Up >
constexpr auto std::operator>= ( const optional< _Tp > &  __lhs,
const optional< _Up > &  __rhs 
) -> __optional_ge_t<_Tp, _Up>
constexpr

Definition at line 1264 of file optional.

◆ operator>=() [5/7]

template<typename _T1 , typename _T2 >
constexpr bool operator>= ( const pair< _T1, _T2 > &  __x,
const pair< _T1, _T2 > &  __y 
)
related

Uses operator< to find the result.

Definition at line 778 of file stl_pair.h.

◆ operator>=() [6/7]

template<typename... _TElements, typename... _UElements>
constexpr bool std::operator>= ( const tuple< _TElements... > &  __t,
const tuple< _UElements... > &  __u 
)
constexpr

Definition at line 1977 of file tuple.

◆ operator>=() [7/7]

template<typename _Tp >
constexpr bool std::operator>= ( nullopt_t  ,
const optional< _Tp > &  __rhs 
)
constexprnoexcept

Definition at line 1343 of file optional.

◆ swap() [1/6]

template<typename _Tp >
constexpr enable_if< __and_< __not_< __is_tuple_like< _Tp > >, is_move_constructible< _Tp >, is_move_assignable< _Tp > >::value >::type std::swap ( _Tp &  __a,
_Tp &  __b 
)
inlineconstexprnoexcept

Swaps two values.

Parameters
__aA thing of arbitrary type.
__bAnother thing of arbitrary type.
Returns
Nothing.

Definition at line 196 of file move.h.

◆ swap() [2/6]

template<typename _Tp , size_t _Nm>
constexpr enable_if< __is_swappable< _Tp >::value >::type std::swap ( _Tp(&)  __a[_Nm],
_Tp(&)  __b[_Nm] 
)
inlineconstexprnoexcept

Swap the contents of two arrays.

Definition at line 220 of file move.h.

References std::swap().

◆ swap() [3/6]

◆ swap() [4/6]

template<typename _Tp >
constexpr enable_if_t< is_move_constructible_v< _Tp > &&is_swappable_v< _Tp > > std::swap ( optional< _Tp > &  __lhs,
optional< _Tp > &  __rhs 
)
inlineconstexprdeletenoexcept

Definition at line 1436 of file optional.

◆ swap() [5/6]

template<typename _T1 , typename _T2 >
constexpr enable_if< __and_< __is_swappable< _T1 >, __is_swappable< _T2 > >::value >::type swap ( pair< _T1, _T2 > &  __x,
pair< _T1, _T2 > &  __y 
)
related

Swap overload for pairs. Calls std::pair::swap().

Note
This std::swap overload is not declared in C++03 mode, which has performance implications, e.g. see https://gcc.gnu.org/PR38466

Definition at line 797 of file stl_pair.h.

References std::pair< _T1, _T2 >::swap().

◆ swap() [6/6]

template<typename... _Elements>
constexpr enable_if< __and_< __is_swappable< _Elements >... >::value >::type std::swap ( tuple< _Elements... > &  __x,
tuple< _Elements... > &  __y 
)
inlineconstexprdeletenoexcept

swap

Definition at line 2166 of file tuple.

◆ tie()

template<typename... _Elements>
constexpr tuple< _Elements &... > std::tie ( _Elements &...  __args)
constexprnoexcept

tie

Definition at line 2152 of file tuple.

Referenced by std::basic_ios< _CharT, _Traits >::copyfmt().

◆ tuple_cat()

template<typename... _Tpls, typename = typename enable_if<__and_<__is_tuple_like<_Tpls>...>::value>::type>
constexpr auto std::tuple_cat ( _Tpls &&...  __tpls) -> typename __tuple_cat_result<_Tpls...>::__type
constexpr

tuple_cat

Definition at line 2138 of file tuple.

Variable Documentation

◆ __is_optional_v

template<typename _Tp >
constexpr bool std::__is_optional_v
inlineconstexpr

Definition at line 679 of file optional.

◆ __is_optional_v< optional< _Tp > >

template<typename _Tp >
constexpr bool std::__is_optional_v< optional< _Tp > >
inlineconstexpr

Definition at line 681 of file optional.

◆ __unpack_std_tuple

template<template< typename... > class _Trait, typename _Tp , typename _Tuple >
constexpr bool std::__unpack_std_tuple
inlineconstexpr

Definition at line 2245 of file tuple.

◆ __unpack_std_tuple< _Trait, _Tp, const tuple< _Up... > & >

template<template< typename... > class _Trait, typename _Tp , typename... _Up>
constexpr bool std::__unpack_std_tuple< _Trait, _Tp, const tuple< _Up... > & >
inlineconstexpr

Definition at line 2260 of file tuple.

◆ __unpack_std_tuple< _Trait, _Tp, const tuple< _Up... > >

template<template< typename... > class _Trait, typename _Tp , typename... _Up>
constexpr bool std::__unpack_std_tuple< _Trait, _Tp, const tuple< _Up... > >
inlineconstexpr

Definition at line 2256 of file tuple.

◆ __unpack_std_tuple< _Trait, _Tp, tuple< _Up... > & >

template<template< typename... > class _Trait, typename _Tp , typename... _Up>
constexpr bool std::__unpack_std_tuple< _Trait, _Tp, tuple< _Up... > & >
inlineconstexpr

Definition at line 2252 of file tuple.

◆ __unpack_std_tuple< _Trait, _Tp, tuple< _Up... > >

template<template< typename... > class _Trait, typename _Tp , typename... _Up>
constexpr bool std::__unpack_std_tuple< _Trait, _Tp, tuple< _Up... > >
inlineconstexpr

Definition at line 2248 of file tuple.

◆ ignore

constexpr _Swallow_assign std::ignore
inlineconstexpr

Definition at line 2200 of file tuple.

◆ nullopt

constexpr nullopt_t std::nullopt
inlineconstexpr

Tag to disengage optional objects.

Definition at line 89 of file optional.

◆ piecewise_construct

constexpr piecewise_construct_t std::piecewise_construct
inlineconstexpr

Tag for piecewise construction of std::pair objects.

Definition at line 83 of file stl_pair.h.

Referenced by std::map< _Key, _Tp, _Compare, _Alloc >::insert_or_assign(), and std::map< _Key, _Tp, _Compare, _Alloc >::try_emplace().

◆ tuple_size_v< const tuple< _Types... > >

template<typename... _Types>
constexpr size_t std::tuple_size_v< const tuple< _Types... > >
inlineconstexpr

Definition at line 1757 of file tuple.

◆ tuple_size_v< tuple< _Types... > >

template<typename... _Types>
constexpr size_t std::tuple_size_v< tuple< _Types... > >
inlineconstexpr

Definition at line 1753 of file tuple.