diff options
author | Chris Lattner <sabre@nondot.org> | 2007-08-25 05:30:33 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-08-25 05:30:33 +0000 |
commit | cc6f65d9f210efc56d7418753e93bf5a14f3ac59 (patch) | |
tree | b1778f3974cadcce52436971de1fd9275836ea4f | |
parent | 388577b3bd05bc1c442365b10e8960306e28a261 (diff) |
Fix the regression on test/Sema/cfstring.c
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@41396 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | Sema/SemaChecking.cpp | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/Sema/SemaChecking.cpp b/Sema/SemaChecking.cpp index a1deb3d256..a62c73e8fb 100644 --- a/Sema/SemaChecking.cpp +++ b/Sema/SemaChecking.cpp @@ -80,10 +80,15 @@ Sema::CheckFunctionCall(Expr *Fn, /// CheckBuiltinCFStringArgument - Checks that the argument to the builtin /// CFString constructor is correct -bool Sema::CheckBuiltinCFStringArgument(Expr* Arg) -{ - while (ParenExpr *PE = dyn_cast<ParenExpr>(Arg)) - Arg = PE->getSubExpr(); +bool Sema::CheckBuiltinCFStringArgument(Expr* Arg) { + while (1) { + if (ParenExpr *PE = dyn_cast<ParenExpr>(Arg)) + Arg = PE->getSubExpr(); + else if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(Arg)) + Arg = ICE->getSubExpr(); + else + break; + } StringLiteral *Literal = dyn_cast<StringLiteral>(Arg); |