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