From: John McCall Date: Sat, 4 Dec 2010 08:24:19 +0000 (+0000) Subject: Make IgnoreParenLValueCasts skip __extension__ nodes like IgnoreParens(). X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=9c5d70cee1fab3f988f9cd40316071b088a3f19d;p=clang Make IgnoreParenLValueCasts skip __extension__ nodes like IgnoreParens(). Abramo noticed this. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@120898 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/AST/Expr.cpp b/lib/AST/Expr.cpp index fbc5a67af1..eef45e388a 100644 --- a/lib/AST/Expr.cpp +++ b/lib/AST/Expr.cpp @@ -1724,18 +1724,26 @@ Expr *Expr::IgnoreParenCasts() { } } +/// IgnoreParenLValueCasts - Ignore parentheses and lvalue-to-rvalue +/// casts. This is intended purely as a temporary workaround for code +/// that hasn't yet been rewritten to do the right thing about those +/// casts, and may disappear along with the last internal use. Expr *Expr::IgnoreParenLValueCasts() { Expr *E = this; - while (E) { + while (true) { if (ParenExpr *P = dyn_cast(E)) { E = P->getSubExpr(); continue; - } - if (CastExpr *P = dyn_cast(E)) { + } else if (CastExpr *P = dyn_cast(E)) { if (P->getCastKind() == CK_LValueToRValue) { E = P->getSubExpr(); continue; } + } else if (UnaryOperator* P = dyn_cast(E)) { + if (P->getOpcode() == UO_Extension) { + E = P->getSubExpr(); + continue; + } } break; }