diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2010-07-23 19:25:41 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2010-07-23 19:25:41 +0000 |
commit | d4c75cdddec4f9ba9201366b6a8f4f810e8f4a38 (patch) | |
tree | bd923b4fda2c05a2599d079235150983b2c5c884 | |
parent | c51609a0b5f5f5ad9ddabf38152b8da19cd902d8 (diff) | |
download | bcm5719-llvm-d4c75cdddec4f9ba9201366b6a8f4f810e8f4a38.tar.gz bcm5719-llvm-d4c75cdddec4f9ba9201366b6a8f4f810e8f4a38.zip |
Fix for PR7694: make sure to pass in a RecordType to CheckBaseClassAccess;
fixes crashes on both valid and invalid code. The diagnostic here could
potentially be improved, but it's good enough as-is.
llvm-svn: 109257
-rw-r--r-- | clang/lib/Sema/SemaCXXCast.cpp | 2 | ||||
-rw-r--r-- | clang/test/SemaCXX/access-member-pointer.cpp | 11 |
2 files changed, 12 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaCXXCast.cpp b/clang/lib/Sema/SemaCXXCast.cpp index b8e27e7b728..787bd00ac81 100644 --- a/clang/lib/Sema/SemaCXXCast.cpp +++ b/clang/lib/Sema/SemaCXXCast.cpp @@ -900,7 +900,7 @@ TryStaticMemberPointerUpcast(Sema &Self, Expr *&SrcExpr, QualType SrcType, } if (!CStyle && Self.CheckBaseClassAccess(OpRange.getBegin(), - DestType, SrcType, + DestClass, SrcClass, Paths.front(), diag::err_upcast_to_inaccessible_base)) { msg = 0; diff --git a/clang/test/SemaCXX/access-member-pointer.cpp b/clang/test/SemaCXX/access-member-pointer.cpp new file mode 100644 index 00000000000..676eb10dcdc --- /dev/null +++ b/clang/test/SemaCXX/access-member-pointer.cpp @@ -0,0 +1,11 @@ +// RUN: %clang_cc1 -fsyntax-only -verify %s +// PR7694 + +class A { }; +class B : private A { public: void foo(); }; // expected-note {{declared private here}} +void B::foo() { + (void)static_cast<void(A::*)()>(&B::foo); +} +void bar() { + (void)static_cast<void(A::*)()>(&B::foo); // expected-error {{cannot cast 'B' to its private base class 'A'}} +} |