summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/ambig-user-defined-conversions.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-01-20 00:18:04 +0000
committerDouglas Gregor <dgregor@apple.com>2011-01-20 00:18:04 +0000
commit668443efb1db5568efc0cc7c1dfbf8ea04e8fb1d (patch)
treeba78db1c2e8f86bfd83e5a036929a58cf2862714 /clang/test/SemaCXX/ambig-user-defined-conversions.cpp
parent2d9e532a3a99d84a30997012c48d24b5e54d13df (diff)
downloadbcm5719-llvm-668443efb1db5568efc0cc7c1dfbf8ea04e8fb1d.tar.gz
bcm5719-llvm-668443efb1db5568efc0cc7c1dfbf8ea04e8fb1d.zip
Sema::BuildCXXMemberCallExpr() can fail due to access or ambiguities,
so allow it to propagate the failure outward. Fixes the crashing part of <rdar://problem/8876150>. llvm-svn: 123863
Diffstat (limited to 'clang/test/SemaCXX/ambig-user-defined-conversions.cpp')
-rw-r--r--clang/test/SemaCXX/ambig-user-defined-conversions.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/ambig-user-defined-conversions.cpp b/clang/test/SemaCXX/ambig-user-defined-conversions.cpp
index dd8501adb62..bf45e5d4d88 100644
--- a/clang/test/SemaCXX/ambig-user-defined-conversions.cpp
+++ b/clang/test/SemaCXX/ambig-user-defined-conversions.cpp
@@ -57,3 +57,11 @@ namespace test1 {
}
}
+namespace rdar8876150 {
+ struct A { operator bool(); };
+ struct B : A { };
+ struct C : A { };
+ struct D : B, C { };
+
+ bool f(D d) { return !d; } // expected-error{{ambiguous conversion from derived class 'rdar8876150::D' to base class 'rdar8876150::A':}}
+}
OpenPOWER on IntegriCloud