mirror of
https://github.com/intel/llvm.git
synced 2026-02-03 02:26:27 +08:00
When performing copy initialization via user-defined conversions,
don't allow two user-defined conversions. Fixes PR6595 (again). llvm-svn: 107379
This commit is contained in:
@@ -2858,7 +2858,6 @@ static void TryUserDefinedConversion(Sema &S,
|
||||
Con != ConEnd; ++Con) {
|
||||
NamedDecl *D = *Con;
|
||||
DeclAccessPair FoundDecl = DeclAccessPair::make(D, D->getAccess());
|
||||
bool SuppressUserConversions = false;
|
||||
|
||||
// Find the constructor (which may be a template).
|
||||
CXXConstructorDecl *Constructor = 0;
|
||||
@@ -2867,17 +2866,8 @@ static void TryUserDefinedConversion(Sema &S,
|
||||
if (ConstructorTmpl)
|
||||
Constructor = cast<CXXConstructorDecl>(
|
||||
ConstructorTmpl->getTemplatedDecl());
|
||||
else {
|
||||
else
|
||||
Constructor = cast<CXXConstructorDecl>(D);
|
||||
|
||||
// If we're performing copy initialization using a copy constructor,
|
||||
// we suppress user-defined conversions on the arguments.
|
||||
// FIXME: Move constructors?
|
||||
if (Kind.getKind() == InitializationKind::IK_Copy &&
|
||||
Constructor->isCopyConstructor())
|
||||
SuppressUserConversions = true;
|
||||
|
||||
}
|
||||
|
||||
if (!Constructor->isInvalidDecl() &&
|
||||
Constructor->isConvertingConstructor(AllowExplicit)) {
|
||||
@@ -2885,11 +2875,11 @@ static void TryUserDefinedConversion(Sema &S,
|
||||
S.AddTemplateOverloadCandidate(ConstructorTmpl, FoundDecl,
|
||||
/*ExplicitArgs*/ 0,
|
||||
&Initializer, 1, CandidateSet,
|
||||
SuppressUserConversions);
|
||||
/*SuppressUserConversions=*/true);
|
||||
else
|
||||
S.AddOverloadCandidate(Constructor, FoundDecl,
|
||||
&Initializer, 1, CandidateSet,
|
||||
SuppressUserConversions);
|
||||
/*SuppressUserConversions=*/true);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -199,17 +199,24 @@ void test()
|
||||
}
|
||||
|
||||
namespace PR6595 {
|
||||
struct OtherString {
|
||||
OtherString();
|
||||
OtherString(const char*);
|
||||
};
|
||||
|
||||
struct String {
|
||||
String(const char *);
|
||||
String(const OtherString&);
|
||||
operator const char*() const;
|
||||
};
|
||||
|
||||
void f(bool Cond, String S) {
|
||||
void f(bool Cond, String S, OtherString OS) {
|
||||
(void)(Cond? S : "");
|
||||
(void)(Cond? "" : S);
|
||||
const char a[1] = {'a'};
|
||||
(void)(Cond? S : a);
|
||||
(void)(Cond? a : S);
|
||||
(void)(Cond? OS : S);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user