From: Anders Carlsson Date: Sat, 3 Oct 2009 16:30:22 +0000 (+0000) Subject: Ignore No-op casts when evaluating lvalue expressions. Fixes PR5122. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=26bc220377705292a0519a71d3ea3aef68fcfec6;p=clang Ignore No-op casts when evaluating lvalue expressions. Fixes PR5122. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@83267 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/AST/ExprConstant.cpp b/lib/AST/ExprConstant.cpp index 2aefae6fd7..94d22998eb 100644 --- a/lib/AST/ExprConstant.cpp +++ b/lib/AST/ExprConstant.cpp @@ -180,6 +180,16 @@ public: { return Visit(E->getSubExpr()); } APValue VisitChooseExpr(const ChooseExpr *E) { return Visit(E->getChosenSubExpr(Info.Ctx)); } + + APValue VisitCastExpr(CastExpr *E) { + switch (E->getCastKind()) { + default: + return APValue(); + + case CastExpr::CK_NoOp: + return Visit(E->getSubExpr()); + } + } // FIXME: Missing: __real__, __imag__ }; } // end anonymous namespace diff --git a/test/CodeGenCXX/references.cpp b/test/CodeGenCXX/references.cpp index 6f4c1032ef..c235521d43 100644 --- a/test/CodeGenCXX/references.cpp +++ b/test/CodeGenCXX/references.cpp @@ -95,3 +95,8 @@ struct A { void f(A* a) { int b = a->b(); } + +// PR5122 +void *foo = 0; +void * const & kFoo = foo; +