summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2013-05-10 20:29:50 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2013-05-10 20:29:50 +0000
commitb8a98241fce39b598799e4d2c79540e79e408b76 (patch)
tree3fa7d5bbd93f7885ac079fdd9728f36e9bb66493
parent300f0b966cdf8848535437fb3d2f844b93bd8547 (diff)
downloadbcm5719-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.cpp2
-rw-r--r--clang/test/SemaCXX/complex-overload.cpp12
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);
OpenPOWER on IntegriCloud