summaryrefslogtreecommitdiff
path: root/ACE/tests/Compiler_Features_28_Test.cpp
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;
}