xref: /llvm-project-15.0.7/libcxx/include/array (revision d437fa5c)
13e519524SHoward Hinnant// -*- C++ -*-
23e519524SHoward Hinnant//===---------------------------- array -----------------------------------===//
33e519524SHoward Hinnant//
45b08a8a4SHoward Hinnant//                     The LLVM Compiler Infrastructure
53e519524SHoward Hinnant//
6412dbebeSHoward Hinnant// This file is dual licensed under the MIT and the University of Illinois Open
7412dbebeSHoward Hinnant// Source Licenses. See LICENSE.TXT for details.
83e519524SHoward Hinnant//
93e519524SHoward Hinnant//===----------------------------------------------------------------------===//
103e519524SHoward Hinnant
113e519524SHoward Hinnant#ifndef _LIBCPP_ARRAY
123e519524SHoward Hinnant#define _LIBCPP_ARRAY
133e519524SHoward Hinnant
143e519524SHoward Hinnant/*
153e519524SHoward Hinnant    array synopsis
163e519524SHoward Hinnant
173e519524SHoward Hinnantnamespace std
183e519524SHoward Hinnant{
193e519524SHoward Hinnanttemplate <class T, size_t N >
203e519524SHoward Hinnantstruct array
213e519524SHoward Hinnant{
223e519524SHoward Hinnant    // types:
233e519524SHoward Hinnant    typedef T & reference;
243e519524SHoward Hinnant    typedef const T & const_reference;
253e519524SHoward Hinnant    typedef implementation defined iterator;
263e519524SHoward Hinnant    typedef implementation defined const_iterator;
273e519524SHoward Hinnant    typedef size_t size_type;
283e519524SHoward Hinnant    typedef ptrdiff_t difference_type;
293e519524SHoward Hinnant    typedef T value_type;
303e519524SHoward Hinnant    typedef T* pointer;
313e519524SHoward Hinnant    typedef const T* const_pointer;
323e519524SHoward Hinnant    typedef std::reverse_iterator<iterator> reverse_iterator;
333e519524SHoward Hinnant    typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
343e519524SHoward Hinnant
353e519524SHoward Hinnant    // No explicit construct/copy/destroy for aggregate type
363e519524SHoward Hinnant    void fill(const T& u);
37f07dd8d0SEric Fiselier    void swap(array& a) noexcept(is_nothrow_swappable_v<T>);
383e519524SHoward Hinnant
393e519524SHoward Hinnant    // iterators:
408f0cd597SHoward Hinnant    iterator begin() noexcept;
418f0cd597SHoward Hinnant    const_iterator begin() const noexcept;
428f0cd597SHoward Hinnant    iterator end() noexcept;
438f0cd597SHoward Hinnant    const_iterator end() const noexcept;
443e519524SHoward Hinnant
458f0cd597SHoward Hinnant    reverse_iterator rbegin() noexcept;
468f0cd597SHoward Hinnant    const_reverse_iterator rbegin() const noexcept;
478f0cd597SHoward Hinnant    reverse_iterator rend() noexcept;
488f0cd597SHoward Hinnant    const_reverse_iterator rend() const noexcept;
493e519524SHoward Hinnant
508f0cd597SHoward Hinnant    const_iterator cbegin() const noexcept;
518f0cd597SHoward Hinnant    const_iterator cend() const noexcept;
528f0cd597SHoward Hinnant    const_reverse_iterator crbegin() const noexcept;
538f0cd597SHoward Hinnant    const_reverse_iterator crend() const noexcept;
543e519524SHoward Hinnant
553e519524SHoward Hinnant    // capacity:
568f0cd597SHoward Hinnant    constexpr size_type size() const noexcept;
578f0cd597SHoward Hinnant    constexpr size_type max_size() const noexcept;
58397717b7SHoward Hinnant    constexpr bool empty() const noexcept;
593e519524SHoward Hinnant
603e519524SHoward Hinnant    // element access:
613e519524SHoward Hinnant    reference operator[](size_type n);
628bf1f08aSMarshall Clow    const_reference operator[](size_type n) const; // constexpr in C++14
638bf1f08aSMarshall Clow    const_reference at(size_type n) const; // constexpr in C++14
643e519524SHoward Hinnant    reference at(size_type n);
653e519524SHoward Hinnant
663e519524SHoward Hinnant    reference front();
678bf1f08aSMarshall Clow    const_reference front() const; // constexpr in C++14
683e519524SHoward Hinnant    reference back();
698bf1f08aSMarshall Clow    const_reference back() const; // constexpr in C++14
703e519524SHoward Hinnant
718f0cd597SHoward Hinnant    T* data() noexcept;
728f0cd597SHoward Hinnant    const T* data() const noexcept;
733e519524SHoward Hinnant};
743e519524SHoward Hinnant
753e519524SHoward Hinnanttemplate <class T, size_t N>
763e519524SHoward Hinnant  bool operator==(const array<T,N>& x, const array<T,N>& y);
773e519524SHoward Hinnanttemplate <class T, size_t N>
783e519524SHoward Hinnant  bool operator!=(const array<T,N>& x, const array<T,N>& y);
793e519524SHoward Hinnanttemplate <class T, size_t N>
803e519524SHoward Hinnant  bool operator<(const array<T,N>& x, const array<T,N>& y);
813e519524SHoward Hinnanttemplate <class T, size_t N>
823e519524SHoward Hinnant  bool operator>(const array<T,N>& x, const array<T,N>& y);
833e519524SHoward Hinnanttemplate <class T, size_t N>
843e519524SHoward Hinnant  bool operator<=(const array<T,N>& x, const array<T,N>& y);
853e519524SHoward Hinnanttemplate <class T, size_t N>
863e519524SHoward Hinnant  bool operator>=(const array<T,N>& x, const array<T,N>& y);
873e519524SHoward Hinnant
883e519524SHoward Hinnanttemplate <class T, size_t N >
898f0cd597SHoward Hinnant  void swap(array<T,N>& x, array<T,N>& y) noexcept(noexcept(x.swap(y)));
903e519524SHoward Hinnant
913e519524SHoward Hinnanttemplate <class T> class tuple_size;
925fcc8169SMarshall Clowtemplate <size_t I, class T> class tuple_element;
933e519524SHoward Hinnanttemplate <class T, size_t N> struct tuple_size<array<T, N>>;
945fcc8169SMarshall Clowtemplate <size_t I, class T, size_t N> struct tuple_element<I, array<T, N>>;
955fcc8169SMarshall Clowtemplate <size_t I, class T, size_t N> T& get(array<T, N>&) noexcept; // constexpr in C++14
965fcc8169SMarshall Clowtemplate <size_t I, class T, size_t N> const T& get(const array<T, N>&) noexcept; // constexpr in C++14
975fcc8169SMarshall Clowtemplate <size_t I, class T, size_t N> T&& get(array<T, N>&&) noexcept; // constexpr in C++14
98545b8861SEric Fiseliertemplate <size_t I, class T, size_t N> const T&& get(const array<T, N>&&) noexcept; // constexpr in C++14
993e519524SHoward Hinnant
1003e519524SHoward Hinnant}  // std
1013e519524SHoward Hinnant
1023e519524SHoward Hinnant*/
1033e519524SHoward Hinnant
1043e519524SHoward Hinnant#include <__config>
1053e519524SHoward Hinnant#include <__tuple>
1063e519524SHoward Hinnant#include <type_traits>
1073e519524SHoward Hinnant#include <utility>
1083e519524SHoward Hinnant#include <iterator>
1093e519524SHoward Hinnant#include <algorithm>
1103e519524SHoward Hinnant#include <stdexcept>
1113e519524SHoward Hinnant
112073458b1SHoward Hinnant#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
1133e519524SHoward Hinnant#pragma GCC system_header
114073458b1SHoward Hinnant#endif
1153e519524SHoward Hinnant
1163e519524SHoward Hinnant_LIBCPP_BEGIN_NAMESPACE_STD
1173e519524SHoward Hinnant
1183e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
119f0544c20SHoward Hinnantstruct _LIBCPP_TYPE_VIS_ONLY array
1203e519524SHoward Hinnant{
1213e519524SHoward Hinnant    // types:
1223e519524SHoward Hinnant    typedef array __self;
1233e519524SHoward Hinnant    typedef _Tp                                   value_type;
1243e519524SHoward Hinnant    typedef value_type&                           reference;
1253e519524SHoward Hinnant    typedef const value_type&                     const_reference;
1263e519524SHoward Hinnant    typedef value_type*                           iterator;
1273e519524SHoward Hinnant    typedef const value_type*                     const_iterator;
1283e519524SHoward Hinnant    typedef value_type*                           pointer;
1293e519524SHoward Hinnant    typedef const value_type*                     const_pointer;
1303e519524SHoward Hinnant    typedef size_t                                size_type;
1313e519524SHoward Hinnant    typedef ptrdiff_t                             difference_type;
1323e519524SHoward Hinnant    typedef std::reverse_iterator<iterator>       reverse_iterator;
1333e519524SHoward Hinnant    typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
1343e519524SHoward Hinnant
1353e519524SHoward Hinnant    value_type __elems_[_Size > 0 ? _Size : 1];
1363e519524SHoward Hinnant
1373e519524SHoward Hinnant    // No explicit construct/copy/destroy for aggregate type
138f5ab703fSHoward Hinnant    _LIBCPP_INLINE_VISIBILITY void fill(const value_type& __u)
139ce48a113SHoward Hinnant        {_VSTD::fill_n(__elems_, _Size, __u);}
1408f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
141f07dd8d0SEric Fiselier    void swap(array& __a) _NOEXCEPT_(_Size == 0 || __is_nothrow_swappable<_Tp>::value)
142f07dd8d0SEric Fiselier        { __swap_dispatch((std::integral_constant<bool, _Size == 0>()), __a); }
143f07dd8d0SEric Fiselier
144f07dd8d0SEric Fiselier    _LIBCPP_INLINE_VISIBILITY
145f07dd8d0SEric Fiselier    void __swap_dispatch(std::true_type, array&) {}
146f07dd8d0SEric Fiselier
147f07dd8d0SEric Fiselier    _LIBCPP_INLINE_VISIBILITY
148f07dd8d0SEric Fiselier    void __swap_dispatch(std::false_type, array& __a)
149ce48a113SHoward Hinnant        { _VSTD::swap_ranges(__elems_, __elems_ + _Size, __a.__elems_);}
1503e519524SHoward Hinnant
1513e519524SHoward Hinnant    // iterators:
1528f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1538f0cd597SHoward Hinnant    iterator begin() _NOEXCEPT {return iterator(__elems_);}
1548f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1558f0cd597SHoward Hinnant    const_iterator begin() const _NOEXCEPT {return const_iterator(__elems_);}
1568f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1578f0cd597SHoward Hinnant    iterator end() _NOEXCEPT {return iterator(__elems_ + _Size);}
1588f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1598f0cd597SHoward Hinnant    const_iterator end() const _NOEXCEPT {return const_iterator(__elems_ + _Size);}
1603e519524SHoward Hinnant
1618f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1628f0cd597SHoward Hinnant    reverse_iterator rbegin() _NOEXCEPT {return reverse_iterator(end());}
1638f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1648f0cd597SHoward Hinnant    const_reverse_iterator rbegin() const _NOEXCEPT {return const_reverse_iterator(end());}
1658f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1668f0cd597SHoward Hinnant    reverse_iterator rend() _NOEXCEPT {return reverse_iterator(begin());}
1678f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1688f0cd597SHoward Hinnant    const_reverse_iterator rend() const _NOEXCEPT {return const_reverse_iterator(begin());}
1693e519524SHoward Hinnant
1708f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1718f0cd597SHoward Hinnant    const_iterator cbegin() const _NOEXCEPT {return begin();}
1728f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1738f0cd597SHoward Hinnant    const_iterator cend() const _NOEXCEPT {return end();}
1748f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1758f0cd597SHoward Hinnant    const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();}
1768f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1778f0cd597SHoward Hinnant    const_reverse_iterator crend() const _NOEXCEPT {return rend();}
1783e519524SHoward Hinnant
1793e519524SHoward Hinnant    // capacity:
1808f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
181397717b7SHoward Hinnant    _LIBCPP_CONSTEXPR size_type size() const _NOEXCEPT {return _Size;}
1828f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
183397717b7SHoward Hinnant    _LIBCPP_CONSTEXPR size_type max_size() const _NOEXCEPT {return _Size;}
1848f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
185397717b7SHoward Hinnant    _LIBCPP_CONSTEXPR bool empty() const _NOEXCEPT {return _Size == 0;}
1863e519524SHoward Hinnant
1873e519524SHoward Hinnant    // element access:
1883e519524SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY reference operator[](size_type __n)             {return __elems_[__n];}
1898bf1f08aSMarshall Clow    _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 const_reference operator[](size_type __n) const {return __elems_[__n];}
1903e519524SHoward Hinnant    reference at(size_type __n);
1918bf1f08aSMarshall Clow    _LIBCPP_CONSTEXPR_AFTER_CXX11 const_reference at(size_type __n) const;
1923e519524SHoward Hinnant
1933e519524SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY reference front()             {return __elems_[0];}
1948bf1f08aSMarshall Clow    _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 const_reference front() const {return __elems_[0];}
1953e519524SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY reference back()              {return __elems_[_Size > 0 ? _Size-1 : 0];}
1968bf1f08aSMarshall Clow    _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11 const_reference back() const  {return __elems_[_Size > 0 ? _Size-1 : 0];}
1973e519524SHoward Hinnant
1988f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
1998f0cd597SHoward Hinnant    value_type* data() _NOEXCEPT {return __elems_;}
2008f0cd597SHoward Hinnant    _LIBCPP_INLINE_VISIBILITY
2018f0cd597SHoward Hinnant    const value_type* data() const _NOEXCEPT {return __elems_;}
2023e519524SHoward Hinnant};
2033e519524SHoward Hinnant
2043e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2053e519524SHoward Hinnanttypename array<_Tp, _Size>::reference
2063e519524SHoward Hinnantarray<_Tp, _Size>::at(size_type __n)
2073e519524SHoward Hinnant{
2083e519524SHoward Hinnant    if (__n >= _Size)
209*d437fa5cSMarshall Clow        __throw_out_of_range("array::at");
210*d437fa5cSMarshall Clow
2113e519524SHoward Hinnant    return __elems_[__n];
2123e519524SHoward Hinnant}
2133e519524SHoward Hinnant
2143e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2158bf1f08aSMarshall Clow_LIBCPP_CONSTEXPR_AFTER_CXX11
2163e519524SHoward Hinnanttypename array<_Tp, _Size>::const_reference
2173e519524SHoward Hinnantarray<_Tp, _Size>::at(size_type __n) const
2183e519524SHoward Hinnant{
2193e519524SHoward Hinnant    if (__n >= _Size)
220*d437fa5cSMarshall Clow        __throw_out_of_range("array::at");
2213e519524SHoward Hinnant    return __elems_[__n];
2223e519524SHoward Hinnant}
2233e519524SHoward Hinnant
2243e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2253af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY
2263e519524SHoward Hinnantbool
2273e519524SHoward Hinnantoperator==(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y)
2283e519524SHoward Hinnant{
229ce48a113SHoward Hinnant    return _VSTD::equal(__x.__elems_, __x.__elems_ + _Size, __y.__elems_);
2303e519524SHoward Hinnant}
2313e519524SHoward Hinnant
2323e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2333af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY
2343e519524SHoward Hinnantbool
2353e519524SHoward Hinnantoperator!=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y)
2363e519524SHoward Hinnant{
2373e519524SHoward Hinnant    return !(__x == __y);
2383e519524SHoward Hinnant}
2393e519524SHoward Hinnant
2403e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2413af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY
2423e519524SHoward Hinnantbool
2433e519524SHoward Hinnantoperator<(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y)
2443e519524SHoward Hinnant{
245ce48a113SHoward Hinnant    return _VSTD::lexicographical_compare(__x.__elems_, __x.__elems_ + _Size, __y.__elems_, __y.__elems_ + _Size);
2463e519524SHoward Hinnant}
2473e519524SHoward Hinnant
2483e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2493af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY
2503e519524SHoward Hinnantbool
2513e519524SHoward Hinnantoperator>(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y)
2523e519524SHoward Hinnant{
2533e519524SHoward Hinnant    return __y < __x;
2543e519524SHoward Hinnant}
2553e519524SHoward Hinnant
2563e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2573af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY
2583e519524SHoward Hinnantbool
2593e519524SHoward Hinnantoperator<=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y)
2603e519524SHoward Hinnant{
2613e519524SHoward Hinnant    return !(__y < __x);
2623e519524SHoward Hinnant}
2633e519524SHoward Hinnant
2643e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2653af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY
2663e519524SHoward Hinnantbool
2673e519524SHoward Hinnantoperator>=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y)
2683e519524SHoward Hinnant{
2693e519524SHoward Hinnant    return !(__x < __y);
2703e519524SHoward Hinnant}
2713e519524SHoward Hinnant
2723e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
2733af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY
274bc95cf0dSHoward Hinnanttypename enable_if
275bc95cf0dSHoward Hinnant<
276f07dd8d0SEric Fiselier    _Size == 0 ||
277bc95cf0dSHoward Hinnant    __is_swappable<_Tp>::value,
2783e519524SHoward Hinnant    void
279bc95cf0dSHoward Hinnant>::type
280ee66eb13SMarshall Clowswap(array<_Tp, _Size>& __x, array<_Tp, _Size>& __y)
281f07dd8d0SEric Fiselier                                  _NOEXCEPT_(noexcept(__x.swap(__y)))
2823e519524SHoward Hinnant{
2833e519524SHoward Hinnant    __x.swap(__y);
2843e519524SHoward Hinnant}
2853e519524SHoward Hinnant
2863e519524SHoward Hinnanttemplate <class _Tp, size_t _Size>
287f0544c20SHoward Hinnantclass _LIBCPP_TYPE_VIS_ONLY tuple_size<array<_Tp, _Size> >
288f5ab703fSHoward Hinnant    : public integral_constant<size_t, _Size> {};
2893e519524SHoward Hinnant
2903e519524SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size>
291f0544c20SHoward Hinnantclass _LIBCPP_TYPE_VIS_ONLY tuple_element<_Ip, array<_Tp, _Size> >
2923e519524SHoward Hinnant{
2933e519524SHoward Hinnantpublic:
2943e519524SHoward Hinnant    typedef _Tp type;
2953e519524SHoward Hinnant};
2963e519524SHoward Hinnant
2973e519524SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size>
2983af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
2993e519524SHoward Hinnant_Tp&
3008f0cd597SHoward Hinnantget(array<_Tp, _Size>& __a) _NOEXCEPT
3013e519524SHoward Hinnant{
30236a60721SMarshall Clow    static_assert(_Ip < _Size, "Index out of bounds in std::get<> (std::array)");
3038bf1f08aSMarshall Clow    return __a.__elems_[_Ip];
3043e519524SHoward Hinnant}
3053e519524SHoward Hinnant
3063e519524SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size>
3073af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
3083e519524SHoward Hinnantconst _Tp&
3098f0cd597SHoward Hinnantget(const array<_Tp, _Size>& __a) _NOEXCEPT
3103e519524SHoward Hinnant{
31136a60721SMarshall Clow    static_assert(_Ip < _Size, "Index out of bounds in std::get<> (const std::array)");
3128bf1f08aSMarshall Clow    return __a.__elems_[_Ip];
3133e519524SHoward Hinnant}
3143e519524SHoward Hinnant
315601afb30SHoward Hinnant#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
316601afb30SHoward Hinnant
317601afb30SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size>
3183af48ef7SHoward Hinnantinline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
319601afb30SHoward Hinnant_Tp&&
3208f0cd597SHoward Hinnantget(array<_Tp, _Size>&& __a) _NOEXCEPT
321601afb30SHoward Hinnant{
32236a60721SMarshall Clow    static_assert(_Ip < _Size, "Index out of bounds in std::get<> (std::array &&)");
3238bf1f08aSMarshall Clow    return _VSTD::move(__a.__elems_[_Ip]);
324601afb30SHoward Hinnant}
325601afb30SHoward Hinnant
326545b8861SEric Fiseliertemplate <size_t _Ip, class _Tp, size_t _Size>
327545b8861SEric Fiselierinline _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX11
328545b8861SEric Fiselierconst _Tp&&
329545b8861SEric Fiselierget(const array<_Tp, _Size>&& __a) _NOEXCEPT
330545b8861SEric Fiselier{
331545b8861SEric Fiselier    static_assert(_Ip < _Size, "Index out of bounds in std::get<> (const std::array &&)");
332545b8861SEric Fiselier    return _VSTD::move(__a.__elems_[_Ip]);
333545b8861SEric Fiselier}
334545b8861SEric Fiselier
335601afb30SHoward Hinnant#endif  // _LIBCPP_HAS_NO_RVALUE_REFERENCES
336601afb30SHoward Hinnant
3373e519524SHoward Hinnant_LIBCPP_END_NAMESPACE_STD
3383e519524SHoward Hinnant
3393e519524SHoward Hinnant#endif  // _LIBCPP_ARRAY
340