From 973aa207e8744a278c3ad72dda91a197be9c6493 Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Thu, 1 Nov 2012 14:32:20 +0000 Subject: [PATCH] Fix an incorrect assert, the LHS can be an LValue. llvm-svn: 167232 --- clang/lib/AST/Expr.cpp | 2 +- clang/test/SemaCXX/crashes.cpp | 12 ++++++++++++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/clang/lib/AST/Expr.cpp b/clang/lib/AST/Expr.cpp index 114aad5..61dd8bd 100644 --- a/clang/lib/AST/Expr.cpp +++ b/clang/lib/AST/Expr.cpp @@ -81,7 +81,7 @@ Expr::skipRValueSubobjectAdjustments( } } else if (const BinaryOperator *BO = dyn_cast(E)) { if (BO->isPtrMemOp()) { - assert(BO->getLHS()->isRValue()); + assert(BO->getRHS()->isRValue()); E = BO->getLHS(); const MemberPointerType *MPT = BO->getRHS()->getType()->getAs(); diff --git a/clang/test/SemaCXX/crashes.cpp b/clang/test/SemaCXX/crashes.cpp index b8b782a..f5682bd 100644 --- a/clang/test/SemaCXX/crashes.cpp +++ b/clang/test/SemaCXX/crashes.cpp @@ -159,3 +159,15 @@ namespace test2 { } } } + +namespace test3 { + struct nsCSSRect { + }; + static int nsCSSRect::* sides; + nsCSSRect dimenX; + void ParseBoxCornerRadii(int y) { + switch (y) { + } + int& x = dimenX.*sides; + } +} -- 2.7.4