diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-01-20 00:18:04 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-01-20 00:18:04 +0000 |
commit | 668443efb1db5568efc0cc7c1dfbf8ea04e8fb1d (patch) | |
tree | ba78db1c2e8f86bfd83e5a036929a58cf2862714 /clang/test/SemaCXX/ambig-user-defined-conversions.cpp | |
parent | 2d9e532a3a99d84a30997012c48d24b5e54d13df (diff) | |
download | bcm5719-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.cpp | 8 |
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':}} +} |