From f2551f357170b97a659ce98b43cd404e1b3e52d0 Mon Sep 17 00:00:00 2001 From: Kriang Lerdsuwanakij Date: Sun, 29 Dec 2002 17:01:45 +0000 Subject: [PATCH] re PR c++/2739 (g++ allows accessing private members) PR c++/2739 * g++.dg/other/access2.C: New test. From-SVN: r60605 --- gcc/testsuite/ChangeLog | 5 ++++ gcc/testsuite/g++.dg/other/access2.C | 35 ++++++++++++++++++++++++++++ 2 files changed, 40 insertions(+) create mode 100644 gcc/testsuite/g++.dg/other/access2.C diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8dc845141f5..3373f6d0caf 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2002-12-29 Kriang Lerdsuwanakij + + PR c++/2739 + * g++.dg/other/access2.C: New test. + 2002-12-29 Gabriel Dos Reis * g++.dg/other/anon-struct.C: No longer fails diff --git a/gcc/testsuite/g++.dg/other/access2.C b/gcc/testsuite/g++.dg/other/access2.C new file mode 100644 index 00000000000..c7dd77a043a --- /dev/null +++ b/gcc/testsuite/g++.dg/other/access2.C @@ -0,0 +1,35 @@ +// { dg-do compile } +// Origin: Dirk Mueller + +// PR c++/2739 +// Access to base class private static member. + +class Base { +private: + static int fooprivate; +protected: + static int fooprotected; +public: + static int foopublic; +}; + +class Derived : public Base { +public: + void test(); +}; + +int Base::fooprivate=42; // { dg-error "private" } +int Base::fooprotected=42; +int Base::foopublic=42; + +void Derived::test() { + if ( fooprivate ); // { dg-error "context" } + if ( fooprotected ); + if ( foopublic ); +} + +int main() +{ + Derived d; + d.test(); +} -- 2.30.2