1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
// PR c++/46056
// Check that range-based for loop calls destructors
// when required
// { dg-do run { target c++11 } }
extern "C" void abort();
int value_counter = 0, it_counter = 0, seq_counter = 0;
struct Int
{
int x;
Int(int v)
:x(v)
{
++value_counter;
}
Int(const Int &o)
:x(o.x)
{
++value_counter;
}
~Int()
{
--value_counter;
}
};
struct iterator
{
int x;
iterator(int v)
:x(v)
{
++it_counter;
}
iterator(const iterator &o)
:x(o.x)
{
++it_counter;
}
~iterator()
{
--it_counter;
}
iterator &operator ++() { ++x; return *this; }
int operator *() { return x; }
bool operator != (const iterator &o) { return x != o.x; }
};
struct container
{
int min, max;
container(int a, int b) :min(a), max(b)
{
++seq_counter;
}
container(const container &) = delete;
~container()
{
--seq_counter;
}
};
iterator begin(container &c)
{
return iterator(c.min);
}
iterator end(container &c)
{
return iterator(c.max + 1);
}
int main()
{
for (Int x : container(0, 10))
{
if (value_counter != 1) abort();
if (it_counter != 2) abort();
if (seq_counter != 1) abort();
}
if (value_counter != 0) abort();
if (it_counter != 0) abort();
if (seq_counter != 0) abort();
try
{
for (Int x : container(0, 10))
{
if (value_counter != 1) abort();
if (it_counter != 2) abort();
if (seq_counter != 1) abort();
}
if (value_counter != 0) abort();
if (it_counter != 0) abort();
if (seq_counter != 0) abort();
for (Int x : container(0, 10))
{
if (value_counter != 1) abort();
if (it_counter != 2) abort();
if (seq_counter != 1) abort();
if (x.x == 5)
throw 0;
}
}
catch (int)
{
if (value_counter != 0) abort();
if (it_counter != 0) abort();
if (seq_counter != 0) abort();
}
return 0;
}
|