summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/nested-name-spec.cpp
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2008-11-08 17:17:31 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2008-11-08 17:17:31 +0000
commit16ac9be7f0b2a7c716adddc92b7ea5b04fe94ba5 (patch)
tree02d1b08d174886a7f7776e44c65cb7af65ae3fff /clang/test/SemaCXX/nested-name-spec.cpp
parent430a58edd8679fc603b5e6d16e995d9b5eb90c3e (diff)
downloadbcm5719-llvm-16ac9be7f0b2a7c716adddc92b7ea5b04fe94ba5.tar.gz
bcm5719-llvm-16ac9be7f0b2a7c716adddc92b7ea5b04fe94ba5.zip
Implement Sema support for C++ nested-name-specifiers.
llvm-svn: 58916
Diffstat (limited to 'clang/test/SemaCXX/nested-name-spec.cpp')
-rw-r--r--clang/test/SemaCXX/nested-name-spec.cpp56
1 files changed, 56 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/nested-name-spec.cpp b/clang/test/SemaCXX/nested-name-spec.cpp
new file mode 100644
index 00000000000..bbca04cd9a4
--- /dev/null
+++ b/clang/test/SemaCXX/nested-name-spec.cpp
@@ -0,0 +1,56 @@
+// RUN: clang -fsyntax-only -verify %s
+namespace A {
+ struct C {
+ static int cx;
+ };
+ int ax;
+ void Af();
+}
+
+A:: ; // expected-error {{expected unqualified-id}}
+::A::ax::undef ex3; // expected-error {{expected a class or namespace}} expected-error {{expected '=', ',', ';', 'asm', or '__attribute__' after declarator}}
+A::undef1::undef2 ex4; // expected-error {{no member named 'undef1'}} expected-error {{expected '=', ',', ';', 'asm', or '__attribute__' after declarator}}
+
+class C2 {
+ void m();
+ int x;
+};
+
+void C2::m() {
+ x = 0;
+}
+
+namespace B {
+ void ::A::Af() {} // expected-error {{definition or redeclaration for 'Af' not in a namespace enclosing 'A'}}
+}
+
+void f1() {
+ void A::Af(); // expected-error {{definition or redeclaration for 'Af' not allowed inside a function}}
+}
+
+void f2() {
+ A:: ; // expected-error {{expected unqualified-id}}
+ A::C::undef = 0; // expected-error {{no member named 'undef'}}
+ ::A::C::cx = 0;
+ int x = ::A::ax = A::C::cx;
+ x = sizeof(A::C);
+ x = sizeof(::A::C::cx);
+}
+
+A::C c1;
+struct A::C c2;
+struct S : public A::C {};
+struct A::undef; // expected-error {{'undef' does not name a tag member in the specified scope}}
+
+void f3() {
+ N::x = 0; // expected-error {{use of undeclared identifier 'N'}}
+ int N;
+ N::x = 0; // expected-error {{expected a class or namespace}}
+ { int A; A::ax = 0; }
+ { enum A {}; A::ax = 0; }
+ { enum A { A }; A::ax = 0; }
+ { typedef int A; A::ax = 0; }
+ { typedef int A(); A::ax = 0; }
+ { typedef A::C A; A::ax = 0; } // expected-error {{no member named 'ax'}}
+ { typedef A::C A; A::cx = 0; }
+}
OpenPOWER on IntegriCloud