From: Anders Carlsson Date: Tue, 24 Nov 2009 16:57:33 +0000 (+0000) Subject: We always need to emit the base expression of a member expression, even when the... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c102297fb2857ef1af191a8e85e842cc3ac3239e;p=clang We always need to emit the base expression of a member expression, even when the member decl refers to an enum. Thanks to Eli for pointing this out! git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@89775 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp index 84adc5fdcf..8bb02f9668 100644 --- a/lib/CodeGen/CGExprScalar.cpp +++ b/lib/CodeGen/CGExprScalar.cpp @@ -169,9 +169,16 @@ public: Value *VisitShuffleVectorExpr(ShuffleVectorExpr *E); Value *VisitMemberExpr(MemberExpr *E) { if (const EnumConstantDecl *EC = - dyn_cast(E->getMemberDecl())) + dyn_cast(E->getMemberDecl())) { + + // We still need to emit the base. + if (E->isArrow()) + CGF.EmitScalarExpr(E->getBase()); + else + CGF.EmitLValue(E->getBase()); return llvm::ConstantInt::get(VMContext, EC->getInitVal()); - + } + return EmitLoadOfLValue(E); } diff --git a/test/CodeGenCXX/member-expressions.cpp b/test/CodeGenCXX/member-expressions.cpp index 223bab55e6..76b81e0688 100644 --- a/test/CodeGenCXX/member-expressions.cpp +++ b/test/CodeGenCXX/member-expressions.cpp @@ -19,9 +19,20 @@ void f() } struct A { + A(); + ~A(); enum E { Foo }; }; +A *g(); + void f(A *a) { - A::E e = a->Foo; + A::E e1 = a->Foo; + + // CHECK: call %struct.A* @_Z1gv() + A::E e2 = g()->Foo; + // CHECK: call void @_ZN1AC1Ev( + // CHECK: call void @_ZN1AD1Ev( + A::E e3 = A().Foo; } +