Home | History | Annotate | Download | only in list
      1 //===----------------------------------------------------------------------===//
      2 //
      3 //                     The LLVM Compiler Infrastructure
      4 //
      5 // This file is dual licensed under the MIT and the University of Illinois Open
      6 // Source Licenses. See LICENSE.TXT for details.
      7 //
      8 //===----------------------------------------------------------------------===//
      9 
     10 // <list>
     11 
     12 // iterator       begin();
     13 // iterator       end();
     14 // const_iterator begin()  const;
     15 // const_iterator end()    const;
     16 // const_iterator cbegin() const;
     17 // const_iterator cend()   const;
     18 
     19 #include <list>
     20 #include <cassert>
     21 #include <iterator>
     22 
     23 #include "min_allocator.h"
     24 
     25 struct A
     26 {
     27     int first;
     28     int second;
     29 };
     30 
     31 int main()
     32 {
     33     {
     34         typedef int T;
     35         typedef std::list<T> C;
     36         C c;
     37         C::iterator i = c.begin();
     38         C::iterator j = c.end();
     39         assert(std::distance(i, j) == 0);
     40         assert(i == j);
     41     }
     42     {
     43         typedef int T;
     44         typedef std::list<T> C;
     45         const C c;
     46         C::const_iterator i = c.begin();
     47         C::const_iterator j = c.end();
     48         assert(std::distance(i, j) == 0);
     49         assert(i == j);
     50     }
     51     {
     52         typedef int T;
     53         typedef std::list<T> C;
     54         C c;
     55         C::const_iterator i = c.cbegin();
     56         C::const_iterator j = c.cend();
     57         assert(std::distance(i, j) == 0);
     58         assert(i == j);
     59         assert(i == c.end());
     60     }
     61     {
     62         typedef int T;
     63         typedef std::list<T> C;
     64         const T t[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
     65         C c(std::begin(t), std::end(t));
     66         C::iterator i = c.begin();
     67         assert(*i == 0);
     68         ++i;
     69         assert(*i == 1);
     70         *i = 10;
     71         assert(*i == 10);
     72         assert(std::distance(c.begin(), c.end()) == 10);
     73     }
     74     {
     75         typedef int T;
     76         typedef std::list<T> C;
     77         C::iterator i;
     78         C::const_iterator j;
     79     }
     80 #if __cplusplus >= 201103L
     81     {
     82         typedef int T;
     83         typedef std::list<T, min_allocator<T>> C;
     84         C c;
     85         C::iterator i = c.begin();
     86         C::iterator j = c.end();
     87         assert(std::distance(i, j) == 0);
     88         assert(i == j);
     89     }
     90     {
     91         typedef int T;
     92         typedef std::list<T, min_allocator<T>> C;
     93         const C c;
     94         C::const_iterator i = c.begin();
     95         C::const_iterator j = c.end();
     96         assert(std::distance(i, j) == 0);
     97         assert(i == j);
     98     }
     99     {
    100         typedef int T;
    101         typedef std::list<T, min_allocator<T>> C;
    102         C c;
    103         C::const_iterator i = c.cbegin();
    104         C::const_iterator j = c.cend();
    105         assert(std::distance(i, j) == 0);
    106         assert(i == j);
    107         assert(i == c.end());
    108     }
    109     {
    110         typedef int T;
    111         typedef std::list<T, min_allocator<T>> C;
    112         const T t[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
    113         C c(std::begin(t), std::end(t));
    114         C::iterator i = c.begin();
    115         assert(*i == 0);
    116         ++i;
    117         assert(*i == 1);
    118         *i = 10;
    119         assert(*i == 10);
    120         assert(std::distance(c.begin(), c.end()) == 10);
    121     }
    122     {
    123         typedef int T;
    124         typedef std::list<T, min_allocator<T>> C;
    125         C::iterator i;
    126         C::const_iterator j;
    127     }
    128     {
    129         typedef A T;
    130         typedef std::list<T, min_allocator<T>> C;
    131         C c = {A{1, 2}};
    132         C::iterator i = c.begin();
    133         i->first = 3;
    134         C::const_iterator j = i;
    135         assert(j->first == 3);
    136     }
    137 #endif
    138 #if _LIBCPP_STD_VER > 11
    139     {
    140         std::list<int> c;
    141         std::list<int>::iterator ii1{}, ii2{};
    142         std::list<int>::iterator ii4 = ii1;
    143         std::list<int>::const_iterator cii{};
    144         assert ( ii1 == ii2 );
    145         assert ( ii1 == ii4 );
    146 
    147         assert (!(ii1 != ii2 ));
    148 
    149         assert ( (ii1 == cii ));
    150         assert ( (cii == ii1 ));
    151         assert (!(ii1 != cii ));
    152         assert (!(cii != ii1 ));
    153 
    154         assert ( ii1 != c.cbegin());
    155         assert ( cii != c.begin());
    156     }
    157 #endif
    158 
    159 }
    160