2009-12-16 04:14:24 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -verify %s
|
2020-07-19 03:39:16 +08:00
|
|
|
struct A; // expected-note 15 {{forward declaration of 'A'}}
|
2009-10-10 07:58:25 +08:00
|
|
|
|
2011-12-15 08:38:15 +08:00
|
|
|
A f(); // expected-note {{'f' declared here}}
|
2020-07-19 03:39:16 +08:00
|
|
|
template <typename T> A ft(T); // expected-note {{'ft' declared here}}
|
2009-10-10 07:58:25 +08:00
|
|
|
|
|
|
|
struct B {
|
2009-10-10 08:06:20 +08:00
|
|
|
A f(); // expected-note {{'f' declared here}}
|
2009-10-14 05:49:31 +08:00
|
|
|
A operator()(); // expected-note 2 {{'operator()' declared here}}
|
2009-10-14 05:02:07 +08:00
|
|
|
operator A(); // expected-note {{'operator A' declared here}}
|
2009-10-14 05:19:37 +08:00
|
|
|
A operator!(); // expected-note 2 {{'operator!' declared here}}
|
2009-10-14 05:49:31 +08:00
|
|
|
A operator++(int); // expected-note {{'operator++' declared here}}
|
2009-10-14 06:22:09 +08:00
|
|
|
A operator[](int); // expected-note {{'operator[]' declared here}}
|
2009-10-14 06:43:21 +08:00
|
|
|
A operator+(int); // expected-note {{'operator+' declared here}}
|
|
|
|
A operator->(); // expected-note {{'operator->' declared here}}
|
2009-10-10 07:58:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
void g() {
|
2010-03-10 19:27:22 +08:00
|
|
|
f(); // expected-error {{calling 'f' with incomplete return type 'A'}}
|
2009-10-10 07:58:25 +08:00
|
|
|
|
|
|
|
typedef A (*Func)();
|
|
|
|
Func fp;
|
2010-03-10 19:27:22 +08:00
|
|
|
fp(); // expected-error {{calling function with incomplete return type 'A'}}
|
|
|
|
((Func)0)(); // expected-error {{calling function with incomplete return type 'A'}}
|
2009-10-10 08:06:20 +08:00
|
|
|
|
|
|
|
B b;
|
2010-03-10 19:27:22 +08:00
|
|
|
b.f(); // expected-error {{calling 'f' with incomplete return type 'A'}}
|
2009-10-14 05:02:07 +08:00
|
|
|
|
2010-03-10 19:27:22 +08:00
|
|
|
b.operator()(); // expected-error {{calling 'operator()' with incomplete return type 'A'}}
|
|
|
|
b.operator A(); // expected-error {{calling 'operator A' with incomplete return type 'A'}}
|
|
|
|
b.operator!(); // expected-error {{calling 'operator!' with incomplete return type 'A'}}
|
2009-10-14 05:19:37 +08:00
|
|
|
|
2010-03-10 19:27:22 +08:00
|
|
|
!b; // expected-error {{calling 'operator!' with incomplete return type 'A'}}
|
|
|
|
b(); // expected-error {{calling 'operator()' with incomplete return type 'A'}}
|
|
|
|
b++; // expected-error {{calling 'operator++' with incomplete return type 'A'}}
|
|
|
|
b[0]; // expected-error {{calling 'operator[]' with incomplete return type 'A'}}
|
|
|
|
b + 1; // expected-error {{calling 'operator+' with incomplete return type 'A'}}
|
|
|
|
b->f(); // expected-error {{calling 'operator->' with incomplete return type 'A'}}
|
2009-10-15 08:41:48 +08:00
|
|
|
|
|
|
|
A (B::*mfp)() = 0;
|
2010-03-10 19:27:22 +08:00
|
|
|
(b.*mfp)(); // expected-error {{calling function with incomplete return type 'A'}}
|
2020-07-19 03:39:16 +08:00
|
|
|
|
[clang] Pass the NamedDecl* instead of the DeclarationName into many diagnostics.
Background:
-----------
There are two related argument types which can be sent into a diagnostic to
display the name of an entity: DeclarationName (ak_declarationname) or
NamedDecl* (ak_nameddecl) (there is also ak_identifierinfo for
IdentifierInfo*, but we are not concerned with it here).
A DeclarationName in a diagnostic will just be streamed to the output,
which will directly result in a call to DeclarationName::print.
A NamedDecl* in a diagnostic will also ultimately result in a call to
DeclarationName::print, but with two customisation points along the way:
The first customisation point is NamedDecl::getNameForDiagnostic which is
overloaded by FunctionDecl, ClassTemplateSpecializationDecl and
VarTemplateSpecializationDecl to print the template arguments, if any.
The second customisation point is NamedDecl::printName. By default it just
streams the stored DeclarationName into the output but it can be customised
to provide a user-friendly name for an entity. It is currently overloaded by
DecompositionDecl and MSGuidDecl.
What this patch does:
---------------------
For many diagnostics a DeclarationName is used instead of the NamedDecl*.
This bypasses the two customisation points mentioned above. This patches fix
this for diagnostics in Sema.cpp, SemaCast.cpp, SemaChecking.cpp, SemaDecl.cpp,
SemaDeclAttr.cpp, SemaDecl.cpp, SemaOverload.cpp and SemaStmt.cpp.
I have only modified diagnostics where I could construct a test-case which
demonstrates that the change is appropriate (either with this patch or the next
one).
Reviewed By: erichkeane, aaron.ballman
Differential Revision: https://reviews.llvm.org/D84656
2020-07-28 06:22:21 +08:00
|
|
|
ft(42); // expected-error {{calling 'ft<int>' with incomplete return type 'A'}}
|
2009-10-10 07:58:25 +08:00
|
|
|
}
|
2009-10-21 14:18:39 +08:00
|
|
|
|
|
|
|
|
|
|
|
struct C; // expected-note{{forward declaration}}
|
|
|
|
|
|
|
|
void test_incomplete_object_call(C& c) {
|
|
|
|
c(); // expected-error{{incomplete type in call to object of type}}
|
|
|
|
}
|
2015-06-11 03:06:59 +08:00
|
|
|
|
2019-01-24 21:52:47 +08:00
|
|
|
void test_incomplete_object_dtor(C *p) {
|
|
|
|
p.~C(); // expected-error{{member reference type 'C *' is a pointer; did you mean to use '->'?}}
|
|
|
|
}
|
|
|
|
|
2015-06-11 03:06:59 +08:00
|
|
|
namespace pr18542 {
|
|
|
|
struct X {
|
|
|
|
int count;
|
|
|
|
template<typename CharT> class basic_istream;
|
|
|
|
template<typename CharT>
|
|
|
|
void basic_istream<CharT>::read() { // expected-error{{out-of-line definition of 'read' from class 'basic_istream<CharT>' without definition}}
|
|
|
|
count = 0;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|