提交 15a3ba0f 编写于 作者: R rfield

8022720: Method refeerences - private method should be accessible (nested classes)

Reviewed-by: jjg, ksrini
上级 28f297a4
......@@ -2087,13 +2087,6 @@ public class LambdaToMethod extends TreeTranslator {
return tree.sym.owner == syms.arrayClass;
}
boolean isPrivateConstructor() {
//hack needed to workaround 292 bug (8005122)
//when 292 issue is fixed we should simply remove this
return tree.sym.name == names.init &&
(tree.sym.flags() & PRIVATE) != 0;
}
boolean receiverAccessible() {
//hack needed to workaround 292 bug (7087658)
//when 292 issue is fixed we should remove this and change the backend
......@@ -2101,13 +2094,25 @@ public class LambdaToMethod extends TreeTranslator {
return tree.ownerAccessible;
}
/**
* The VM does not support access across nested classes (8010319).
* Were that ever to change, this should be removed.
*/
boolean isPrivateInOtherClass() {
return (tree.sym.flags() & PRIVATE) != 0 &&
!types.isSameType(
types.erasure(tree.sym.enclClass().asType()),
types.erasure(owner.enclClass().asType()));
}
/**
* Does this reference needs a bridge (i.e. var args need to be
* expanded or "super" is used)
*/
final boolean needsBridge() {
return isSuper || needsVarArgsConversion() || isArrayOp() ||
isPrivateConstructor() || !receiverAccessible();
isPrivateInOtherClass() ||
!receiverAccessible();
}
Type generatedRefSig() {
......
/*
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8022720
* @summary private method should be accessible (nested classes)
* @run main MethodInvoker
*/
interface MyFunctionalInterface1 {
int invokeMethodReference();
}
public class MethodInvoker {
public static void main(String[] args) throws Exception {
MethodInvoker.invoke();
System.out.println("Passed!");
}
public static void invoke() throws Exception {
MethodSupplier ms = new MethodSupplier();
MyFunctionalInterface1 fi = ms::m;
if (fi.invokeMethodReference() != 123) {
throw new Exception();
}
}
static class MethodSupplier {
private int m() {
return 123;
}
}
}
/*
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8022720
* @summary private method should be accessible (nested classes)
* @run main MethodSupplier
*/
interface MyFunctionalInterface2 {
int invokeMethodReference();
}
public class MethodSupplier {
public static void main(String[] args) throws Exception {
MethodInvoker.invoke();
System.out.println("Passed!");
}
private int m() {
return 4321;
}
static class MethodInvoker {
public static void invoke() throws Exception {
MethodSupplier ms = new MethodSupplier();
MyFunctionalInterface2 fi = ms::m;
if (fi.invokeMethodReference() != 4321) {
throw new Exception();
}
}
}
}
/*
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8022720
* @summary private method should be accessible (nested classes)
* @run main ThirdClass
*/
interface MyFunctionalInterface3 {
int invokeMethodReference();
}
public class ThirdClass {
public static void main(String[] args) throws Exception {
MethodInvoker.invoke();
System.out.println("Passed!");
}
static class MethodSupplier {
private int m() {
return 999;
}
}
static class MethodInvoker {
public static void invoke() throws Exception {
MethodSupplier ms = new MethodSupplier();
MyFunctionalInterface3 fi = ms::m;
if (fi.invokeMethodReference() != 999) {
throw new Exception();
}
}
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册