diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-05-10 20:29:50 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-05-10 20:29:50 +0000 |
commit | b8a98241fce39b598799e4d2c79540e79e408b76 (patch) | |
tree | 3fa7d5bbd93f7885ac079fdd9728f36e9bb66493 | |
parent | 300f0b966cdf8848535437fb3d2f844b93bd8547 (diff) | |
download | bcm5719-llvm-b8a98241fce39b598799e4d2c79540e79e408b76.tar.gz bcm5719-llvm-b8a98241fce39b598799e4d2c79540e79e408b76.zip |
PR15966: don't get confused by a complex integer -> complex integer conversion
and misclassify it as a complex-real conversion.
llvm-svn: 181626
-rw-r--r-- | clang/lib/Sema/SemaOverload.cpp | 2 | ||||
-rw-r--r-- | clang/test/SemaCXX/complex-overload.cpp | 12 |
2 files changed, 10 insertions, 4 deletions
diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp index 3461f91ff31..dbe151c7828 100644 --- a/clang/lib/Sema/SemaOverload.cpp +++ b/clang/lib/Sema/SemaOverload.cpp @@ -1591,7 +1591,7 @@ static bool IsStandardConversion(Sema &S, Expr* From, QualType ToType, // Integral conversions (C++ 4.7). SCS.Second = ICK_Integral_Conversion; FromType = ToType.getUnqualifiedType(); - } else if (FromType->isAnyComplexType() && ToType->isComplexType()) { + } else if (FromType->isAnyComplexType() && ToType->isAnyComplexType()) { // Complex conversions (C99 6.3.1.6) SCS.Second = ICK_Complex_Conversion; FromType = ToType.getUnqualifiedType(); diff --git a/clang/test/SemaCXX/complex-overload.cpp b/clang/test/SemaCXX/complex-overload.cpp index 719a850dbf7..1381968751a 100644 --- a/clang/test/SemaCXX/complex-overload.cpp +++ b/clang/test/SemaCXX/complex-overload.cpp @@ -42,9 +42,15 @@ void test_promote_or_convert2(float _Complex fc) { int *cp = promote_or_convert2(fc); } -char *promote_or_convert3(int _Complex); -int *promote_or_convert3(long _Complex); +char *promote_or_convert3(int _Complex); // expected-note {{candidate}} +int *promote_or_convert3(long _Complex); // expected-note {{candidate}} void test_promote_or_convert3(short _Complex sc) { - char *cp = promote_or_convert3(sc); + char *cp1 = promote_or_convert3(sc); + char *cp2 = promote_or_convert3(1i); + int *cp3 = promote_or_convert3(1il); + int *cp4 = promote_or_convert3(1ill); // expected-error {{ambiguous}} } + +char &convert4(short _Complex); +char &test_convert4 = convert4(1i); |