diff options
author | Douglas Gregor <dgregor@apple.com> | 2008-12-20 23:49:58 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2008-12-20 23:49:58 +0000 |
commit | 2eedc3aa1ce4af390e5f1efd49087fd23f191565 (patch) | |
tree | 00fa35dbcbb3156de9c1e06278cf87da294a7399 /clang/lib/CodeGen | |
parent | a0befc0a6f064c3cff0d2c5386eabb763e991bf0 (diff) | |
download | bcm5719-llvm-2eedc3aa1ce4af390e5f1efd49087fd23f191565.tar.gz bcm5719-llvm-2eedc3aa1ce4af390e5f1efd49087fd23f191565.zip |
Add support for member references (E1.E2, E1->E2) with C++ semantics,
which can refer to static data members, enumerators, and member
functions as well as to non-static data members.
Implement correct lvalue computation for member references in C++.
Compute the result type of non-static data members of reference type properly.
llvm-svn: 61294
Diffstat (limited to 'clang/lib/CodeGen')
-rw-r--r-- | clang/lib/CodeGen/CGExpr.cpp | 4 | ||||
-rw-r--r-- | clang/lib/CodeGen/CGExprConstant.cpp | 5 |
2 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CGExpr.cpp b/clang/lib/CodeGen/CGExpr.cpp index 59d7108e19f..b085de304aa 100644 --- a/clang/lib/CodeGen/CGExpr.cpp +++ b/clang/lib/CodeGen/CGExpr.cpp @@ -782,7 +782,9 @@ LValue CodeGenFunction::EmitMemberExpr(const MemberExpr *E) { CVRQualifiers = BaseExpr->getType().getCVRQualifiers(); } - FieldDecl *Field = E->getMemberDecl(); + FieldDecl *Field = dyn_cast<FieldDecl>(E->getMemberDecl()); + // FIXME: Handle non-field member expressions + assert(Field && "No code generation for non-field member references"); LValue MemExpLV = EmitLValueForField(BaseValue, Field, isUnion, CVRQualifiers); LValue::SetObjCIvar(MemExpLV, isIvar); return MemExpLV; diff --git a/clang/lib/CodeGen/CGExprConstant.cpp b/clang/lib/CodeGen/CGExprConstant.cpp index 2166a5c8989..a82efca6148 100644 --- a/clang/lib/CodeGen/CGExprConstant.cpp +++ b/clang/lib/CodeGen/CGExprConstant.cpp @@ -564,7 +564,10 @@ public: else Base = EmitLValue(ME->getBase()); - unsigned FieldNumber = CGM.getTypes().getLLVMFieldNo(ME->getMemberDecl()); + FieldDecl *Field = dyn_cast<FieldDecl>(ME->getMemberDecl()); + // FIXME: Handle other kinds of member expressions. + assert(Field && "No code generation for non-field member expressions"); + unsigned FieldNumber = CGM.getTypes().getLLVMFieldNo(Field); llvm::Constant *Zero = llvm::ConstantInt::get(llvm::Type::Int32Ty, 0); llvm::Constant *Idx = llvm::ConstantInt::get(llvm::Type::Int32Ty, FieldNumber); |