summaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.old-deja/g++.other/anon3.C
blob: 3f8b5cc002775226c8160ded184a37cff94ba3cd (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
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
// { dg-do run  }
// Copyright (C) 1999 Free Software Foundation, Inc.
// Contributed by Nathan Sidwell 20 May 1999 <nathan@acm.org>

// Although anon unions cannot have user defined member functions
// [class.union/2].  They should have implicitly defined copy ctors and
// and the like [class.copy/4].  Make sure we generate one of the correct
// signature and that it works ok.

extern "C" void abort();

struct A
{
  union
  {
    int a;
  };
};
union B
{
  int a;
};

static A Ctor(A const &src)
{
  A result(src);  // this should not cause a const violation
  
  result = src;   // and neither should this
  
  return result;
}

typedef __SIZE_TYPE__ size_t;

void *operator new(size_t, void *ptr)
{
  return ptr;
}

// check copy ctor and assignment for plain union
void check_union()
{
  B b1;
  B b2;
  
  b1.a = 5;
  b2.a = 6;
  b2 = b1;
  if(b2.a != 5)
    abort();
  
  b2.a = 6;
  new (&b2) B(b1);
  if(b2.a != 5)
    abort();
  
  return;
}

// check copy ctor and assignment for class containing anon-union
void check_union_member()
{
  A a1;
  A a2;
  
  a1.a = 5;
  a2.a = 6;
  a2 = a1;
  if(a2.a != 5)
    abort();
  
  a2.a = 6;
  new (&a2) A(a1);
  if(a2.a != 5)
    abort();
  
  return;
}

int main()
{
  check_union();
  check_union_member();
  
  return 0;
}