summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaTemplate/dependent-names-no-std.cpp
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2011-06-08 10:13:17 +0000
committerChandler Carruth <chandlerc@gmail.com>2011-06-08 10:13:17 +0000
commitd54186ac33c555538fc5c7e838c0f5e5d3931c3f (patch)
tree14670feafb3ec6e9d1679854dfda8801da5eb967 /clang/test/SemaTemplate/dependent-names-no-std.cpp
parent0169ec0988f9cc0d8a4c2ee05a79871e1ad4a598 (diff)
downloadbcm5719-llvm-d54186ac33c555538fc5c7e838c0f5e5d3931c3f.tar.gz
bcm5719-llvm-d54186ac33c555538fc5c7e838c0f5e5d3931c3f.zip
Fix a regression in the two-phase lookup diagnostics that switching the
namespace set algorithm (re-)introduced. We may not have seen the 'std' namespace, but we should still suggested associated namespaces. Easy fix, but a bit annoying to test. llvm-svn: 132744
Diffstat (limited to 'clang/test/SemaTemplate/dependent-names-no-std.cpp')
-rw-r--r--clang/test/SemaTemplate/dependent-names-no-std.cpp21
1 files changed, 21 insertions, 0 deletions
diff --git a/clang/test/SemaTemplate/dependent-names-no-std.cpp b/clang/test/SemaTemplate/dependent-names-no-std.cpp
new file mode 100644
index 00000000000..e9ac99faf65
--- /dev/null
+++ b/clang/test/SemaTemplate/dependent-names-no-std.cpp
@@ -0,0 +1,21 @@
+// RUN: %clang_cc1 -fsyntax-only -verify %s
+//
+// The whole point of this test is to verify certain diagnostics work in the
+// absence of namespace 'std'.
+
+namespace PR10053 {
+ namespace ns {
+ struct Data {};
+ }
+
+ template<typename T> struct A {
+ T t;
+ A() {
+ f(t); // expected-error {{call to function 'f' that is neither visible in the template definition nor found by argument dependent lookup}}
+ }
+ };
+
+ void f(ns::Data); // expected-note {{in namespace 'PR10053::ns'}}
+
+ A<ns::Data> a; // expected-note {{in instantiation of member function}}
+}
OpenPOWER on IntegriCloud