diff options
author | Dmitry Polukhin <dmitry.polukhin@gmail.com> | 2016-07-19 11:29:16 +0000 |
---|---|---|
committer | Dmitry Polukhin <dmitry.polukhin@gmail.com> | 2016-07-19 11:29:16 +0000 |
commit | ba57f027207763e6eb767949fb2ba8855098e42f (patch) | |
tree | 4b687be44d47504819d164c454325d8c6ab85a3c | |
parent | 22117a8913debfc2d12671031b537753e7c9bb78 (diff) | |
download | bcm5719-llvm-ba57f027207763e6eb767949fb2ba8855098e42f.tar.gz bcm5719-llvm-ba57f027207763e6eb767949fb2ba8855098e42f.zip |
Deprecated (legacy) string literal conversion to 'char *' causes strange overloading resolution
It's a patch for PR28050. Seems like overloading resolution wipes out
the first standard conversion sequence (before user-defined conversion)
in case of deprecated string literal conversion.
Differential revision: https://reviews.llvm.org/D21228
Patch by Alexander Makarov
llvm-svn: 275970
-rw-r--r-- | clang/include/clang/Sema/Overload.h | 7 | ||||
-rw-r--r-- | clang/lib/Sema/SemaOverload.cpp | 2 | ||||
-rw-r--r-- | clang/test/SemaCXX/pr28050.cpp | 11 |
3 files changed, 16 insertions, 4 deletions
diff --git a/clang/include/clang/Sema/Overload.h b/clang/include/clang/Sema/Overload.h index d0f21cd71f8..68678ad7fcd 100644 --- a/clang/include/clang/Sema/Overload.h +++ b/clang/include/clang/Sema/Overload.h @@ -428,8 +428,11 @@ namespace clang { }; ImplicitConversionSequence() - : ConversionKind(Uninitialized), StdInitializerListElement(false) - {} + : ConversionKind(Uninitialized), StdInitializerListElement(false) { + Standard.First = ICK_Identity; + Standard.Second = ICK_Identity; + Standard.Third = ICK_Identity; + } ~ImplicitConversionSequence() { destruct(); } diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp index b025a397edc..dfb4cceddfd 100644 --- a/clang/lib/Sema/SemaOverload.cpp +++ b/clang/lib/Sema/SemaOverload.cpp @@ -1199,7 +1199,6 @@ TryUserDefinedConversion(Sema &S, Expr *From, QualType ToType, case OR_Success: case OR_Deleted: ICS.setUserDefined(); - ICS.UserDefined.Before.setAsIdentityConversion(); // C++ [over.ics.user]p4: // A conversion of an expression of class type to the same class // type is given Exact Match rank, and a conversion of an @@ -4540,7 +4539,6 @@ TryReferenceInit(Sema &S, Expr *Init, QualType DeclType, return ICS; } - ICS.UserDefined.Before.setAsIdentityConversion(); ICS.UserDefined.After.ReferenceBinding = true; ICS.UserDefined.After.IsLvalueReference = !isRValRef; ICS.UserDefined.After.BindsToFunctionLvalue = false; diff --git a/clang/test/SemaCXX/pr28050.cpp b/clang/test/SemaCXX/pr28050.cpp new file mode 100644 index 00000000000..57e90eb7516 --- /dev/null +++ b/clang/test/SemaCXX/pr28050.cpp @@ -0,0 +1,11 @@ +// RUN: %clang_cc1 -triple x86_64-pc-windows-msvc -std=c++11 %s -fsyntax-only +// +// expected-no-diagnostics + +class A { +public: + A(char *s) {} + A(A &&) = delete; +}; + +int main() { A a("OK"); } |