| // 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; |
| } |