diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2009-09-15 19:12:21 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-09-15 19:12:21 +0000 |
commit | 34acd3e62c4ca3a2904f2515ff2a1a94c7d27b01 (patch) | |
tree | 7b85e3e0751dcf22720553ea1957de31d12f55f3 /lib/Sema/SemaInit.cpp | |
parent | f882574cf640d5c8355965e1c486f9d8d8ffcf47 (diff) |
Issue good diagnostics when initialization failes due to
ambiguity in type conversion function selection.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@81898 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaInit.cpp')
-rw-r--r-- | lib/Sema/SemaInit.cpp | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/lib/Sema/SemaInit.cpp b/lib/Sema/SemaInit.cpp index 328609a192..6574524d14 100644 --- a/lib/Sema/SemaInit.cpp +++ b/lib/Sema/SemaInit.cpp @@ -70,11 +70,23 @@ static bool CheckSingleInitializer(Expr *&Init, QualType DeclType, if (S.getLangOptions().CPlusPlus) { // FIXME: I dislike this error message. A lot. - if (S.PerformImplicitConversion(Init, DeclType, "initializing", DirectInit)) - return S.Diag(Init->getSourceRange().getBegin(), - diag::err_typecheck_convert_incompatible) - << DeclType << Init->getType() << "initializing" - << Init->getSourceRange(); + if (S.PerformImplicitConversion(Init, DeclType, + "initializing", DirectInit)) { + ImplicitConversionSequence ICS; + OverloadCandidateSet CandidateSet; + if (S.IsUserDefinedConversion(Init, DeclType, ICS.UserDefined, + CandidateSet, + true, false, false) != S.OR_Ambiguous) + return S.Diag(Init->getSourceRange().getBegin(), + diag::err_typecheck_convert_incompatible) + << DeclType << Init->getType() << "initializing" + << Init->getSourceRange(); + S.Diag(Init->getSourceRange().getBegin(), + diag::err_typecheck_convert_ambiguous) + << DeclType << Init->getType() << Init->getSourceRange(); + S.PrintOverloadCandidates(CandidateSet, /*OnlyViable=*/false); + return true; + } return false; } |