aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-11-24 16:57:33 +0000
committerAnders Carlsson <andersca@mac.com>2009-11-24 16:57:33 +0000
commitc102297fb2857ef1af191a8e85e842cc3ac3239e (patch)
tree32ead98cff95e863fb802a872999cea72c8305b8
parenta244dc3a554f6bf82416697e34f9e96dc1efbb88 (diff)
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
-rw-r--r--lib/CodeGen/CGExprScalar.cpp11
-rw-r--r--test/CodeGenCXX/member-expressions.cpp13
2 files changed, 21 insertions, 3 deletions
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<EnumConstantDecl>(E->getMemberDecl()))
+ dyn_cast<EnumConstantDecl>(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;
}
+