diff options
| author | Anders Carlsson <andersca@mac.com> | 2007-11-30 19:04:31 +0000 | 
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2007-11-30 19:04:31 +0000 | 
| commit | 801c5c74677fa615bbe5c18576f38499c8d3f82c (patch) | |
| tree | 17ef3c0afa808787ceb103f2408e40f067f4e35d /clang/AST/Expr.cpp | |
| parent | 907703cecddca73eaaa1c4d3c4fdf9ef8c9bd987 (diff) | |
| download | bcm5719-llvm-801c5c74677fa615bbe5c18576f38499c8d3f82c.tar.gz bcm5719-llvm-801c5c74677fa615bbe5c18576f38499c8d3f82c.zip | |
GCC has an extension where the left hand side of the ? : operator can be omitted. Handle this in a few more places.
llvm-svn: 44462
Diffstat (limited to 'clang/AST/Expr.cpp')
| -rw-r--r-- | clang/AST/Expr.cpp | 8 | 
1 files changed, 5 insertions, 3 deletions
| diff --git a/clang/AST/Expr.cpp b/clang/AST/Expr.cpp index 682b4bd92be..0aee702c65d 100644 --- a/clang/AST/Expr.cpp +++ b/clang/AST/Expr.cpp @@ -494,7 +494,8 @@ bool Expr::isConstantExpr(ASTContext &Ctx, SourceLocation *Loc) const {    case ConditionalOperatorClass: {      const ConditionalOperator *Exp = cast<ConditionalOperator>(this);      if (!Exp->getCond()->isConstantExpr(Ctx, Loc) || -        !Exp->getLHS()->isConstantExpr(Ctx, Loc) || +        // Handle the GNU extension for missing LHS. +        !(Exp->getLHS() && Exp->getLHS()->isConstantExpr(Ctx, Loc)) ||          !Exp->getRHS()->isConstantExpr(Ctx, Loc))        return false;      return true; @@ -809,10 +810,11 @@ bool Expr::isIntegerConstantExpr(llvm::APSInt &Result, ASTContext &Ctx,      if (Result == 0) std::swap(TrueExp, FalseExp);      // Evaluate the false one first, discard the result. -    if (!FalseExp->isIntegerConstantExpr(Result, Ctx, Loc, false)) +    if (FalseExp && !FalseExp->isIntegerConstantExpr(Result, Ctx, Loc, false))        return false;      // Evalute the true one, capture the result. -    if (!TrueExp->isIntegerConstantExpr(Result, Ctx, Loc, isEvaluated)) +    if (TrueExp &&  +        !TrueExp->isIntegerConstantExpr(Result, Ctx, Loc, isEvaluated))        return false;      break;    } | 

