diff options
author | Chris Lattner <sabre@nondot.org> | 2009-04-12 08:11:20 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-04-12 08:11:20 +0000 |
commit | a8a7d0f371619116481bde713b2d90aae5f6a37e (patch) | |
tree | c5b7897c448a0d2866173fea4091c9d4979e062e /clang/lib/Sema/SemaOverload.cpp | |
parent | ce6bcf0847329c708a09e1dba8adfb7fd92c4beb (diff) | |
download | bcm5719-llvm-a8a7d0f371619116481bde713b2d90aae5f6a37e.tar.gz bcm5719-llvm-a8a7d0f371619116481bde713b2d90aae5f6a37e.zip |
implement rdar://6780761, making sema reject some code that otherwise
crashes codegen.
llvm-svn: 68891
Diffstat (limited to 'clang/lib/Sema/SemaOverload.cpp')
-rw-r--r-- | clang/lib/Sema/SemaOverload.cpp | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp index 0a12a71bb74..875a38253da 100644 --- a/clang/lib/Sema/SemaOverload.cpp +++ b/clang/lib/Sema/SemaOverload.cpp @@ -4178,11 +4178,13 @@ Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Object, else if (NumArgs > NumArgsInProto) NumArgsToCheck = NumArgsInProto; + bool IsError = false; + // Initialize the implicit object parameter. - if (PerformObjectArgumentInitialization(Object, Method)) - return true; + IsError |= PerformObjectArgumentInitialization(Object, Method); TheCall->setArg(0, Object); + // Check the argument types. for (unsigned i = 0; i != NumArgsToCheck; i++) { Expr *Arg; @@ -4191,8 +4193,7 @@ Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Object, // Pass the argument. QualType ProtoArgType = Proto->getArgType(i); - if (PerformCopyInitialization(Arg, ProtoArgType, "passing")) - return true; + IsError |= PerformCopyInitialization(Arg, ProtoArgType, "passing"); } else { Arg = new (Context) CXXDefaultArgExpr(Method->getParamDecl(i)); } @@ -4205,12 +4206,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]; - - DefaultVariadicArgumentPromotion(Arg, VariadicMethod); + IsError |= DefaultVariadicArgumentPromotion(Arg, VariadicMethod); TheCall->setArg(i + 1, Arg); } } + if (IsError) return true; + return CheckFunctionCall(Method, TheCall.take()).release(); } |