Index: lib/Sema/SemaOverload.cpp =================================================================== --- lib/Sema/SemaOverload.cpp (revision 234797) +++ lib/Sema/SemaOverload.cpp (working copy) @@ -2954,7 +2954,10 @@ bool HadMultipleCandidates = (CandidateSet.size() > 1); OverloadCandidateSet::iterator Best; - switch (CandidateSet.BestViableFunction(S, From->getLocStart(), Best, true)) { + OverloadingResult OVLReasult = + CandidateSet.BestViableFunction(S, From->getLocStart(), Best, true); + switch (OVLReasult) { + case OR_Deleted: case OR_Success: { // Record the standard conversion we used and the conversion function. CXXConstructorDecl *Constructor = cast(Best->Function); @@ -2967,13 +2970,11 @@ User.After.setAsIdentityConversion(); User.After.setFromType(ThisType->getAs()->getPointeeType()); User.After.setAllToTypes(ToType); - return OR_Success; + return OVLReasult; } case OR_No_Viable_Function: return OR_No_Viable_Function; - case OR_Deleted: - return OR_Deleted; case OR_Ambiguous: return OR_Ambiguous; } Index: test/SemaCXX/cxx11-call-to-deleted-constructor.cpp =================================================================== --- test/SemaCXX/cxx11-call-to-deleted-constructor.cpp (revision 0) +++ test/SemaCXX/cxx11-call-to-deleted-constructor.cpp (working copy) @@ -0,0 +1,41 @@ +// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s +// rdar://20281011 + +namespace std { +template class initializer_list { }; +} + +namespace cva { + +template +class Matrix { +public: + + typedef VT value_type; + inline __attribute__((always_inline)) value_type& at(); +}; + +template using Vector = Matrix; + +template +using RGBValue = Vector; +using RGBFValue = RGBValue; + +template class Matrix { // expected-note {{passing argument to parameter here}} +public: + typedef VT value_type; + Matrix(const unsigned int nRows, const unsigned int nColumns, const value_type* data = nullptr); + + Matrix(const std::initializer_list& list) = delete; // expected-note {{'Matrix' has been explicitly marked deleted here}} + +}; + +void getLaplacianClosedForm() +{ + Matrix winI(0, 3); + RGBFValue* inputPreL; + winI = { inputPreL->at() }; // expected-error {{call to deleted constructor of 'cva::Matrix &&'}} +} + +} +