From: Mike Stump Date: Wed, 18 Feb 2009 21:44:49 +0000 (+0000) Subject: Codegen for int (^bp)(int) = 0; X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=ca2f3fdeedc4e4beea4f7572d6d975188d0bb5ef;p=clang Codegen for int (^bp)(int) = 0; git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64951 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/AST/ExprConstant.cpp b/lib/AST/ExprConstant.cpp index ccea646fb7..ee698d6c93 100644 --- a/lib/AST/ExprConstant.cpp +++ b/lib/AST/ExprConstant.cpp @@ -265,7 +265,8 @@ public: } // end anonymous namespace static bool EvaluatePointer(const Expr* E, APValue& Result, EvalInfo &Info) { - if (!E->getType()->isPointerType()) + if (!E->getType()->isPointerType() + && !E->getType()->isBlockPointerType()) return false; Result = PointerExprEvaluator(Info).Visit(const_cast(E)); return Result.isLValue(); @@ -1533,7 +1534,8 @@ bool Expr::Evaluate(EvalResult &Result, ASTContext &Ctx) const { return false; Result.Val = APValue(sInt); - } else if (getType()->isPointerType()) { + } else if (getType()->isPointerType() + || getType()->isBlockPointerType()) { if (!EvaluatePointer(this, Result.Val, Info)) return false; } else if (getType()->isRealFloatingType()) {