diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-05-19 04:45:15 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-05-19 04:45:15 +0000 |
| commit | 549c5bd8248b868f46ae36012e42f3e05adb8330 (patch) | |
| tree | 0452c361941a1f079fea265f892910b84f25dc2e /clang/lib/Sema/SemaExprCXX.cpp | |
| parent | cec35d7e6a69dffa7aa53aa53298636e33175e14 (diff) | |
| download | bcm5719-llvm-549c5bd8248b868f46ae36012e42f3e05adb8330.tar.gz bcm5719-llvm-549c5bd8248b868f46ae36012e42f3e05adb8330.zip | |
Create CXXConstructExpr calls for arguments passed to functions.
llvm-svn: 72102
Diffstat (limited to 'clang/lib/Sema/SemaExprCXX.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaExprCXX.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp index 109247f977e..30a7598ec62 100644 --- a/clang/lib/Sema/SemaExprCXX.cpp +++ b/clang/lib/Sema/SemaExprCXX.cpp @@ -854,9 +854,13 @@ Sema::PerformImplicitConversion(Expr *&From, QualType ToType, QualType FromType = From->getType(); if (SCS.CopyConstructor) { - // FIXME: Create a temporary object by calling the copy constructor. - ImpCastExprToType(From, ToType.getNonReferenceType(), - ToType->isLValueReferenceType()); + // FIXME: When can ToType be a reference type? + assert(!ToType->isReferenceType()); + + CXXTempVarDecl *Temp = CXXTempVarDecl::Create(Context, CurContext, ToType); + // FIXME: Keep track of whether the copy constructor is elidable or not. + From = CXXConstructExpr::Create(Context, Temp, ToType, + SCS.CopyConstructor, false, &From, 1); return false; } |

