aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.old-deja/g++.mike/p2846b.C
blob: 0fb8217456e672c08ecd7d2f9ba31ae7a90b88b9 (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
// Shows that problem of initializing one object's secondary base from
// another object via a user defined copy constructor for that base,
// the pointer for the secondary vtable is not set after implicit
// copying of the outer class, but rather has the pointer to the main
// vtable for the secondary base left over from the user defined copy
// constructor for that base.

// Correct answer is B::beefy.
// g++ prints A::beefy, which is wrong.  Cfront gets it right.

// prms-id: 2846

extern "C" int printf(const char *, ...);
extern "C" void exit(int);

class B;

class A {
 public:

  A(void){}
  A(const A&){}

  virtual void print(void) const { }
  B compute(void) const;
};

class C {
public:
  C() { }
  C(C& o) { }		// with it, things are wrong, without it, they're ok
  virtual void beefy(void) const { printf("A::beefy\n"); exit(1); }
};

class B : private A, public C {
public:
  B(const A& x, int){}
  void beefy(void) const { printf("B::beefy\n"); }
};

B A::compute(void) const
{
  B sub(*this, 1);
  return sub;
}

main ()
{
  A titi;
  titi.compute().beefy();
  return 0;
}