// RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s typedef double A; template class B { typedef int A; }; template struct X : B { static A a; }; int a0[sizeof(X::a) == sizeof(double) ? 1 : -1]; // PR4365. template class Q; template class R : Q {T current;}; namespace test0 { template class Base { public: void instance_foo(); static void static_foo(); class Inner { public: void instance_foo(); static void static_foo(); }; }; template class Derived1 : Base { public: void test0() { Base::static_foo(); Base::instance_foo(); } void test1() { Base::Inner::static_foo(); Base::Inner::instance_foo(); // expected-error {{call to non-static member function without an object argument}} } static void test2() { Base::static_foo(); Base::instance_foo(); // expected-error {{call to non-static member function without an object argument}} } static void test3() { Base::Inner::static_foo(); Base::Inner::instance_foo(); // expected-error {{call to non-static member function without an object argument}} } }; template class Derived2 : Base::Inner { public: void test0() { Base::static_foo(); Base::instance_foo(); // expected-error {{call to non-static member function without an object argument}} } void test1() { Base::Inner::static_foo(); Base::Inner::instance_foo(); } static void test2() { Base::static_foo(); Base::instance_foo(); // expected-error {{call to non-static member function without an object argument}} } static void test3() { Base::Inner::static_foo(); Base::Inner::instance_foo(); // expected-error {{call to non-static member function without an object argument}} } }; void test0() { Derived1 d1; d1.test0(); d1.test1(); // expected-note {{in instantiation of member function}} d1.test2(); // expected-note {{in instantiation of member function}} d1.test3(); // expected-note {{in instantiation of member function}} Derived2 d2; d2.test0(); // expected-note {{in instantiation of member function}} d2.test1(); d2.test2(); // expected-note {{in instantiation of member function}} d2.test3(); // expected-note {{in instantiation of member function}} } } namespace test1 { template struct Base { void foo(T); // expected-note {{member is declared here}} }; template struct Derived : Base { void doFoo(T v) { foo(v); // expected-error {{explicit qualification required to use member 'foo' from dependent base class}} } }; template struct Derived; // expected-note {{requested here}} } namespace PR8966 { template class MyClassCore { }; template class MyClass : public MyClassCore { public: enum { N }; // static member declaration static const char* array [N]; void f() { MyClass::InBase = 17; } }; // static member definition template const char* MyClass::array [MyClass::N] = { "A", "B", "C" }; } namespace std { inline namespace v1 { template struct basic_ostream; } namespace inner { template struct vector {}; } using inner::vector; template struct pair {}; typedef basic_ostream ostream; extern ostream cout; std::ostream &operator<<(std::ostream &out, const char *); } namespace PR10053 { template 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(int&); // expected-note {{'f' should be declared prior to the call site}} A a; // expected-note {{in instantiation of member function}} namespace N { namespace M { template int g(T t) { f(t); // expected-error {{call to function 'f' that is neither visible in the template definition nor found by argument-dependent lookup}} }; } void f(char&); // expected-note {{'f' should be declared prior to the call site}} } void f(char&); int k = N::M::g(0);; // expected-note {{in instantiation of function}} namespace O { int f(char&); // expected-note {{candidate function not viable}} template struct C { static const int n = f(T()); // expected-error {{no matching function}} }; } int f(double); // no note, shadowed by O::f O::C c; // expected-note {{requested here}} // Example from www/compatibility.html namespace my_file { template T Squared(T x) { return Multiply(x, x); // expected-error {{neither visible in the template definition nor found by argument-dependent lookup}} } int Multiply(int x, int y) { // expected-note {{should be declared prior to the call site}} return x * y; } int main() { Squared(5); // expected-note {{here}} } } // Example from www/compatibility.html namespace my_file2 { template void Dump(const T& value) { std::cout << value << "\n"; // expected-error {{neither visible in the template definition nor found by argument-dependent lookup}} } namespace ns { struct Data {}; } std::ostream& operator<<(std::ostream& out, ns::Data data) { // expected-note {{should be declared prior to the call site or in namespace 'PR10053::my_file2::ns'}} return out << "Some data"; } void Use() { Dump(ns::Data()); // expected-note {{here}} } } namespace my_file2_a { template void Dump(const T &value) { print(std::cout, value); // expected-error 4{{neither visible in the template definition nor found by argument-dependent lookup}} } namespace ns { struct Data {}; } namespace ns2 { struct Data {}; } std::ostream &print(std::ostream &out, int); // expected-note-re {{should be declared prior to the call site{{$}}}} std::ostream &print(std::ostream &out, ns::Data); // expected-note {{should be declared prior to the call site or in namespace 'PR10053::my_file2_a::ns'}} std::ostream &print(std::ostream &out, std::vector); // expected-note {{should be declared prior to the call site or in namespace 'PR10053::my_file2_a::ns2'}} std::ostream &print(std::ostream &out, std::pair); // expected-note {{should be declared prior to the call site or in an associated namespace of one of its arguments}} void Use() { Dump(0); // expected-note {{requested here}} Dump(ns::Data()); // expected-note {{requested here}} Dump(std::vector()); // expected-note {{requested here}} Dump(std::pair()); // expected-note {{requested here}} } } namespace unary { template T Negate(const T& value) { return !value; // expected-error {{call to function 'operator!' that is neither visible in the template definition nor found by argument-dependent lookup}} } namespace ns { struct Data {}; } ns::Data operator!(ns::Data); // expected-note {{should be declared prior to the call site or in namespace 'PR10053::unary::ns'}} void Use() { Negate(ns::Data()); // expected-note {{requested here}} } } } namespace PR10187 { namespace A1 { template struct S { void f() { for (auto &a : e) __range(a); // expected-error {{undeclared identifier '__range'}} } int e[10]; }; } namespace A2 { template struct S { void f() { for (auto &a : e) __range(a); // expected-error {{undeclared identifier '__range'}} } T e[10]; }; void g() { S().f(); // expected-note {{here}} } struct X {}; void __range(X); void h() { S().f(); } } namespace B { template void g(); // expected-note {{not viable}} template void f() { g(T()); // expected-error {{no matching function}} } namespace { struct S {}; } void g(S); template void f(); // expected-note {{here}} } } namespace rdar11242625 { template struct Main { struct default_names { typedef int id; }; template struct TS { T2 q; }; }; struct Sub : public Main { TS<> ff; }; int arr[sizeof(Sub)]; } namespace PR11421 { template < unsigned > struct X { static const unsigned dimension = 3; template struct Y: Y { }; // expected-error{{circular inheritance between 'Y' and 'Y'}} }; typedef X<3> X3; X3::Y<>::iterator it; // expected-error {{no type named 'iterator' in 'PR11421::X<3>::Y<3>'}} } namespace rdar12629723 { template struct X { struct C : public C { }; // expected-error{{circular inheritance between 'rdar12629723::X::C' and 'rdar12629723::X::C'}} struct B; struct A : public B { // expected-note{{'rdar12629723::X::A' declared here}} virtual void foo() { } }; struct D : T::foo { }; struct E : D { }; }; template struct X::B : public A { // expected-error{{circular inheritance between 'rdar12629723::X::A' and 'rdar12629723::X::B'}} virtual void foo() { } }; } namespace test_reserved_identifiers { template void tempf(A a, B b) { a + b; // expected-error{{call to function 'operator+' that is neither visible in the template definition nor found by argument-dependent lookup}} } namespace __gnu_cxx { struct X {}; } namespace ns { struct Y {}; } void operator+(__gnu_cxx::X, ns::Y); // expected-note{{or in namespace 'test_reserved_identifiers::ns'}} void test() { __gnu_cxx::X x; ns::Y y; tempf(x, y); // expected-note{{in instantiation of}} } } // This test must live in the global namespace. struct PR14695_X {}; // FIXME: This note is bogus; it is the using directive which would need to move // to prior to the call site to fix the problem. namespace PR14695_A { void PR14695_f(PR14695_X); } // expected-note {{'PR14695_f' should be declared prior to the call site or in the global namespace}} template void PR14695_g(T t) { PR14695_f(t); } // expected-error {{call to function 'PR14695_f' that is neither visible in the template definition nor found by argument-dependent lookup}} using namespace PR14695_A; template void PR14695_g(PR14695_X); // expected-note{{requested here}} namespace OperatorNew { template void f(T t) { operator new(100, t); // expected-error{{call to function 'operator new' that is neither visible in the template definition nor found by argument-dependent lookup}} // FIXME: This should give the same error. new (t) int; } struct X {}; }; using size_t = decltype(sizeof(0)); void *operator new(size_t, OperatorNew::X); // expected-note-re {{should be declared prior to the call site{{$}}}} template void OperatorNew::f(OperatorNew::X); // expected-note {{instantiation of}} namespace PR19936 { template decltype(*T()) f() {} // expected-note {{previous}} template decltype(T() * T()) g() {} // expected-note {{previous}} // Create some overloaded operators so we build an overload operator call // instead of a builtin operator call for the dependent expression. enum E {}; int operator*(E); int operator*(E, E); // Check that they still profile the same. template decltype(*T()) f() {} // expected-error {{redefinition}} template decltype(T() * T()) g() {} // expected-error {{redefinition}} } template struct CT2 { template struct X; }; template int CT2::X<>; // expected-error {{template parameter list matching the non-templated nested type 'CT2' should be empty}} namespace DependentTemplateIdWithNoArgs { template void f() { T::template f(); } struct X { template static void f(); }; void g() { f(); } } namespace DependentUnresolvedUsingTemplate { template struct X : T { using T::foo; void f() { this->template foo(); } // expected-error {{does not refer to a template}} void g() { this->template foo<>(); } // expected-error {{does not refer to a template}} void h() { this->template foo(); } // expected-error {{does not refer to a template}} }; struct A { template int foo(); }; struct B { int foo(); }; // expected-note 3{{non-template here}} void test(X xa, X xb) { xa.f(); xa.g(); xa.h(); xb.f(); // expected-note {{instantiation of}} xb.g(); // expected-note {{instantiation of}} xb.h(); // expected-note {{instantiation of}} } } namespace PR37680 { template struct b : a { using a::add; template int add() { return this->template add(0); } }; struct a { template int add(...); void add(int); }; int f(b ba) { return ba.add<0>(); } }