]> granicus.if.org Git - clang/commitdiff
We always need to emit the base expression of a member expression, even when the...
authorAnders Carlsson <andersca@mac.com>
Tue, 24 Nov 2009 16:57:33 +0000 (16:57 +0000)
committerAnders Carlsson <andersca@mac.com>
Tue, 24 Nov 2009 16:57:33 +0000 (16:57 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@89775 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGExprScalar.cpp
test/CodeGenCXX/member-expressions.cpp

index 84adc5fdcff1362054397d0b9a784fcd600de827..8bb02f9668c3dcdf08dc5c2c4626a6f69d719259 100644 (file)
@@ -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);
   }
     
index 223bab55e64af0a98bef4b7e6c70a905ae13f2a0..76b81e068823f9b1de49ee52dd8af4b9be4c3d19 100644 (file)
@@ -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;
 }
+