forked from OSchip/llvm-project
122 lines
5.9 KiB
C++
122 lines
5.9 KiB
C++
// RUN: %clang_cc1 -fsyntax-only -verify -Wno-c++11-extensions %s
|
|
|
|
namespace fizbin { class Foobar {}; } // expected-note 2 {{'fizbin::Foobar' declared here}} \
|
|
// expected-note {{'Foobar' declared here}}
|
|
Foobar *my_bar // expected-error{{unknown type name 'Foobar'; did you mean 'fizbin::Foobar'?}}
|
|
= new Foobar; // expected-error{{unknown type name 'Foobar'; did you mean 'fizbin::Foobar'?}}
|
|
fizbin::Foobar *my_foo = new fizbin::FooBar; // expected-error{{no type named 'FooBar' in namespace 'fizbin'; did you mean 'Foobar'?}}
|
|
|
|
namespace barstool { int toFoobar() { return 1; } } // expected-note 3 {{'barstool::toFoobar' declared here}}
|
|
int Double(int x) { return x + x; }
|
|
void empty() {
|
|
Double(toFoobar()); // expected-error{{use of undeclared identifier 'toFoobar'; did you mean 'barstool::toFoobar'?}}
|
|
}
|
|
|
|
namespace fizbin {
|
|
namespace baztool { bool toFoobar() { return true; } } // expected-note{{'fizbin::baztool' declared here}}
|
|
namespace nested { bool moreFoobar() { return true; } } // expected-note{{'fizbin::nested::moreFoobar' declared here}}
|
|
namespace nested { bool lessFoobar() { return true; } } // expected-note{{'fizbin::nested' declared here}} \
|
|
// expected-note{{'fizbin::nested::lessFoobar' declared here}}
|
|
class dummy { // expected-note 2 {{'fizbin::dummy' declared here}}
|
|
public:
|
|
static bool morebar() { return false; } // expected-note{{'morebar' declared here}}
|
|
};
|
|
}
|
|
void Check() { // expected-note{{'Check' declared here}}
|
|
if (toFoobar()) Double(7); // expected-error{{use of undeclared identifier 'toFoobar'; did you mean 'barstool::toFoobar'?}}
|
|
if (noFoobar()) Double(7); // expected-error{{use of undeclared identifier 'noFoobar'; did you mean 'barstool::toFoobar'?}}
|
|
if (moreFoobar()) Double(7); // expected-error{{use of undeclared identifier 'moreFoobar'; did you mean 'fizbin::nested::moreFoobar'}}
|
|
if (lessFoobar()) Double(7); // expected-error{{use of undeclared identifier 'lessFoobar'; did you mean 'fizbin::nested::lessFoobar'?}}
|
|
if (baztool::toFoobar()) Double(7); // expected-error{{use of undeclared identifier 'baztool'; did you mean 'fizbin::baztool'?}}
|
|
if (nested::moreFoobar()) Double(7); // expected-error{{use of undeclared identifier 'nested'; did you mean 'fizbin::nested'?}}
|
|
if (dummy::morebar()) Double(7); // expected-error{{use of undeclared identifier 'dummy'; did you mean 'fizbin::dummy'?}}
|
|
if (dummy::mrebar()) Double(7); // expected-error{{use of undeclared identifier 'dummy'; did you mean 'fizbin::dummy'?}} \
|
|
// expected-error{{no member named 'mrebar' in 'fizbin::dummy'; did you mean 'morebar'?}}
|
|
if (moFoobin()) Double(7); // expected-error{{use of undeclared identifier 'moFoobin'}}
|
|
}
|
|
|
|
void Alt() {
|
|
Cleck(); // expected-error{{use of undeclared identifier 'Cleck'; did you mean 'Check'?}}
|
|
}
|
|
|
|
namespace N {
|
|
namespace inner {
|
|
class myvector { /* ... */ }; // expected-note{{'inner::myvector' declared here}}
|
|
}
|
|
|
|
void f() {
|
|
myvector v; // expected-error{{unknown type name 'myvector'; did you mean 'inner::myvector'?}}
|
|
}
|
|
}
|
|
|
|
namespace realstd {
|
|
inline namespace __1 {
|
|
class mylinkedlist { /* ... */ }; // expected-note 2 {{'realstd::mylinkedlist' declared here}}
|
|
}
|
|
|
|
class linkedlist { /* ... */ };
|
|
}
|
|
|
|
void f() {
|
|
mylinkedlist v; // expected-error{{unknown type name 'mylinkedlist'; did you mean 'realstd::mylinkedlist'?}}
|
|
nylinkedlist w; // expected-error{{unknown type name 'nylinkedlist'; did you mean 'realstd::mylinkedlist'?}}
|
|
}
|
|
|
|
// Test case from http://llvm.org/bugs/show_bug.cgi?id=10318
|
|
namespace llvm {
|
|
template <typename T> class GraphWriter {}; // expected-note 3{{declared here}}
|
|
}
|
|
|
|
struct S {};
|
|
void bar() {
|
|
GraphWriter<S> x; //expected-error{{no template named 'GraphWriter'; did you mean 'llvm::GraphWriter'?}}
|
|
(void)new llvm::GraphWriter; // expected-error {{use of class template 'llvm::GraphWriter' requires template arguments}}
|
|
(void)new llvm::Graphwriter<S>; // expected-error {{no template named 'Graphwriter' in namespace 'llvm'; did you mean 'GraphWriter'?}}
|
|
}
|
|
|
|
// If namespace prefixes and character edits have the same weight, correcting
|
|
// "fimish" to "N::famish" would have the same edit distance as correcting
|
|
// "fimish" to "Finish". The result would be no correction being suggested
|
|
// unless one of the corrections is given precedence (e.g. by filtering out
|
|
// suggestions with added namespace qualifiers).
|
|
namespace N { void famish(int); }
|
|
void Finish(int); // expected-note {{'Finish' declared here}}
|
|
void Start() {
|
|
fimish(7); // expected-error {{use of undeclared identifier 'fimish'; did you mean 'Finish'?}}
|
|
}
|
|
|
|
// But just eliminating the corrections containing added namespace qualifiers
|
|
// won't work if both of the tied corrections have namespace qualifiers added.
|
|
namespace N {
|
|
void someCheck(int); // expected-note {{'N::someCheck' declared here}}
|
|
namespace O { void somechock(int); }
|
|
}
|
|
void confusing() {
|
|
somechick(7); // expected-error {{use of undeclared identifier 'somechick'; did you mean 'N::someCheck'?}}
|
|
}
|
|
|
|
|
|
class Message {};
|
|
namespace extra {
|
|
namespace util {
|
|
namespace MessageUtils {
|
|
bool Equivalent(const Message&, const Message&); // expected-note {{'extra::util::MessageUtils::Equivalent' declared here}} \
|
|
// expected-note {{'::extra::util::MessageUtils::Equivalent' declared here}}
|
|
}
|
|
}
|
|
}
|
|
namespace util { namespace MessageUtils {} }
|
|
bool nstest () {
|
|
Message a, b;
|
|
return util::MessageUtils::Equivalent(a, b); // expected-error {{no member named 'Equivalent' in namespace 'util::MessageUtils'; did you mean 'extra::util::MessageUtils::Equivalent'?}}
|
|
}
|
|
|
|
namespace util {
|
|
namespace extra {
|
|
bool nstest () {
|
|
Message a, b;
|
|
return MessageUtils::Equivalent(a, b); // expected-error {{no member named 'Equivalent' in namespace 'util::MessageUtils'; did you mean '::extra::util::MessageUtils::Equivalent'?}}
|
|
}
|
|
}
|
|
}
|