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;
}
|