diff options
author | Daniel Dunbar <daniel@zuster.org> | 2008-10-02 23:30:31 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2008-10-02 23:30:31 +0000 |
commit | ae3f4919e4805f59c554d39cb9cd3a601809b2cb (patch) | |
tree | 8a4d321aee06a9fa6259449fbe0f764ce181b457 /lib/Sema/SemaDecl.cpp | |
parent | de45428f923b38d80407dbb9ede0df504256f9f6 (diff) |
Add Builtins.def attribute for "can be a constant expression".
- Enabled for builtins which are always constant expressions
(__builtin_huge_val*, __builtin_inf*, __builtin_constant_p,
__builtin_classify_type, __builtin___CFStringMakeConstantString).
Added Builtin::Context::isConstantExpr.
- Currently overly simply interface which only works for builtins
whose constantexprness does not depend on their arguments.
CallExpr::isBuiltinConstantExpr now takes an ASTContext argument.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@56983 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaDecl.cpp')
-rw-r--r-- | lib/Sema/SemaDecl.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 9c5c4f2d4b..8214fe4c63 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -878,7 +878,7 @@ bool Sema::CheckAddressConstantExpression(const Expr* Init) { return false; case Expr::CallExprClass: { const CallExpr *CE = cast<CallExpr>(Init); - if (CE->isBuiltinConstantExpr()) + if (CE->isBuiltinConstantExpr(Context)) return false; Diag(Init->getExprLoc(), diag::err_init_element_not_constant, Init->getSourceRange()); @@ -1077,7 +1077,7 @@ bool Sema::CheckArithmeticConstantExpression(const Expr* Init) { return false; case Expr::CallExprClass: { const CallExpr *CE = cast<CallExpr>(Init); - if (CE->isBuiltinConstantExpr()) + if (CE->isBuiltinConstantExpr(Context)) return false; Diag(Init->getExprLoc(), diag::err_init_element_not_constant, Init->getSourceRange()); |