diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2009-10-14 00:52:43 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-10-14 00:52:43 +0000 |
| commit | 31481d8b22a93bb419982916c65860b7da51e633 (patch) | |
| tree | 4e4bf2dacf0a56328e68d975cb5b5e662c221f46 /clang/lib | |
| parent | 153d23f4cd0e209336b0c6af984fe282f67cadcb (diff) | |
| download | bcm5719-llvm-31481d8b22a93bb419982916c65860b7da51e633.tar.gz bcm5719-llvm-31481d8b22a93bb419982916c65860b7da51e633.zip | |
Handle ambiguity of reference initialization.
Removes a FIXME.
llvm-svn: 84068
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 075f756bb59..acb2a677702 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -3731,7 +3731,16 @@ Sema::CheckReferenceInit(Expr *&Init, QualType DeclType, break; case OR_Ambiguous: - assert(false && "Ambiguous reference binding conversions not implemented."); + if (ICS) { + for (OverloadCandidateSet::iterator Cand = CandidateSet.begin(); + Cand != CandidateSet.end(); ++Cand) + if (Cand->Viable) + ICS->ConversionFunctionSet.push_back(Cand->Function); + break; + } + Diag(DeclLoc, diag::err_ref_init_ambiguous) << DeclType << Init->getType() + << Init->getSourceRange(); + PrintOverloadCandidates(CandidateSet, /*OnlyViable=*/true); return true; case OR_No_Viable_Function: |

