diff options
author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2009-03-16 23:22:08 +0000 |
---|---|---|
committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2009-03-16 23:22:08 +0000 |
commit | 7c80bd64032e610c0dbd74fc0ef6ea334447f2fd (patch) | |
tree | 063757ae5ba5bc99323c26d4590654ed2f82a1b4 /lib/CodeGen | |
parent | a393e9eedcc28b25f521a4feceb3b56e3d0d360f (diff) |
Almost complete implementation of rvalue references. One bug, and a few unclear areas. Maybe Doug can shed some light on some of the fixmes.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67059 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen')
-rw-r--r-- | lib/CodeGen/CGDebugInfo.cpp | 3 | ||||
-rw-r--r-- | lib/CodeGen/CGExprScalar.cpp | 1 | ||||
-rw-r--r-- | lib/CodeGen/CodeGenTypes.cpp | 3 | ||||
-rw-r--r-- | lib/CodeGen/Mangle.cpp | 11 |
4 files changed, 13 insertions, 5 deletions
diff --git a/lib/CodeGen/CGDebugInfo.cpp b/lib/CodeGen/CGDebugInfo.cpp index 9b56b8449f..0dac6ba920 100644 --- a/lib/CodeGen/CGDebugInfo.cpp +++ b/lib/CodeGen/CGDebugInfo.cpp @@ -502,7 +502,8 @@ llvm::DIType CGDebugInfo::getOrCreateType(QualType Ty, assert(false && "Dependent types cannot show up in debug information"); case Type::Complex: - case Type::Reference: + case Type::LValueReference: + case Type::RValueReference: case Type::Vector: case Type::ExtVector: case Type::ExtQual: diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp index 8cd353408f..1a64e3c905 100644 --- a/lib/CodeGen/CGExprScalar.cpp +++ b/lib/CodeGen/CGExprScalar.cpp @@ -571,6 +571,7 @@ Value *ScalarExprEmitter::VisitImplicitCastExpr(const ImplicitCastExpr *E) { return V; } else if (E->getType()->isReferenceType()) { + // FIXME: An expression cannot have reference type. return EmitLValue(Op).getAddress(); } diff --git a/lib/CodeGen/CodeGenTypes.cpp b/lib/CodeGen/CodeGenTypes.cpp index 2d4c27c2ac..85d7384c6c 100644 --- a/lib/CodeGen/CodeGenTypes.cpp +++ b/lib/CodeGen/CodeGenTypes.cpp @@ -266,7 +266,8 @@ const llvm::Type *CodeGenTypes::ConvertNewType(QualType T) { ConvertTypeRecursive(cast<ComplexType>(Ty).getElementType()); return llvm::StructType::get(EltTy, EltTy, NULL); } - case Type::Reference: { + case Type::LValueReference: + case Type::RValueReference: { const ReferenceType &RTy = cast<ReferenceType>(Ty); QualType ETy = RTy.getPointeeType(); llvm::OpaqueType *PointeeType = llvm::OpaqueType::get(); diff --git a/lib/CodeGen/Mangle.cpp b/lib/CodeGen/Mangle.cpp index 92eeb5db14..d54849bd78 100644 --- a/lib/CodeGen/Mangle.cpp +++ b/lib/CodeGen/Mangle.cpp @@ -365,12 +365,17 @@ void CXXNameMangler::mangleType(QualType T) { mangleType(PT->getPointeeType()); } // ::= R <type> # reference-to - // ::= O <type> # rvalue reference-to (C++0x) - else if (const ReferenceType *RT = dyn_cast<ReferenceType>(T.getTypePtr())) { - // FIXME: rvalue references + else if (const LValueReferenceType *RT = + dyn_cast<LValueReferenceType>(T.getTypePtr())) { Out << 'R'; mangleType(RT->getPointeeType()); } + // ::= O <type> # rvalue reference-to (C++0x) + else if (const RValueReferenceType *RT = + dyn_cast<RValueReferenceType>(T.getTypePtr())) { + Out << 'O'; + mangleType(RT->getPointeeType()); + } // ::= C <type> # complex pair (C 2000) else if (const ComplexType *CT = dyn_cast<ComplexType>(T.getTypePtr())) { Out << 'C'; |