xref: /llvm-project-15.0.7/libcxx/include/array (revision bc95cf0d)
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