2013-06-23 06:03:31 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -std=c++11 -verify %s
|
2009-08-28 23:18:15 +08:00
|
|
|
|
|
|
|
template<typename T> struct A {
|
|
|
|
void f() { }
|
2009-11-18 10:36:19 +08:00
|
|
|
struct N { }; // expected-note{{target of using declaration}}
|
2009-08-28 23:18:15 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
template<typename T> struct B : A<T> {
|
|
|
|
using A<T>::f;
|
2009-11-18 10:36:19 +08:00
|
|
|
using A<T>::N; // expected-error{{dependent using declaration resolved to type without 'typename'}}
|
2009-08-28 23:18:15 +08:00
|
|
|
|
|
|
|
using A<T>::foo; // expected-error{{no member named 'foo'}}
|
2009-12-08 15:46:18 +08:00
|
|
|
using A<double>::f; // expected-error{{using declaration refers into 'A<double>::', which is not a base class of 'B<int>'}}
|
2009-08-28 23:18:15 +08:00
|
|
|
};
|
|
|
|
|
2010-03-10 19:27:22 +08:00
|
|
|
B<int> a; // expected-note{{in instantiation of template class 'B<int>' requested here}}
|
2009-08-29 01:57:07 +08:00
|
|
|
|
|
|
|
template<typename T> struct C : A<T> {
|
|
|
|
using A<T>::f;
|
|
|
|
|
|
|
|
void f() { };
|
|
|
|
};
|
2009-08-29 08:56:38 +08:00
|
|
|
|
|
|
|
template <typename T> struct D : A<T> {
|
|
|
|
using A<T>::f;
|
|
|
|
|
|
|
|
void f();
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename T> void D<T>::f() { }
|
2009-08-29 09:06:32 +08:00
|
|
|
|
|
|
|
template<typename T> struct E : A<T> {
|
|
|
|
using A<T>::f;
|
|
|
|
|
|
|
|
void g() { f(); }
|
|
|
|
};
|
2009-12-05 06:46:56 +08:00
|
|
|
|
|
|
|
namespace test0 {
|
|
|
|
struct Base {
|
|
|
|
int foo;
|
|
|
|
};
|
|
|
|
template<typename T> struct E : Base {
|
|
|
|
using Base::foo;
|
|
|
|
};
|
|
|
|
|
|
|
|
template struct E<int>;
|
|
|
|
}
|
2010-11-04 16:48:52 +08:00
|
|
|
|
|
|
|
// PR7896
|
|
|
|
namespace PR7896 {
|
|
|
|
template <class T> struct Foo {
|
|
|
|
int k (float);
|
|
|
|
};
|
|
|
|
struct Baz {
|
|
|
|
int k (int);
|
|
|
|
};
|
|
|
|
template <class T> struct Bar : public Foo<T>, Baz {
|
|
|
|
using Foo<T>::k;
|
|
|
|
using Baz::k;
|
|
|
|
int foo() {
|
|
|
|
return k (1.0f);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
template int Bar<int>::foo();
|
|
|
|
}
|
2011-09-08 04:25:59 +08:00
|
|
|
|
|
|
|
// PR10883
|
|
|
|
namespace PR10883 {
|
|
|
|
template <typename T>
|
|
|
|
class Base {
|
|
|
|
public:
|
|
|
|
typedef long Container;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
class Derived : public Base<T> {
|
|
|
|
public:
|
|
|
|
using Base<T>::Container;
|
|
|
|
|
|
|
|
void foo(const Container& current); // expected-error {{unknown type name 'Container'}}
|
|
|
|
};
|
|
|
|
}
|
2013-06-20 08:04:23 +08:00
|
|
|
|
|
|
|
template<typename T> class UsingTypenameNNS {
|
|
|
|
using typename T::X;
|
|
|
|
typename X::X x;
|
|
|
|
};
|
2013-06-23 06:03:31 +08:00
|
|
|
|
|
|
|
namespace aliastemplateinst {
|
|
|
|
template<typename T> struct A { };
|
|
|
|
template<typename T> using APtr = A<T*>; // expected-note{{previous use is here}}
|
|
|
|
|
2016-04-06 05:13:54 +08:00
|
|
|
template struct APtr<int>; // expected-error{{elaborated type refers to a type alias template}}
|
2013-06-23 06:03:31 +08:00
|
|
|
}
|
2016-10-10 22:26:40 +08:00
|
|
|
|
|
|
|
namespace DontDiagnoseInvalidTest {
|
|
|
|
template <bool Value> struct Base {
|
|
|
|
static_assert(Value, ""); // expected-error {{static_assert failed}}
|
|
|
|
};
|
|
|
|
struct Derived : Base<false> { // expected-note {{requested here}}
|
|
|
|
using Base<false>::Base; // OK. Don't diagnose that 'Base' isn't a base class of Derived.
|
|
|
|
};
|
|
|
|
} // namespace DontDiagnoseInvalidTest
|