blob: a31da3380f4230be72059f82e04504eb79255af3 (
plain)
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
|
/**
* This program checks if the compiler doesn't have a certain bug
* that we encountered when testing C++11 features
*/
#include "test_config.h"
#include <cstdint>
enum class OPERATIONS
{
ADD_OBJECT_POLICY,
ADD_CURRENT_POLICY,
LAST_OPERATION
};
/// Using this to iterate over the OPERATIONS enum
OPERATIONS operator++(OPERATIONS& x) { return x = static_cast<OPERATIONS>(static_cast<uint16_t>(x) + 1); }
OPERATIONS operator*(OPERATIONS c) {return c;}
OPERATIONS begin(OPERATIONS ) {return OPERATIONS::ADD_OBJECT_POLICY;}
OPERATIONS end(OPERATIONS ) {return OPERATIONS::LAST_OPERATION;}
int
run_main (int, ACE_TCHAR *[])
{
ACE_START_TEST (ACE_TEXT("Compiler_Features_28_Test"));
int16_t count = 0;
for (OPERATIONS op : OPERATIONS ())
{
if (op == OPERATIONS::ADD_OBJECT_POLICY && count != 0)
ACE_ERROR ((LM_ERROR, "Wrong order when using range based for loop\n"));
if (op == OPERATIONS::ADD_CURRENT_POLICY && count != 1)
ACE_ERROR ((LM_ERROR, "Wrong order when using range based for loop\n"));
if (op == OPERATIONS::LAST_OPERATION && count != 2)
ACE_ERROR ((LM_ERROR, "Wrong order when using range based for loop\n"));
++count;
}
ACE_END_TEST;
return 0;
}
|