|  | // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s | 
|  | // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s | 
|  |  | 
|  | extern "C" { void f(bool); } | 
|  |  | 
|  | namespace std { | 
|  | using ::f; | 
|  | inline void f() { return f(true); } | 
|  | } | 
|  |  | 
|  | namespace M { | 
|  | void f(float); | 
|  | } | 
|  |  | 
|  | namespace N { | 
|  | using M::f; | 
|  | void f(int) { } // expected-note{{previous}} | 
|  |  | 
|  | void f(int) { } // expected-error{{redefinition}} | 
|  | } | 
|  |  | 
|  | namespace N { | 
|  | void f(double); | 
|  | void f(long); | 
|  | } | 
|  |  | 
|  | struct X0 { | 
|  | void operator()(int); | 
|  | void operator()(long); | 
|  | }; | 
|  |  | 
|  | struct X1 : X0 { | 
|  | void operator()(float&); | 
|  | using X0::operator(); | 
|  |  | 
|  | void test() { | 
|  | (*this)(1); | 
|  | } | 
|  | }; | 
|  |  | 
|  | struct A { void f(); }; | 
|  | struct B : A { }; | 
|  | class C : B { using B::f; }; | 
|  |  | 
|  | // PR5751: Resolve overloaded functions through using decls. | 
|  | namespace O { | 
|  | void f(int i); | 
|  | void f(double d); | 
|  | } | 
|  | namespace P { | 
|  | void f(); | 
|  | void g(void (*ptr)(int)); | 
|  | using O::f; | 
|  | void test() { | 
|  | f(); | 
|  | f(1); | 
|  | void (*f_ptr1)(double) = f; | 
|  | void (*f_ptr2)() = f; | 
|  | g(f); | 
|  | } | 
|  | } | 
|  |  | 
|  | // Make sure that ADL can find names brought in by using decls. | 
|  | namespace test0 { | 
|  | namespace ns { | 
|  | class Foo {}; | 
|  |  | 
|  | namespace inner { | 
|  | void foo(char *); // expected-note {{no known conversion}} | 
|  | } | 
|  |  | 
|  | using inner::foo; | 
|  | } | 
|  |  | 
|  | void test(ns::Foo *p) { | 
|  | foo(*p); // expected-error {{no matching function for call to 'foo'}} | 
|  | } | 
|  | } | 
|  |  | 
|  | // Redeclarations! | 
|  | namespace test1 { | 
|  | namespace ns0 { struct Foo {}; } | 
|  | namespace A { void foo(ns0::Foo *p, int y, int z); } | 
|  | namespace ns2 { using A::foo; } | 
|  | namespace ns1 { struct Bar : ns0::Foo {}; } | 
|  | namespace A { void foo(ns0::Foo *p, int y, int z = 0); } // expected-note {{candidate}} | 
|  | namespace ns1 { using A::foo; } | 
|  | namespace ns2 { struct Baz : ns1::Bar {}; } | 
|  | namespace A { void foo(ns0::Foo *p, int y = 0, int z); } | 
|  |  | 
|  | void test(ns2::Baz *p) { | 
|  | foo(p, 0, 0); // okay! | 
|  | foo(p, 0); // should be fine! | 
|  | foo(p); // expected-error {{no matching function}} | 
|  | } | 
|  | } | 
|  |  | 
|  | namespace test2 { | 
|  | namespace ns { int foo; } | 
|  | template <class T> using ns::foo; // expected-error {{cannot template a using declaration}} | 
|  |  | 
|  | // PR8022 | 
|  | struct A { | 
|  | template <typename T> void f(T); | 
|  | }; | 
|  | class B : A { | 
|  | template <typename T> using A::f<T>; // expected-error {{cannot template a using declaration}} | 
|  | }; | 
|  | } | 
|  |  | 
|  | // PR8756 | 
|  | namespace foo | 
|  | { | 
|  | class Class1; // expected-note{{forward declaration}} | 
|  | class Class2 | 
|  | { | 
|  | using ::foo::Class1::Function; // expected-error{{incomplete type 'foo::Class1' named in nested name specifier}} | 
|  | }; | 
|  | } | 
|  |  | 
|  | // Don't suggest non-typenames for positions requiring typenames. | 
|  | namespace using_suggestion_tyname_val { | 
|  | namespace N { void FFF() {} } | 
|  | using typename N::FFG; // expected-error {{no member named 'FFG' in namespace 'using_suggestion_tyname_val::N'}} | 
|  | } | 
|  |  | 
|  | namespace using_suggestion_member_tyname_val { | 
|  | class CCC { public: void AAA() { } }; | 
|  | class DDD : public CCC { public: using typename CCC::AAB; }; // expected-error {{no member named 'AAB' in 'using_suggestion_member_tyname_val::CCC'}} | 
|  | } | 
|  |  | 
|  | namespace using_suggestion_tyname_val_dropped_specifier { | 
|  | void FFF() {} | 
|  | namespace N { } | 
|  | using typename N::FFG; // expected-error {{no member named 'FFG' in namespace 'using_suggestion_tyname_val_dropped_specifier::N'}} | 
|  | } | 
|  |  | 
|  | // Currently hints aren't provided to drop out the incorrect M::. | 
|  | namespace using_suggestion_ty_dropped_nested_specifier { | 
|  | namespace N { | 
|  | class AAA {}; // expected-note {{'N::AAA' declared here}} | 
|  | namespace M { } | 
|  | } | 
|  | using N::M::AAA; // expected-error {{no member named 'AAA' in namespace 'using_suggestion_ty_dropped_nested_specifier::N::M'; did you mean 'N::AAA'?}} | 
|  | } | 
|  |  | 
|  | namespace using_suggestion_tyname_ty_dropped_nested_specifier { | 
|  | namespace N { | 
|  | class AAA {}; // expected-note {{'N::AAA' declared here}} | 
|  | namespace M { } | 
|  | } | 
|  | using typename N::M::AAA; // expected-error {{no member named 'AAA' in namespace 'using_suggestion_tyname_ty_dropped_nested_specifier::N::M'; did you mean 'N::AAA'?}} | 
|  | } | 
|  |  | 
|  | namespace using_suggestion_val_dropped_nested_specifier { | 
|  | namespace N { | 
|  | void FFF() {} // expected-note {{'N::FFF' declared here}} | 
|  | namespace M { } | 
|  | } | 
|  | using N::M::FFF; // expected-error {{no member named 'FFF' in namespace 'using_suggestion_val_dropped_nested_specifier::N::M'; did you mean 'N::FFF'?}} | 
|  | } | 
|  |  | 
|  | namespace UsingDeclVsHiddenName { | 
|  | namespace A { | 
|  | enum HiddenTag1 {}; // expected-note {{previous use is here}} | 
|  | enum HiddenTag2 {}; // expected-note {{target}} | 
|  | int HiddenFn1; // expected-note {{target}} | 
|  | int HiddenFn2; // expected-note {{target}} | 
|  | int HiddenLocalExtern1; | 
|  | int HiddenLocalExtern2; | 
|  | } | 
|  |  | 
|  | namespace B { | 
|  | using A::HiddenTag1; | 
|  | using A::HiddenFn1; // expected-note {{using declaration}} | 
|  | using A::HiddenLocalExtern1; | 
|  |  | 
|  | struct S { | 
|  | friend struct HiddenTag1; // expected-error {{tag type that does not match previous}} | 
|  | friend struct HiddenTag2; // expected-note {{conflicting declaration}} | 
|  | friend void HiddenFn1(); // expected-error {{cannot befriend target of using declaration}} | 
|  | friend void HiddenFn2(); // expected-note {{conflicting declaration}} | 
|  | void f() { | 
|  | // OK, these are not in the scope of namespace B, even though they're | 
|  | // members of the namespace. | 
|  | void HiddenLocalExtern1(); | 
|  | void HiddenLocalExtern2(); | 
|  | } | 
|  | }; | 
|  |  | 
|  | using A::HiddenTag2; // expected-error {{conflicts with declaration already in scope}} | 
|  | using A::HiddenFn2; // expected-error {{conflicts with declaration already in scope}} | 
|  | using A::HiddenLocalExtern2; | 
|  | } | 
|  | } | 
|  |  | 
|  | namespace PR19171 { | 
|  | struct Z { | 
|  | Z(); | 
|  | }; | 
|  |  | 
|  | typedef struct { | 
|  | Z i; | 
|  | } S; | 
|  |  | 
|  | struct Y : S { | 
|  | using S::S; | 
|  | #if __cplusplus < 201103L | 
|  | // expected-error@-2 {{no member named 'S' in 'PR19171::S'}} | 
|  | #endif | 
|  | }; | 
|  |  | 
|  | // [namespace.udecl]p3: In a using-declaration used as a member-declaration, | 
|  | // the nested-name-specifier shall name a base class of the class being defined. | 
|  | // If such a using-declaration names a constructor, the nested-name-specifier | 
|  | // shall name a direct base class of the class being defined; | 
|  |  | 
|  | struct B_blah { }; | 
|  | struct C_blah : B_blah { C_blah(int); }; // expected-note 0-1{{declared here}} | 
|  | struct D1 : C_blah { | 
|  | // FIXME: We should be able to correct this in C++11 mode. | 
|  | using B_blah::C_blah; // expected-error-re {{no member named 'C_blah' in 'PR19171::B_blah'{{$}}}} | 
|  | }; | 
|  | struct D2 : C_blah { | 
|  | // Somewhat bizarrely, this names the injected-class-name of B_blah within | 
|  | // C_blah, and is valid. | 
|  | using C_blah::B_blah; | 
|  | }; | 
|  | struct D3 : C_blah { | 
|  | using C_blah::D_blah; | 
|  | #if __cplusplus < 201103L | 
|  | // expected-error-re@-2 {{no member named 'D_blah' in 'PR19171::C_blah'{{$}}}} | 
|  | #else | 
|  | // expected-error@-4 {{no member named 'D_blah' in 'PR19171::C_blah'; did you mean 'C_blah'?}} | 
|  | #endif | 
|  | }; | 
|  | #if __cplusplus >= 201103L | 
|  | D3 d3(0); // ok | 
|  | #endif | 
|  |  | 
|  | struct E { }; | 
|  | struct EE { int EE; }; | 
|  | struct F : E { | 
|  | using E::EE; // expected-error-re {{no member named 'EE' in 'PR19171::E'{{$}}}} | 
|  | }; | 
|  |  | 
|  | struct TypoDuplicate { // expected-note 0-4{{here}} | 
|  | TypoDuplicate(int); | 
|  | void foobar(); // expected-note 2{{here}} | 
|  | }; | 
|  | struct TypoDuplicateDerived1 : TypoDuplicate { | 
|  | #if __cplusplus >= 201103L | 
|  | using TypoDuplicate::TypoFuplicate; // expected-error {{did you mean 'TypoDuplicate'}} expected-note {{previous}} | 
|  | using TypoDuplicate::TypoDuplicate; // expected-error {{redeclaration}} | 
|  | #endif | 
|  | using TypoDuplicate::goobar; // expected-error {{did you mean 'foobar'}} expected-note {{previous}} | 
|  | using TypoDuplicate::foobar; // expected-error {{redeclaration}} | 
|  | }; | 
|  | struct TypoDuplicateDerived2 : TypoDuplicate { | 
|  | #if __cplusplus >= 201103L | 
|  | using TypoFuplicate::TypoDuplicate; // expected-error {{did you mean 'TypoDuplicate'}} expected-note {{previous}} | 
|  | using TypoDuplicate::TypoDuplicate; // expected-error {{redeclaration}} | 
|  | #endif | 
|  | }; | 
|  | struct TypoDuplicateDerived3 : TypoDuplicate { | 
|  | #if __cplusplus >= 201103L | 
|  | // FIXME: Don't suggest a correction that would lead to a redeclaration | 
|  | // error here... or at least diagnose the error. | 
|  | using TypoDuplicate::TypoDuplicate; | 
|  | using TypoDuplicate::TypoFuplicate; // expected-error {{did you mean 'TypoDuplicate'}} | 
|  | #endif | 
|  | using TypoDuplicate::foobar; | 
|  | using TypoDuplicate::goobar; // expected-error {{did you mean 'foobar'}} | 
|  | }; | 
|  | struct TypoDuplicateDerived4 : TypoDuplicate { | 
|  | #if __cplusplus >= 201103L | 
|  | using TypoDuplicate::TypoDuplicate; // expected-note {{previous}} | 
|  | using TypoFuplicate::TypoDuplicate; // expected-error {{did you mean 'TypoDuplicate'}} expected-error {{redeclaration}} | 
|  | #endif | 
|  | }; | 
|  | } | 
|  |  | 
|  | namespace TypoCorrectTemplateMember { | 
|  | struct A { | 
|  | template<typename T> void foobar(T); // expected-note {{'foobar' declared here}} | 
|  | }; | 
|  | struct B : A { | 
|  | using A::goobar; // expected-error {{no member named 'goobar' in 'TypoCorrectTemplateMember::A'; did you mean 'foobar'?}} | 
|  | }; | 
|  | } | 
|  |  | 
|  | namespace use_instance_in_static { | 
|  | struct A { int n; }; | 
|  | struct B : A { | 
|  | using A::n; | 
|  | static int f() { return n; } // expected-error {{invalid use of member 'n' in static member function}} | 
|  | }; | 
|  | } | 
|  |  | 
|  | namespace PR24030 { | 
|  | namespace X { | 
|  | class A; // expected-note {{target}} | 
|  | int i; // expected-note {{target}} | 
|  | } | 
|  | namespace Y { | 
|  | using X::A; // expected-note {{using}} | 
|  | using X::i; // expected-note {{using}} | 
|  | class A {}; // expected-error {{conflicts}} | 
|  | int i; // expected-error {{conflicts}} | 
|  | } | 
|  | } | 
|  |  | 
|  | namespace PR24033 { | 
|  | extern int a; // expected-note 2{{target of using declaration}} | 
|  | void f(); // expected-note 2{{target of using declaration}} | 
|  | struct s; // expected-note 2{{target of using declaration}} | 
|  | enum e {}; // expected-note 2{{target of using declaration}} | 
|  |  | 
|  | template<typename> extern int vt; // expected-note 2{{target of using declaration}} expected-warning 0-1{{extension}} | 
|  | template<typename> void ft(); // expected-note 2{{target of using declaration}} | 
|  | template<typename> struct st; // expected-note 2{{target of using declaration}} | 
|  |  | 
|  | namespace X { | 
|  | using PR24033::a; // expected-note {{using declaration}} | 
|  | using PR24033::f; // expected-note {{using declaration}} | 
|  | using PR24033::s; // expected-note {{using declaration}} | 
|  | using PR24033::e; // expected-note {{using declaration}} | 
|  |  | 
|  | using PR24033::vt; // expected-note {{using declaration}} | 
|  | using PR24033::ft; // expected-note {{using declaration}} | 
|  | using PR24033::st; // expected-note {{using declaration}} | 
|  |  | 
|  | extern int a; // expected-error {{declaration conflicts with target of using declaration already in scope}} | 
|  | void f(); // expected-error {{declaration conflicts with target of using declaration already in scope}} | 
|  | struct s; // expected-error {{declaration conflicts with target of using declaration already in scope}} | 
|  | enum e {}; // expected-error {{declaration conflicts with target of using declaration already in scope}} | 
|  |  | 
|  | template<typename> extern int vt; // expected-error {{declaration conflicts with target of using declaration already in scope}} expected-warning 0-1{{extension}} | 
|  | template<typename> void ft(); // expected-error {{declaration conflicts with target of using declaration already in scope}} | 
|  | template<typename> struct st; // expected-error {{declaration conflicts with target of using declaration already in scope}} | 
|  | } | 
|  |  | 
|  | namespace Y { | 
|  | extern int a; // expected-note {{conflicting declaration}} | 
|  | void f(); // expected-note {{conflicting declaration}} | 
|  | struct s; // expected-note {{conflicting declaration}} | 
|  | enum e {}; // expected-note {{conflicting declaration}} | 
|  |  | 
|  | template<typename> extern int vt; // expected-note {{conflicting declaration}} expected-warning 0-1{{extension}} | 
|  | template<typename> void ft(); // expected-note {{conflicting declaration}} | 
|  | template<typename> struct st; // expected-note {{conflicting declaration}} | 
|  |  | 
|  | using PR24033::a; // expected-error {{target of using declaration conflicts with declaration already in scope}} | 
|  | using PR24033::f; // expected-error {{target of using declaration conflicts with declaration already in scope}} | 
|  | using PR24033::s; // expected-error {{target of using declaration conflicts with declaration already in scope}} | 
|  | using PR24033::e; // expected-error {{target of using declaration conflicts with declaration already in scope}} | 
|  |  | 
|  | using PR24033::vt; // expected-error {{target of using declaration conflicts with declaration already in scope}} | 
|  | using PR24033::ft; // expected-error {{target of using declaration conflicts with declaration already in scope}} | 
|  | using PR24033::st; // expected-error {{target of using declaration conflicts with declaration already in scope}} | 
|  | } | 
|  | } | 
|  |  | 
|  | namespace field_use { | 
|  | struct A { int field; }; | 
|  | struct B : A { | 
|  | // Previously Clang rejected this valid C++11 code because it didn't look | 
|  | // through the UsingShadowDecl. | 
|  | using A::field; | 
|  | #if __cplusplus < 201103L | 
|  | // expected-error@+2 {{invalid use of non-static data member 'field'}} | 
|  | #endif | 
|  | enum { X = sizeof(field) }; | 
|  | }; | 
|  | } | 
|  |  | 
|  | namespace tag_vs_var { | 
|  | namespace N { | 
|  | struct X {}; | 
|  |  | 
|  | struct Y {}; | 
|  | int Y; | 
|  |  | 
|  | int Z; | 
|  | } | 
|  | using N::X; | 
|  | using N::Y; | 
|  | using N::Z; | 
|  |  | 
|  | namespace N { | 
|  | int X; | 
|  |  | 
|  | struct Z {}; | 
|  | } | 
|  | using N::X; | 
|  | using N::Y; | 
|  | using N::Z; | 
|  | } |