forked from OSchip/llvm-project
Refactor some code into a new findMaterializedTemporary function.
llvm-svn: 166849
This commit is contained in:
parent
b413676cd7
commit
b9d75ca84b
|
@ -227,6 +227,27 @@ CreateReferenceTemporary(CodeGenFunction &CGF, QualType Type,
|
||||||
return CGF.CreateMemTemp(Type, "ref.tmp");
|
return CGF.CreateMemTemp(Type, "ref.tmp");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const Expr *
|
||||||
|
findMaterializedTemporary(const Expr *E, const MaterializeTemporaryExpr *&MTE) {
|
||||||
|
// Look through single-element init lists that claim to be lvalues. They're
|
||||||
|
// just syntactic wrappers in this case.
|
||||||
|
if (const InitListExpr *ILE = dyn_cast<InitListExpr>(E)) {
|
||||||
|
if (ILE->getNumInits() == 1 && ILE->isGLValue())
|
||||||
|
E = ILE->getInit(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Look through expressions for materialized temporaries (for now).
|
||||||
|
if (const MaterializeTemporaryExpr *M
|
||||||
|
= dyn_cast<MaterializeTemporaryExpr>(E)) {
|
||||||
|
MTE = M;
|
||||||
|
E = M->GetTemporaryExpr();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (const CXXDefaultArgExpr *DAE = dyn_cast<CXXDefaultArgExpr>(E))
|
||||||
|
E = DAE->getExpr();
|
||||||
|
return E;
|
||||||
|
}
|
||||||
|
|
||||||
static const Expr *
|
static const Expr *
|
||||||
skipRValueSubobjectAdjustments(const Expr *E,
|
skipRValueSubobjectAdjustments(const Expr *E,
|
||||||
SmallVectorImpl<SubobjectAdjustment> &Adjustments) {
|
SmallVectorImpl<SubobjectAdjustment> &Adjustments) {
|
||||||
|
@ -279,31 +300,17 @@ EmitExprForReferenceBinding(CodeGenFunction &CGF, const Expr *E,
|
||||||
const CXXDestructorDecl *&ReferenceTemporaryDtor,
|
const CXXDestructorDecl *&ReferenceTemporaryDtor,
|
||||||
QualType &ObjCARCReferenceLifetimeType,
|
QualType &ObjCARCReferenceLifetimeType,
|
||||||
const NamedDecl *InitializedDecl) {
|
const NamedDecl *InitializedDecl) {
|
||||||
// Look through single-element init lists that claim to be lvalues. They're
|
const MaterializeTemporaryExpr *M = NULL;
|
||||||
// just syntactic wrappers in this case.
|
E = findMaterializedTemporary(E, M);
|
||||||
if (const InitListExpr *ILE = dyn_cast<InitListExpr>(E)) {
|
|
||||||
if (ILE->getNumInits() == 1 && ILE->isGLValue())
|
|
||||||
E = ILE->getInit(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Look through expressions for materialized temporaries (for now).
|
|
||||||
if (const MaterializeTemporaryExpr *M
|
|
||||||
= dyn_cast<MaterializeTemporaryExpr>(E)) {
|
|
||||||
// Objective-C++ ARC:
|
// Objective-C++ ARC:
|
||||||
// If we are binding a reference to a temporary that has ownership, we
|
// If we are binding a reference to a temporary that has ownership, we
|
||||||
// need to perform retain/release operations on the temporary.
|
// need to perform retain/release operations on the temporary.
|
||||||
if (CGF.getContext().getLangOpts().ObjCAutoRefCount &&
|
if (M && CGF.getContext().getLangOpts().ObjCAutoRefCount &&
|
||||||
E->getType()->isObjCLifetimeType() &&
|
M->getType()->isObjCLifetimeType() &&
|
||||||
(E->getType().getObjCLifetime() == Qualifiers::OCL_Strong ||
|
(M->getType().getObjCLifetime() == Qualifiers::OCL_Strong ||
|
||||||
E->getType().getObjCLifetime() == Qualifiers::OCL_Weak ||
|
M->getType().getObjCLifetime() == Qualifiers::OCL_Weak ||
|
||||||
E->getType().getObjCLifetime() == Qualifiers::OCL_Autoreleasing))
|
M->getType().getObjCLifetime() == Qualifiers::OCL_Autoreleasing))
|
||||||
ObjCARCReferenceLifetimeType = E->getType();
|
ObjCARCReferenceLifetimeType = M->getType();
|
||||||
|
|
||||||
E = M->GetTemporaryExpr();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (const CXXDefaultArgExpr *DAE = dyn_cast<CXXDefaultArgExpr>(E))
|
|
||||||
E = DAE->getExpr();
|
|
||||||
|
|
||||||
if (const ExprWithCleanups *EWC = dyn_cast<ExprWithCleanups>(E)) {
|
if (const ExprWithCleanups *EWC = dyn_cast<ExprWithCleanups>(E)) {
|
||||||
CGF.enterFullExpression(EWC);
|
CGF.enterFullExpression(EWC);
|
||||||
|
|
Loading…
Reference in New Issue