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); 378f0cd597SHoward Hinnant void swap(array& a) noexcept(noexcept(swap(declval<T&>(), declval<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; 588f0cd597SHoward Hinnant bool empty() const noexcept; 593e519524SHoward Hinnant 603e519524SHoward Hinnant // element access: 613e519524SHoward Hinnant reference operator[](size_type n); 623e519524SHoward Hinnant const_reference operator[](size_type n) const; 633e519524SHoward Hinnant const_reference at(size_type n) const; 643e519524SHoward Hinnant reference at(size_type n); 653e519524SHoward Hinnant 663e519524SHoward Hinnant reference front(); 673e519524SHoward Hinnant const_reference front() const; 683e519524SHoward Hinnant reference back(); 693e519524SHoward Hinnant const_reference back() const; 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; 923e519524SHoward Hinnanttemplate <int I, class T> class tuple_element; 933e519524SHoward Hinnanttemplate <class T, size_t N> struct tuple_size<array<T, N>>; 943e519524SHoward Hinnanttemplate <int I, class T, size_t N> struct tuple_element<I, array<T, N>>; 958f0cd597SHoward Hinnanttemplate <int I, class T, size_t N> T& get(array<T, N>&) noexcept; 968f0cd597SHoward Hinnanttemplate <int I, class T, size_t N> const T& get(const array<T, N>&) noexcept; 978f0cd597SHoward Hinnanttemplate <int I, class T, size_t N> T&& get(array<T, N>&&) noexcept; 983e519524SHoward Hinnant 993e519524SHoward Hinnant} // std 1003e519524SHoward Hinnant 1013e519524SHoward Hinnant*/ 1023e519524SHoward Hinnant 1033e519524SHoward Hinnant#include <__config> 1043e519524SHoward Hinnant#include <__tuple> 1053e519524SHoward Hinnant#include <type_traits> 1063e519524SHoward Hinnant#include <utility> 1073e519524SHoward Hinnant#include <iterator> 1083e519524SHoward Hinnant#include <algorithm> 1093e519524SHoward Hinnant#include <stdexcept> 1103e519524SHoward Hinnant#if defined(_LIBCPP_NO_EXCEPTIONS) 1113e519524SHoward Hinnant #include <cassert> 1123e519524SHoward Hinnant#endif 1133e519524SHoward Hinnant 1143e519524SHoward Hinnant#pragma GCC system_header 1153e519524SHoward Hinnant 1163e519524SHoward Hinnant_LIBCPP_BEGIN_NAMESPACE_STD 1173e519524SHoward Hinnant 1183e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 119f5ab703fSHoward Hinnantstruct _LIBCPP_VISIBLE 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) 139f5ab703fSHoward Hinnant {_STD::fill_n(__elems_, _Size, __u);} 1408f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1418f0cd597SHoward Hinnant void swap(array& __a) _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value) 142f5ab703fSHoward Hinnant {_STD::swap_ranges(__elems_, __elems_ + _Size, __a.__elems_);} 1433e519524SHoward Hinnant 1443e519524SHoward Hinnant // iterators: 1458f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1468f0cd597SHoward Hinnant iterator begin() _NOEXCEPT {return iterator(__elems_);} 1478f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1488f0cd597SHoward Hinnant const_iterator begin() const _NOEXCEPT {return const_iterator(__elems_);} 1498f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1508f0cd597SHoward Hinnant iterator end() _NOEXCEPT {return iterator(__elems_ + _Size);} 1518f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1528f0cd597SHoward Hinnant const_iterator end() const _NOEXCEPT {return const_iterator(__elems_ + _Size);} 1533e519524SHoward Hinnant 1548f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1558f0cd597SHoward Hinnant reverse_iterator rbegin() _NOEXCEPT {return reverse_iterator(end());} 1568f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1578f0cd597SHoward Hinnant const_reverse_iterator rbegin() const _NOEXCEPT {return const_reverse_iterator(end());} 1588f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1598f0cd597SHoward Hinnant reverse_iterator rend() _NOEXCEPT {return reverse_iterator(begin());} 1608f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1618f0cd597SHoward Hinnant const_reverse_iterator rend() const _NOEXCEPT {return const_reverse_iterator(begin());} 1623e519524SHoward Hinnant 1638f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1648f0cd597SHoward Hinnant const_iterator cbegin() const _NOEXCEPT {return begin();} 1658f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1668f0cd597SHoward Hinnant const_iterator cend() const _NOEXCEPT {return end();} 1678f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1688f0cd597SHoward Hinnant const_reverse_iterator crbegin() const _NOEXCEPT {return rbegin();} 1698f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1708f0cd597SHoward Hinnant const_reverse_iterator crend() const _NOEXCEPT {return rend();} 1713e519524SHoward Hinnant 1723e519524SHoward Hinnant // capacity: 1738f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1748f0cd597SHoward Hinnant /*constexpr*/ size_type size() const _NOEXCEPT {return _Size;} 1758f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1768f0cd597SHoward Hinnant /*constexpr*/ size_type max_size() const _NOEXCEPT {return _Size;} 1778f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1788f0cd597SHoward Hinnant bool empty() const _NOEXCEPT {return _Size == 0;} 1793e519524SHoward Hinnant 1803e519524SHoward Hinnant // element access: 1813e519524SHoward Hinnant _LIBCPP_INLINE_VISIBILITY reference operator[](size_type __n) {return __elems_[__n];} 1823e519524SHoward Hinnant _LIBCPP_INLINE_VISIBILITY const_reference operator[](size_type __n) const {return __elems_[__n];} 1833e519524SHoward Hinnant reference at(size_type __n); 1843e519524SHoward Hinnant const_reference at(size_type __n) const; 1853e519524SHoward Hinnant 1863e519524SHoward Hinnant _LIBCPP_INLINE_VISIBILITY reference front() {return __elems_[0];} 1873e519524SHoward Hinnant _LIBCPP_INLINE_VISIBILITY const_reference front() const {return __elems_[0];} 1883e519524SHoward Hinnant _LIBCPP_INLINE_VISIBILITY reference back() {return __elems_[_Size > 0 ? _Size-1 : 0];} 1893e519524SHoward Hinnant _LIBCPP_INLINE_VISIBILITY const_reference back() const {return __elems_[_Size > 0 ? _Size-1 : 0];} 1903e519524SHoward Hinnant 1918f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1928f0cd597SHoward Hinnant value_type* data() _NOEXCEPT {return __elems_;} 1938f0cd597SHoward Hinnant _LIBCPP_INLINE_VISIBILITY 1948f0cd597SHoward Hinnant const value_type* data() const _NOEXCEPT {return __elems_;} 1953e519524SHoward Hinnant}; 1963e519524SHoward Hinnant 1973e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 1983e519524SHoward Hinnanttypename array<_Tp, _Size>::reference 1993e519524SHoward Hinnantarray<_Tp, _Size>::at(size_type __n) 2003e519524SHoward Hinnant{ 2013e519524SHoward Hinnant if (__n >= _Size) 2023e519524SHoward Hinnant#ifndef _LIBCPP_NO_EXCEPTIONS 2033e519524SHoward Hinnant throw out_of_range("array::at"); 2043e519524SHoward Hinnant#else 2053e519524SHoward Hinnant assert(!"array::at out_of_range"); 2063e519524SHoward Hinnant#endif 2073e519524SHoward Hinnant return __elems_[__n]; 2083e519524SHoward Hinnant} 2093e519524SHoward Hinnant 2103e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 2113e519524SHoward Hinnanttypename array<_Tp, _Size>::const_reference 2123e519524SHoward Hinnantarray<_Tp, _Size>::at(size_type __n) const 2133e519524SHoward Hinnant{ 2143e519524SHoward Hinnant if (__n >= _Size) 2153e519524SHoward Hinnant#ifndef _LIBCPP_NO_EXCEPTIONS 2163e519524SHoward Hinnant throw out_of_range("array::at"); 2173e519524SHoward Hinnant#else 2183e519524SHoward Hinnant assert(!"array::at out_of_range"); 2193e519524SHoward Hinnant#endif 2203e519524SHoward Hinnant return __elems_[__n]; 2213e519524SHoward Hinnant} 2223e519524SHoward Hinnant 2233e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 2243e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 2253e519524SHoward Hinnantbool 2263e519524SHoward Hinnantoperator==(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) 2273e519524SHoward Hinnant{ 2283e519524SHoward Hinnant return _STD::equal(__x.__elems_, __x.__elems_ + _Size, __y.__elems_); 2293e519524SHoward Hinnant} 2303e519524SHoward Hinnant 2313e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 2323e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 2333e519524SHoward Hinnantbool 2343e519524SHoward Hinnantoperator!=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) 2353e519524SHoward Hinnant{ 2363e519524SHoward Hinnant return !(__x == __y); 2373e519524SHoward Hinnant} 2383e519524SHoward Hinnant 2393e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 2403e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 2413e519524SHoward Hinnantbool 2423e519524SHoward Hinnantoperator<(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) 2433e519524SHoward Hinnant{ 2443e519524SHoward Hinnant return _STD::lexicographical_compare(__x.__elems_, __x.__elems_ + _Size, __y.__elems_, __y.__elems_ + _Size); 2453e519524SHoward Hinnant} 2463e519524SHoward Hinnant 2473e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 2483e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 2493e519524SHoward Hinnantbool 2503e519524SHoward Hinnantoperator>(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) 2513e519524SHoward Hinnant{ 2523e519524SHoward Hinnant return __y < __x; 2533e519524SHoward Hinnant} 2543e519524SHoward Hinnant 2553e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 2563e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 2573e519524SHoward Hinnantbool 2583e519524SHoward Hinnantoperator<=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) 2593e519524SHoward Hinnant{ 2603e519524SHoward Hinnant return !(__y < __x); 2613e519524SHoward Hinnant} 2623e519524SHoward Hinnant 2633e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 2643e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 2653e519524SHoward Hinnantbool 2663e519524SHoward Hinnantoperator>=(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) 2673e519524SHoward Hinnant{ 2683e519524SHoward Hinnant return !(__x < __y); 2693e519524SHoward Hinnant} 2703e519524SHoward Hinnant 2713e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 2723e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 273*bc95cf0dSHoward Hinnanttypename enable_if 274*bc95cf0dSHoward Hinnant< 275*bc95cf0dSHoward Hinnant __is_swappable<_Tp>::value, 2763e519524SHoward Hinnant void 277*bc95cf0dSHoward Hinnant>::type 2783e519524SHoward Hinnantswap(const array<_Tp, _Size>& __x, const array<_Tp, _Size>& __y) 2798f0cd597SHoward Hinnant _NOEXCEPT_(__is_nothrow_swappable<_Tp>::value) 2803e519524SHoward Hinnant{ 2813e519524SHoward Hinnant __x.swap(__y); 2823e519524SHoward Hinnant} 2833e519524SHoward Hinnant 2843e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 285f5ab703fSHoward Hinnantclass _LIBCPP_VISIBLE tuple_size<array<_Tp, _Size> > 286f5ab703fSHoward Hinnant : public integral_constant<size_t, _Size> {}; 2873e519524SHoward Hinnant 2883e519524SHoward Hinnanttemplate <class _Tp, size_t _Size> 289f5ab703fSHoward Hinnantclass _LIBCPP_VISIBLE tuple_size<const array<_Tp, _Size> > 290f5ab703fSHoward Hinnant : public integral_constant<size_t, _Size> {}; 2913e519524SHoward Hinnant 2923e519524SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size> 293f5ab703fSHoward Hinnantclass _LIBCPP_VISIBLE tuple_element<_Ip, array<_Tp, _Size> > 2943e519524SHoward Hinnant{ 2953e519524SHoward Hinnantpublic: 2963e519524SHoward Hinnant typedef _Tp type; 2973e519524SHoward Hinnant}; 2983e519524SHoward Hinnant 2993e519524SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size> 300f5ab703fSHoward Hinnantclass _LIBCPP_VISIBLE tuple_element<_Ip, const array<_Tp, _Size> > 3013e519524SHoward Hinnant{ 3023e519524SHoward Hinnantpublic: 3033e519524SHoward Hinnant typedef const _Tp type; 3043e519524SHoward Hinnant}; 3053e519524SHoward Hinnant 3063e519524SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size> 3073e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 3083e519524SHoward Hinnant_Tp& 3098f0cd597SHoward Hinnantget(array<_Tp, _Size>& __a) _NOEXCEPT 3103e519524SHoward Hinnant{ 3113e519524SHoward Hinnant return __a[_Ip]; 3123e519524SHoward Hinnant} 3133e519524SHoward Hinnant 3143e519524SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size> 3153e519524SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 3163e519524SHoward Hinnantconst _Tp& 3178f0cd597SHoward Hinnantget(const array<_Tp, _Size>& __a) _NOEXCEPT 3183e519524SHoward Hinnant{ 3193e519524SHoward Hinnant return __a[_Ip]; 3203e519524SHoward Hinnant} 3213e519524SHoward Hinnant 322601afb30SHoward Hinnant#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES 323601afb30SHoward Hinnant 324601afb30SHoward Hinnanttemplate <size_t _Ip, class _Tp, size_t _Size> 325601afb30SHoward Hinnant_LIBCPP_INLINE_VISIBILITY inline 326601afb30SHoward Hinnant_Tp&& 3278f0cd597SHoward Hinnantget(array<_Tp, _Size>&& __a) _NOEXCEPT 328601afb30SHoward Hinnant{ 329601afb30SHoward Hinnant return _STD::move(__a[_Ip]); 330601afb30SHoward Hinnant} 331601afb30SHoward Hinnant 332601afb30SHoward Hinnant#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES 333601afb30SHoward Hinnant 3343e519524SHoward Hinnant_LIBCPP_END_NAMESPACE_STD 3353e519524SHoward Hinnant 3363e519524SHoward Hinnant#endif // _LIBCPP_ARRAY 337