diff options
Diffstat (limited to 'clang')
-rw-r--r-- | clang/lib/AST/Expr.cpp | 25 | ||||
-rw-r--r-- | clang/test/CodeGen/staticinit.c | 6 |
2 files changed, 31 insertions, 0 deletions
diff --git a/clang/lib/AST/Expr.cpp b/clang/lib/AST/Expr.cpp index 0ff345a1a8d..6d29dd1f319 100644 --- a/clang/lib/AST/Expr.cpp +++ b/clang/lib/AST/Expr.cpp @@ -622,8 +622,32 @@ Expr *Expr::IgnoreParenCasts() { } } +#define USE_EVALUATE bool Expr::isConstantExpr(ASTContext &Ctx, SourceLocation *Loc) const { +#ifdef USE_EVALUATE + switch (getStmtClass()) { + default: + if (!isEvaluatable(Ctx)) { + if (Loc) *Loc = getLocStart(); + return false; + } + break; + case StringLiteralClass: + case ObjCStringLiteralClass: + return true; + case InitListExprClass: { + const InitListExpr *Exp = cast<InitListExpr>(this); + unsigned numInits = Exp->getNumInits(); + for (unsigned i = 0; i < numInits; i++) { + if (!Exp->getInit(i)->isConstantExpr(Ctx, Loc)) + return false; + } + } + } + + return true; +#else switch (getStmtClass()) { default: if (Loc) *Loc = getLocStart(); @@ -762,6 +786,7 @@ bool Expr::isConstantExpr(ASTContext &Ctx, SourceLocation *Loc) const { case CXXDefaultArgExprClass: return cast<CXXDefaultArgExpr>(this)->getExpr()->isConstantExpr(Ctx, Loc); } +#endif } /// isIntegerConstantExpr - this recursive routine will test if an expression is diff --git a/clang/test/CodeGen/staticinit.c b/clang/test/CodeGen/staticinit.c index 50c837a1c2f..196d931f64a 100644 --- a/clang/test/CodeGen/staticinit.c +++ b/clang/test/CodeGen/staticinit.c @@ -18,3 +18,9 @@ void g() { static char a[10]; static char *b = a; } + +struct s { void *p; }; + +void foo(void) { + static struct s var = {((void*)&((char*)0)[0])}; +} |