blob: dee7f219f2e47beb42f3f742cfd80c5655a8567a (
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
|
// Build don't link:
// Copyright (C) 1999 Free Software Foundation
// by Alexandre Oliva <oliva@dcc.unicamp.br>
// simplified from bug report by K. Haley <khaley@bigfoot.com>
// based on analysis by Martin v. Loewis
// [class.dtor]/11: delete must be implicitly checked for
// accessibility only in the definition of virtual destructors,
// implicitly defined or not.
struct foo {
foo() {}
private:
void operator delete(void *) {} // ERROR - private
} foo_;
struct bar : foo {
~bar() {
delete this; // ERROR - delete is private
// An implicit invocation of delete is emitted in destructors, but
// it should only be checked in virtual destructors
} // gets bogus error - not virtual - XFAIL *-*-*
} bar_;
struct baz : foo {
virtual ~baz() {} // ERROR - delete is private in vdtor
} baz_;
struct bad : baz {} bad_; // ERROR - delete is private in vdtor
|