summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2010-07-23 19:25:41 +0000
committerEli Friedman <eli.friedman@gmail.com>2010-07-23 19:25:41 +0000
commitd4c75cdddec4f9ba9201366b6a8f4f810e8f4a38 (patch)
treebd923b4fda2c05a2599d079235150983b2c5c884
parentc51609a0b5f5f5ad9ddabf38152b8da19cd902d8 (diff)
downloadbcm5719-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.cpp2
-rw-r--r--clang/test/SemaCXX/access-member-pointer.cpp11
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'}}
+}
OpenPOWER on IntegriCloud