diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-09-09 23:08:42 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-09-09 23:08:42 +0000 |
commit | 39da0b8145eaec7da7004f9b3645c5c9f4f63b1d (patch) | |
tree | 736478849d6a4c9123a029dc251b7b242111088d /lib/Sema/SemaInit.cpp | |
parent | 84ec96c8a810df59de4052368beab29f13456707 (diff) |
Improve handling of initialization by constructor, by ensuring that
such initializations properly convert constructor arguments and fill
in default arguments where necessary. This also makes the ownership
model more clear.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@81394 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaInit.cpp')
-rw-r--r-- | lib/Sema/SemaInit.cpp | 44 |
1 files changed, 32 insertions, 12 deletions
diff --git a/lib/Sema/SemaInit.cpp b/lib/Sema/SemaInit.cpp index c1f7716330..328609a192 100644 --- a/lib/Sema/SemaInit.cpp +++ b/lib/Sema/SemaInit.cpp @@ -172,18 +172,23 @@ bool Sema::CheckInitializerTypes(Expr *&Init, QualType &DeclType, if (RD->hasTrivialConstructor() && RD->hasTrivialDestructor()) return false; + ASTOwningVector<&ActionBase::DeleteExpr> ConstructorArgs(*this); + CXXConstructorDecl *Constructor - = PerformInitializationByConstructor(DeclType, &Init, 1, - InitLoc, Init->getSourceRange(), - InitEntity, - DirectInit? IK_Direct : IK_Copy); + = PerformInitializationByConstructor(DeclType, + MultiExprArg(*this, + (void **)&Init, 1), + InitLoc, Init->getSourceRange(), + InitEntity, + DirectInit? IK_Direct : IK_Copy, + ConstructorArgs); if (!Constructor) return true; OwningExprResult InitResult = BuildCXXConstructExpr(/*FIXME:ConstructLoc*/SourceLocation(), DeclType, Constructor, - MultiExprArg(*this, (void**)&Init, 1)); + move_arg(ConstructorArgs)); if (InitResult.isInvalid()) return true; @@ -1810,13 +1815,28 @@ bool Sema::CheckValueInitialization(QualType Type, SourceLocation Loc) { // constructor (12.1), then the default constructor for T is // called (and the initialization is ill-formed if T has no // accessible default constructor); - if (ClassDecl->hasUserDeclaredConstructor()) - // FIXME: Eventually, we'll need to put the constructor decl into the - // AST. - return PerformInitializationByConstructor(Type, 0, 0, Loc, - SourceRange(Loc), - DeclarationName(), - IK_Direct); + if (ClassDecl->hasUserDeclaredConstructor()) { + ASTOwningVector<&ActionBase::DeleteExpr> ConstructorArgs(*this); + + CXXConstructorDecl *Constructor + = PerformInitializationByConstructor(Type, + MultiExprArg(*this, 0, 0), + Loc, SourceRange(Loc), + DeclarationName(), + IK_Direct, + ConstructorArgs); + if (!Constructor) + return true; + + OwningExprResult Init + = BuildCXXConstructExpr(Loc, Type, Constructor, + move_arg(ConstructorArgs)); + if (Init.isInvalid()) + return true; + + // FIXME: Actually perform the value-initialization! + return false; + } } } |