summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2009-08-28 22:04:50 +0000
committerFariborz Jahanian <fjahanian@apple.com>2009-08-28 22:04:50 +0000
commit2fee79a9a19b0b60f74c2b8f3e475a512aced3e2 (patch)
tree15b11dd02162b6f11a963fbc5dddba9071b11059 /clang/lib
parentf3db00335894ca4c11263e36004527af43328ee0 (diff)
downloadbcm5719-llvm-2fee79a9a19b0b60f74c2b8f3e475a512aced3e2.tar.gz
bcm5719-llvm-2fee79a9a19b0b60f74c2b8f3e475a512aced3e2.zip
path to ir-gen 12.3.1 Conversion by constructor
llvm-svn: 80398
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/AST/StmtDumper.cpp3
-rw-r--r--clang/lib/Sema/SemaExprCXX.cpp27
2 files changed, 23 insertions, 7 deletions
diff --git a/clang/lib/AST/StmtDumper.cpp b/clang/lib/AST/StmtDumper.cpp
index 5f680ea5429..720188377d5 100644
--- a/clang/lib/AST/StmtDumper.cpp
+++ b/clang/lib/AST/StmtDumper.cpp
@@ -333,6 +333,9 @@ void StmtDumper::VisitCastExpr(CastExpr *Node) {
case CastExpr::CK_UserDefinedConversion:
fprintf(F, "<UserDefinedConversion>");
break;
+ case CastExpr::CK_ConstructorConversion:
+ fprintf(F, "<ConstructorConversion>");
+ break;
}
}
diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp
index 61891e78833..fe67ec6face 100644
--- a/clang/lib/Sema/SemaExprCXX.cpp
+++ b/clang/lib/Sema/SemaExprCXX.cpp
@@ -920,9 +920,10 @@ Sema::PerformImplicitConversion(Expr *&From, QualType ToType,
break;
case ImplicitConversionSequence::UserDefinedConversion:
- // FIXME. Support other kinds of user defined convesions.
- if (CXXConversionDecl *CV =
- dyn_cast<CXXConversionDecl>(ICS.UserDefined.ConversionFunction))
+ {
+ FunctionDecl *FD = ICS.UserDefined.ConversionFunction;
+ CastExpr::CastKind CastKind = CastExpr::CK_Unknown;
+ if (CXXConversionDecl *CV = dyn_cast<CXXConversionDecl>(FD)) {
// FIXME. Get actual Source Location.
From =
new (Context) CXXFunctionalCastExpr(ToType.getNonReferenceType(),
@@ -930,10 +931,22 @@ Sema::PerformImplicitConversion(Expr *&From, QualType ToType,
CastExpr::CK_UserDefinedConversion,
From, CV,
SourceLocation());
- ImpCastExprToType(From, ToType.getNonReferenceType(),
- CastExpr::CK_Unknown,
- ToType->isLValueReferenceType());
- return false;
+ CastKind = CastExpr::CK_UserDefinedConversion;
+ }
+ else if (CXXConstructorDecl *CD = dyn_cast<CXXConstructorDecl>(FD)) {
+ // FIXME. Do we need to check for isLValueReferenceType?
+ DefaultFunctionArrayConversion(From);
+ OwningExprResult InitResult =
+ BuildCXXConstructExpr(ToType.getNonReferenceType(),
+ CD, &From, 1);
+ From = InitResult.takeAs<Expr>();
+ CastKind = CastExpr::CK_ConstructorConversion ;
+ }
+ ImpCastExprToType(From, ToType.getNonReferenceType(),
+ CastKind,
+ ToType->isLValueReferenceType());
+ return false;
+ }
case ImplicitConversionSequence::EllipsisConversion:
assert(false && "Cannot perform an ellipsis conversion");
OpenPOWER on IntegriCloud