2010-11-18 08:20:36 +08:00
|
|
|
// RUN: %clang_cc1 -verify -fsyntax-only -Wlarge-by-value-copy=100 %s
|
2010-11-18 07:11:54 +08:00
|
|
|
|
|
|
|
// rdar://8548050
|
|
|
|
namespace rdar8548050 {
|
|
|
|
|
|
|
|
struct S100 {
|
|
|
|
char x[100];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct S101 {
|
|
|
|
char x[101];
|
|
|
|
};
|
|
|
|
|
|
|
|
S100 f100(S100 s) { return s; }
|
|
|
|
|
2010-11-18 08:20:36 +08:00
|
|
|
S101 f101(S101 s) { return s; } // expected-warning {{return value of 'f101' is a large (101 bytes) pass-by-value object}} \
|
|
|
|
// expected-warning {{'s' is a large (101 bytes) pass-by-value argument}}
|
2010-11-18 07:11:54 +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
|
|
|
void f101_no_param_name(S101) {} // expected-warning {{'' is a large (101 bytes) pass-by-value argument}}
|
|
|
|
|
|
|
|
// FIXME: Don't warn when when the return value is subject to (N)RVO.
|
|
|
|
|
|
|
|
template <typename T> T foo_template(T);
|
|
|
|
template <> S101 foo_template(S101) { return S101(); } // expected-warning {{return value of 'foo_template<rdar8548050::S101>' is a large}}
|
|
|
|
// expected-warning@-1 {{'' is a large (101 bytes) pass-by-value argument}}
|
|
|
|
|
2010-11-18 07:11:54 +08:00
|
|
|
typedef int Arr[200];
|
|
|
|
void farr(Arr a) { }
|
|
|
|
|
|
|
|
struct NonPOD {
|
|
|
|
char x[200];
|
|
|
|
virtual void m();
|
|
|
|
};
|
|
|
|
|
|
|
|
NonPOD fNonPOD(NonPOD s) { return s; }
|
|
|
|
|
|
|
|
template <unsigned size>
|
|
|
|
struct TS {
|
|
|
|
char x[size];
|
|
|
|
};
|
|
|
|
|
|
|
|
template <unsigned size>
|
2010-11-18 08:20:36 +08:00
|
|
|
void tf(TS<size> ts) {} // expected-warning {{ts' is a large (300 bytes) pass-by-value argument}}
|
2010-11-18 07:11:54 +08:00
|
|
|
|
|
|
|
void g() {
|
|
|
|
TS<300> ts;
|
|
|
|
tf<300>(ts); // expected-note {{instantiation}}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2012-01-10 07:46:59 +08:00
|
|
|
|
|
|
|
template<typename T> class DependentPOD {
|
|
|
|
enum b { x };
|
|
|
|
b foo() { return x; }
|
|
|
|
};
|