diff options
author | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
---|---|---|
committer | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
commit | 554fd8c5195424bdbcabf5de30fdc183aba391bd (patch) | |
tree | 976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/g++.old-deja/g++.other/friend1.C | |
download | cbb-gcc-4.6.4-upstream.tar.bz2 cbb-gcc-4.6.4-upstream.tar.xz |
obtained gcc-4.6.4.tar.bz2 from upstream website;upstream
verified gcc-4.6.4.tar.bz2.sig;
imported gcc-4.6.4 source tree from verified upstream tarball.
downloading a git-generated archive based on the 'upstream' tag
should provide you with a source tree that is binary identical
to the one extracted from the above tarball.
if you have obtained the source via the command 'git clone',
however, do note that line-endings of files in your working
directory might differ from line-endings of the respective
files in the upstream repository.
Diffstat (limited to 'gcc/testsuite/g++.old-deja/g++.other/friend1.C')
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.other/friend1.C | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.other/friend1.C b/gcc/testsuite/g++.old-deja/g++.other/friend1.C new file mode 100644 index 000000000..56236ab33 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.other/friend1.C @@ -0,0 +1,88 @@ +// { dg-do assemble } +// f() should be able to access B::j, as of FDIS [class.protected]/1 + +// Subject: Re: [bug] Inheritance and friend access control broken +// References: <199803032141.WAA09332@piano.dptmaths.ens-cachan.fr> +// <orhg5ff544.fsf@iguacu.dcc.unicamp.br> +// <199803041125.MAA06937@cor.dptmaths.ens-cachan.fr> +// <orn2f6ek92.fsf@iguacu.dcc.unicamp.br> <19980304102900.46897@dgii.com> +// From: Alexandre Oliva <oliva@dcc.unicamp.br> +// Date: 06 Mar 1998 01:43:18 -0300 + +template <int*> +class X {}; + +template <typename T> +void g(); + +struct S; + +template <typename T> +struct R; + +class B { +protected: + int i; // { dg-error "" } in this context + static int j; +}; + +class D : public B { + friend void f(); + template <typename T> + friend void g(); + friend struct S; + template <typename T> + friend struct R; +}; + +struct S { + void h(); + X<&B::j> x; +}; + +template <typename T> +struct R { + void h(); + X<&B::j> x; +}; + +B b; +D d; + +void f() +{ + b.i = 3; // { dg-error "" } protected + d.i = 4; + B::j = 5; + D::j = 6; +} + +template <typename T> +void g() +{ + b.i = 3; // { dg-error "" } protected + d.i = 4; + B::j = 5; + D::j = 6; +} + +template void g<int>(); + +void S::h() +{ + b.i = 3; // { dg-error "" } protected + d.i = 4; + B::j = 5; + D::j = 6; +} + +template <typename T> +void R<T>::h() +{ + b.i = 3; // { dg-error "" } protected + d.i = 4; + B::j = 5; + D::j = 6; +} + +template struct R<double>; |