[Flang] remove whole-archive option for AIX linker (#76039)
[llvm-project.git] / clang / test / CXX / class.access / p6.cpp
blob510aaa208982f18f252095975d747f4f20c37556
1 // RUN: %clang_cc1 -fsyntax-only -verify %s
3 // C++0x [class.access]p6:
4 // All access controls in [class.access] affect the ability to
5 // access a class member name from a particular scope. For purposes
6 // of access control, the base-specifiers of a class and the
7 // definitions of class members that appear outside of the class
8 // definition are considered to be within the scope of that
9 // class. In particular, access controls apply as usual to member
10 // names accessed as part of a function return type, even though it
11 // is not possible to determine the access privileges of that use
12 // without first parsing the rest of the function
13 // declarator. Similarly, access control for implicit calls to the
14 // constructors, the conversion functions, or the destructor called
15 // to create and destroy a static data member is performed as if
16 // these calls appeared in the scope of the member's class.
18 struct Public {}; struct Protected {}; struct Private {};
20 namespace test0 {
21 class A {
22 typedef int type; // expected-note {{declared private here}}
23 type foo();
26 A::type foo() { } // expected-error {{'type' is a private member}}
27 A::type A::foo() { }
30 // conversion decls
31 namespace test1 {
32 class A {
33 public:
34 A();
35 operator Public ();
36 A(Public);
37 protected:
38 operator Protected (); // expected-note {{declared protected here}}
39 A(Protected); // expected-note {{declared protected here}}
40 private:
41 operator Private (); // expected-note {{declared private here}}
42 A(Private); // expected-note {{declared private here}}
45 void test() {
46 A a;
47 Public pub = a;
48 Protected prot = a; // expected-error {{'operator Protected' is a protected member}}
49 Private priv = a; // expected-error {{'operator Private' is a private member}}
50 A apub = pub;
51 A aprot = prot; // expected-error {{protected constructor}}
52 A apriv = priv; // expected-error {{private constructor}}
56 // PR6967
57 namespace test2 {
58 class A {
59 public:
60 template <class T> static void set(T &t, typename T::type v) {
61 t.value = v;
63 template <class T> static typename T::type get(const T &t) {
64 return t.value;
68 class B {
69 friend class A;
71 private:
72 typedef int type;
73 type value;
76 int test() {
77 B b;
78 A::set(b, 0);
79 return A::get(b);
83 namespace test3 {
84 class Green {}; class Blue {};
86 // We have to wrap this in a class because a partial specialization
87 // isn't actually in the context of the template.
88 struct Outer {
89 template <class T, class Nat> class A {
93 template <class T> class Outer::A<T, typename T::nature> {
94 public:
95 static void foo(); // expected-note {{'Outer::A<B, Green>::foo' declared here}}
98 class B {
99 private: typedef Green nature;
100 friend class Outer;
103 void test() {
104 Outer::A<B, Green>::foo();
105 Outer::A<B, Blue>::foo(); // expected-error {{no member named 'foo' in 'test3::Outer::A<test3::B, test3::Blue>'; did you mean 'Outer::A<B, Green>::foo'?}}
109 namespace test4 {
110 template <class T> class A {
111 private: typedef int type;
112 template <class U> friend void foo(U &, typename U::type);
115 template <class U> void foo(U &, typename U::type) {}
117 void test() {
118 A<int> a;
119 foo(a, 0);
123 // PR7644
124 namespace test5 {
125 class A {
126 enum Enum { E0, E1, E2 }; // expected-note 4 {{declared private here}}
127 template <Enum> void foo();
128 template <Enum> class bar;
131 template <A::Enum en> void A::foo() {}
132 template <A::Enum en> class A::bar {};
134 template <A::Enum en> void foo() {} // expected-error {{'Enum' is a private member of 'test5::A'}}
135 template <A::Enum en> class bar {}; // expected-error {{'Enum' is a private member of 'test5::A'}}
137 class B {
138 template <A::Enum en> void foo() {} // expected-error {{'Enum' is a private member of 'test5::A'}}
139 template <A::Enum en> class bar {}; // expected-error {{'Enum' is a private member of 'test5::A'}}
143 namespace test6 {
144 class A {
145 public: class public_inner {};
146 protected: class protected_inner {};
147 private: class private_inner {}; // expected-note {{declared private here}}
150 class B : A {
151 public_inner a;
152 protected_inner b;
153 private_inner c; // expected-error {{'private_inner' is a private member of 'test6::A'}}
157 // PR9229
158 namespace test7 {
159 void foo(int arg[1]);
160 class A {
161 void check();
163 class B {
164 friend class A;
165 A ins;
167 void A::check() {
168 void foo(int arg[__builtin_offsetof(B, ins)]);
172 namespace test8 {
173 class A {
174 typedef void* (A::*UnspecifiedBoolType)() const;
175 operator UnspecifiedBoolType() const; // expected-note {{implicitly declared private here}}
178 void test(A &a) {
179 if (a) return; // expected-error-re {{'operator void *(test8::A::*)(){{( __attribute__\(\(thiscall\)\))?}} const' is a private member of 'test8::A'}}
183 namespace test9 {
184 class A {
185 operator char*() const; // expected-note {{implicitly declared private here}}
188 void test(A &a) {
189 delete a; // expected-error {{'operator char *' is a private member of 'test9::A'}}