aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-01-13 05:48:52 +0000
committerAnders Carlsson <andersca@mac.com>2009-01-13 05:48:52 +0000
commit906fed0fb54a338961aba3aa54802b7d68de94c7 (patch)
tree0ce6bb608a4a5693b22ecd9d3147f0ee7721ade9 /lib
parent518fda1d121dcba3ad7276f5e9a94f733f6e5ecd (diff)
Warn when someone tries to pass a variable with a non-POD type to a varargs function/method/block.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@62148 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/Sema/SemaExpr.cpp11
-rw-r--r--lib/Sema/SemaExprObjC.cpp9
-rw-r--r--lib/Sema/SemaOverload.cpp7
3 files changed, 26 insertions, 1 deletions
diff --git a/lib/Sema/SemaExpr.cpp b/lib/Sema/SemaExpr.cpp
index d3d3d3556c..2721bb8dc6 100644
--- a/lib/Sema/SemaExpr.cpp
+++ b/lib/Sema/SemaExpr.cpp
@@ -1688,6 +1688,17 @@ Sema::ConvertArgumentsForCall(CallExpr *Call, Expr *Fn,
// Promote the arguments (C99 6.5.2.2p7).
for (unsigned i = NumArgsInProto; i != NumArgs; i++) {
Expr *Arg = Args[i];
+ if (!Arg->getType()->isPODType()) {
+ int CallType = 0;
+ if (Fn->getType()->isBlockPointerType())
+ CallType = 1; // Block
+ else if (isa<MemberExpr>(Fn))
+ CallType = 2;
+
+ Diag(Arg->getLocStart(),
+ diag::warn_cannot_pass_non_pod_arg_to_vararg) <<
+ Arg->getType() << CallType;
+ }
DefaultArgumentPromotion(Arg);
Call->setArg(i, Arg);
}
diff --git a/lib/Sema/SemaExprObjC.cpp b/lib/Sema/SemaExprObjC.cpp
index 415bc94759..a73f386dab 100644
--- a/lib/Sema/SemaExprObjC.cpp
+++ b/lib/Sema/SemaExprObjC.cpp
@@ -156,8 +156,15 @@ bool Sema::CheckMessageArgumentTypes(Expr **Args, unsigned NumArgs,
// Promote additional arguments to variadic methods.
if (Method->isVariadic()) {
- for (unsigned i = NumNamedArgs; i < NumArgs; ++i)
+ for (unsigned i = NumNamedArgs; i < NumArgs; ++i) {
+ if (!Args[i]->getType()->isPODType()) {
+ Diag(Args[i]->getLocStart(),
+ diag::warn_cannot_pass_non_pod_arg_to_vararg) <<
+ Args[i]->getType() << 2; // Method
+ }
+
DefaultArgumentPromotion(Args[i]);
+ }
} else {
// Check for extra arguments to non-variadic methods.
if (NumArgs != NumNamedArgs) {
diff --git a/lib/Sema/SemaOverload.cpp b/lib/Sema/SemaOverload.cpp
index c66db173eb..d74a5d54b9 100644
--- a/lib/Sema/SemaOverload.cpp
+++ b/lib/Sema/SemaOverload.cpp
@@ -3576,6 +3576,13 @@ Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Object,
// Promote the arguments (C99 6.5.2.2p7).
for (unsigned i = NumArgsInProto; i != NumArgs; i++) {
Expr *Arg = Args[i];
+
+ if (!Arg->getType()->isPODType()) {
+ Diag(Arg->getLocStart(),
+ diag::warn_cannot_pass_non_pod_arg_to_vararg) <<
+ Arg->getType() << 2; // Method
+ }
+
DefaultArgumentPromotion(Arg);
TheCall->setArg(i + 1, Arg);
}