summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaStmt.cpp
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2009-03-26 07:32:37 +0000
committerEli Friedman <eli.friedman@gmail.com>2009-03-26 07:32:37 +0000
commit6568eef9f90d7c843676f47ee2938a8af2600bf3 (patch)
treecd98ba9f72cc6561fba9c5d9631234b5930eae57 /clang/lib/Sema/SemaStmt.cpp
parent55a2cd736d91e024ea5718f80edadff8c24434b7 (diff)
downloadbcm5719-llvm-6568eef9f90d7c843676f47ee2938a8af2600bf3.tar.gz
bcm5719-llvm-6568eef9f90d7c843676f47ee2938a8af2600bf3.zip
Sanity-check argument to indirect goto.
llvm-svn: 67746
Diffstat (limited to 'clang/lib/Sema/SemaStmt.cpp')
-rw-r--r--clang/lib/Sema/SemaStmt.cpp10
1 files changed, 7 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaStmt.cpp b/clang/lib/Sema/SemaStmt.cpp
index 4ef0fda3612..bbcc71d6e4d 100644
--- a/clang/lib/Sema/SemaStmt.cpp
+++ b/clang/lib/Sema/SemaStmt.cpp
@@ -687,10 +687,14 @@ Sema::ActOnGotoStmt(SourceLocation GotoLoc, SourceLocation LabelLoc,
Action::OwningStmtResult
Sema::ActOnIndirectGotoStmt(SourceLocation GotoLoc,SourceLocation StarLoc,
ExprArg DestExp) {
- // FIXME: Verify that the operand is convertible to void*.
// Convert operand to void*
- Expr* E = (Expr*)DestExp.release();
- ImpCastExprToType(E, Context.VoidPtrTy);
+ Expr* E = DestExp.takeAs<Expr>();
+ QualType ETy = E->getType();
+ AssignConvertType ConvTy =
+ CheckSingleAssignmentConstraints(Context.VoidPtrTy, E);
+ if (DiagnoseAssignmentResult(ConvTy, StarLoc, Context.VoidPtrTy, ETy,
+ E, "passing"))
+ return StmtError();
return Owned(new (Context) IndirectGotoStmt(E));
}
OpenPOWER on IntegriCloud