diff options
author | Anders Carlsson <andersca@mac.com> | 2009-01-16 16:48:51 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-01-16 16:48:51 +0000 |
commit | dce5e2cabf07ff25eb4d9e1859c0a21c69f588d2 (patch) | |
tree | c7ff69f2a0de6bddc5568146a2f9f56ad0446d00 /lib/Sema/SemaExprObjC.cpp | |
parent | 636c5ef6572e899d36cec1b0023fb28ba65189e1 (diff) |
Use a single function for doing vararg argument promotion. Also, make sure to do the promotion before checking the type - fixes PR3340.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@62323 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaExprObjC.cpp')
-rw-r--r-- | lib/Sema/SemaExprObjC.cpp | 11 |
1 files changed, 2 insertions, 9 deletions
diff --git a/lib/Sema/SemaExprObjC.cpp b/lib/Sema/SemaExprObjC.cpp index a73f386dab..548389db37 100644 --- a/lib/Sema/SemaExprObjC.cpp +++ b/lib/Sema/SemaExprObjC.cpp @@ -156,15 +156,8 @@ bool Sema::CheckMessageArgumentTypes(Expr **Args, unsigned NumArgs, // Promote additional arguments to variadic methods. if (Method->isVariadic()) { - 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]); - } + for (unsigned i = NumNamedArgs; i < NumArgs; ++i) + DefaultVariadicArgumentPromotion(Args[i], VariadicMethod); } else { // Check for extra arguments to non-variadic methods. if (NumArgs != NumNamedArgs) { |