r325335 - Revert r325321 "[Sema] Take into account the current context when checking the"
Hans Wennborg via cfe-commits
cfe-commits at lists.llvm.org
Fri Feb 16 04:06:32 PST 2018
Author: hans
Date: Fri Feb 16 04:06:32 2018
New Revision: 325335
URL: http://llvm.org/viewvc/llvm-project?rev=325335&view=rev
Log:
Revert r325321 "[Sema] Take into account the current context when checking the"
This broke the Chromium build, see https://crbug.com/813017
> accessibility of a class member.
>
> This fixes PR32898.
>
> rdar://problem/33737747
>
> Differential revision: https://reviews.llvm.org/D36918
Modified:
cfe/trunk/lib/Sema/SemaAccess.cpp
cfe/trunk/test/SemaCXX/access.cpp
Modified: cfe/trunk/lib/Sema/SemaAccess.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaAccess.cpp?rev=325335&r1=325334&r2=325335&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaAccess.cpp (original)
+++ cfe/trunk/lib/Sema/SemaAccess.cpp Fri Feb 16 04:06:32 2018
@@ -1793,11 +1793,6 @@ Sema::AccessResult Sema::CheckAddressOfM
AccessTarget Entity(Context, AccessTarget::Member, NamingClass, Found,
/*no instance context*/ QualType());
-
- if (IsAccessible(*this, EffectiveContext(CurScope->getEntity()), Entity) ==
- ::AR_accessible)
- return AR_accessible;
-
Entity.setDiag(diag::err_access)
<< Ovl->getSourceRange();
Modified: cfe/trunk/test/SemaCXX/access.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/access.cpp?rev=325335&r1=325334&r2=325335&view=diff
==============================================================================
--- cfe/trunk/test/SemaCXX/access.cpp (original)
+++ cfe/trunk/test/SemaCXX/access.cpp Fri Feb 16 04:06:32 2018
@@ -169,38 +169,3 @@ namespace ThisLambdaIsNotMyFriend {
}
void bar() { foo<void>(); }
}
-
-namespace OverloadedMemberFunctionPointer {
- template<class T, void(T::*pMethod)()>
- void func0() {}
-
- template<class T, void(T::*pMethod)(int)>
- void func1() {}
-
- template<class T>
- void func2(void(*fn)()) {} // expected-note 2 {{candidate function not viable: no overload of 'func}}
-
- class C {
- private:
- friend void friendFunc();
- void overloadedMethod();
- protected:
- void overloadedMethod(int);
- public:
- void overloadedMethod(int, int);
- void method() {
- func2<int>(&func0<C, &C::overloadedMethod>);
- func2<int>(&func1<C, &C::overloadedMethod>);
- }
- };
-
- void friendFunc() {
- func2<int>(&func0<C, &C::overloadedMethod>);
- func2<int>(&func1<C, &C::overloadedMethod>);
- }
-
- void nonFriendFunc() {
- func2<int>(&func0<C, &C::overloadedMethod>); // expected-error {{no matching function for call to 'func2'}}
- func2<int>(&func1<C, &C::overloadedMethod>); // expected-error {{no matching function for call to 'func2'}}
- }
-}
More information about the cfe-commits
mailing list