Home | History | Annotate | Download | only in list.modifiers
      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 // void pop_back();
     13 
     14 #if _LIBCPP_DEBUG >= 1
     15 #define _LIBCPP_ASSERT(x, m) ((x) ? (void)0 : std::exit(0))
     16 #endif
     17 
     18 #include <list>
     19 #include <cassert>
     20 
     21 #include "min_allocator.h"
     22 
     23 int main()
     24 {
     25     {
     26     int a[] = {1, 2, 3};
     27     std::list<int> c(a, a+3);
     28     c.pop_back();
     29     assert(c == std::list<int>(a, a+2));
     30     c.pop_back();
     31     assert(c == std::list<int>(a, a+1));
     32     c.pop_back();
     33     assert(c.empty());
     34 #if _LIBCPP_DEBUG >= 1
     35         c.pop_back();
     36         assert(false);
     37 #endif
     38     }
     39 #if __cplusplus >= 201103L
     40     {
     41     int a[] = {1, 2, 3};
     42     std::list<int, min_allocator<int>> c(a, a+3);
     43     c.pop_back();
     44     assert((c == std::list<int, min_allocator<int>>(a, a+2)));
     45     c.pop_back();
     46     assert((c == std::list<int, min_allocator<int>>(a, a+1)));
     47     c.pop_back();
     48     assert(c.empty());
     49 #if _LIBCPP_DEBUG >= 1
     50         c.pop_back();
     51         assert(false);
     52 #endif
     53     }
     54 #endif
     55 }
     56