1e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant//===----------------------------------------------------------------------===//
2e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant//
3e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant//                     The LLVM Compiler Infrastructure
4e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant//
5e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant// This file is dual licensed under the MIT and the University of Illinois Open
6e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant// Source Licenses. See LICENSE.TXT for details.
7e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant//
8e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant//===----------------------------------------------------------------------===//
9e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
10e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant// <list>
11e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
12e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant// Call erase(const_iterator first, const_iterator last); with second iterator from another container
13e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
145e57142c5902c3f73a6fdcb8cab55e88ffb43a56Howard Hinnant#if _LIBCPP_DEBUG >= 1
15e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
16e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant#define _LIBCPP_ASSERT(x, m) ((x) ? (void)0 : std::exit(0))
17e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
18e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant#include <list>
19e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant#include <cassert>
20e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant#include <exception>
21e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant#include <cstdlib>
22e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
23061d0cc4db18d17bf01ed14c5db0be098205bd47Marshall Clow#include "min_allocator.h"
2429f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant
25e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnantint main()
26e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant{
2729f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    {
28e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant    int a1[] = {1, 2, 3};
29e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant    std::list<int> l1(a1, a1+3);
30e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant    std::list<int> l2(a1, a1+3);
31e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant    std::list<int>::iterator i = l1.erase(l1.cbegin(), next(l2.cbegin()));
32e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant    assert(false);
3329f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    }
3429f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant#if __cplusplus >= 201103L
3529f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    {
3629f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    int a1[] = {1, 2, 3};
3729f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    std::list<int, min_allocator<int>> l1(a1, a1+3);
3829f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    std::list<int, min_allocator<int>> l2(a1, a1+3);
3929f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    std::list<int, min_allocator<int>>::iterator i = l1.erase(l1.cbegin(), next(l2.cbegin()));
4029f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    assert(false);
4129f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant    }
4229f7432ff3a5c503a98a66ae46dd571b651c88b5Howard Hinnant#endif
43e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant}
44e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
45e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant#else
46e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
47e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnantint main()
48e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant{
49e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant}
50e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant
51e1e96cb840c4587f51f23cd30ce1e0690846e552Howard Hinnant#endif
52