8173975: Lookup::in should not allow target class be primitive or array class
Reviewed-by: alanb
This commit is contained in:
parent
0b33bc1617
commit
5b0fbb2560
@ -203,7 +203,7 @@ public class MethodHandles {
|
||||
* @param targetClass the target class
|
||||
* @param caller the caller lookup object
|
||||
* @return a lookup object for the target class, with private access
|
||||
* @throws IllegalArgumentException if {@code targetClass} is a primitive type or array class
|
||||
* @throws IllegalArgumentException if {@code targetClass} is a primitive type or void or array class
|
||||
* @throws NullPointerException if {@code targetClass} or {@code caller} is {@code null}
|
||||
* @throws SecurityException if denied by the security manager
|
||||
* @throws IllegalAccessException if any of the other access checks specified above fails
|
||||
@ -1385,7 +1385,7 @@ public class MethodHandles {
|
||||
private Lookup(Class<?> lookupClass, Class<?> prevLookupClass, int allowedModes) {
|
||||
assert prevLookupClass == null || ((allowedModes & MODULE) == 0
|
||||
&& prevLookupClass.getModule() != lookupClass.getModule());
|
||||
|
||||
assert !lookupClass.isArray() && !lookupClass.isPrimitive();
|
||||
this.lookupClass = lookupClass;
|
||||
this.prevLookupClass = prevLookupClass;
|
||||
this.allowedModes = allowedModes;
|
||||
@ -1443,6 +1443,7 @@ public class MethodHandles {
|
||||
* @param requestedLookupClass the desired lookup class for the new lookup object
|
||||
* @return a lookup object which reports the desired lookup class, or the same object
|
||||
* if there is no change
|
||||
* @throws IllegalArgumentException if {@code requestedLookupClass} is a primitive type or void or array class
|
||||
* @throws NullPointerException if the argument is null
|
||||
*
|
||||
* @revised 9
|
||||
@ -1452,6 +1453,11 @@ public class MethodHandles {
|
||||
*/
|
||||
public Lookup in(Class<?> requestedLookupClass) {
|
||||
Objects.requireNonNull(requestedLookupClass);
|
||||
if (requestedLookupClass.isPrimitive())
|
||||
throw new IllegalArgumentException(requestedLookupClass + " is a primitive class");
|
||||
if (requestedLookupClass.isArray())
|
||||
throw new IllegalArgumentException(requestedLookupClass + " is an array class");
|
||||
|
||||
if (allowedModes == TRUSTED) // IMPL_LOOKUP can make any lookup at all
|
||||
return new Lookup(requestedLookupClass, null, FULL_POWER_MODES);
|
||||
if (requestedLookupClass == this.lookupClass)
|
||||
|
68
test/jdk/java/lang/invoke/lookup/LookupClassTest.java
Normal file
68
test/jdk/java/lang/invoke/lookup/LookupClassTest.java
Normal file
@ -0,0 +1,68 @@
|
||||
/*
|
||||
* Copyright (c) 2019, 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 8173975
|
||||
* @summary Lookup::in throws IAE if the target class is a primitive class or array class
|
||||
* @run testng/othervm LookupClassTest
|
||||
*/
|
||||
|
||||
import java.lang.invoke.MethodHandles;
|
||||
import java.lang.invoke.MethodHandles.Lookup;
|
||||
|
||||
import org.testng.annotations.BeforeTest;
|
||||
import org.testng.annotations.Test;
|
||||
import static org.testng.Assert.*;
|
||||
|
||||
public class LookupClassTest {
|
||||
private static final LookupClassTest[] ARRAY = new LookupClassTest[0];
|
||||
@BeforeTest
|
||||
public void test() {
|
||||
assertTrue(ARRAY.getClass().isArray());
|
||||
assertSamePackage(MethodHandles.lookup(), ARRAY.getClass());
|
||||
assertSamePackage(MethodHandles.publicLookup(), int.class);
|
||||
}
|
||||
|
||||
private void assertSamePackage(Lookup lookup, Class<?> targetClass) {
|
||||
assertEquals(lookup.lookupClass().getPackageName(), targetClass.getPackageName());
|
||||
}
|
||||
|
||||
@Test(expectedExceptions = IllegalArgumentException.class)
|
||||
public void arrayLookupClass() {
|
||||
Lookup lookup = MethodHandles.lookup();
|
||||
lookup.in(ARRAY.getClass());
|
||||
}
|
||||
|
||||
@Test(expectedExceptions = IllegalArgumentException.class)
|
||||
public void primitiveLookupClass() {
|
||||
Lookup lookup = MethodHandles.publicLookup();
|
||||
lookup.in(int.class);
|
||||
}
|
||||
|
||||
@Test(expectedExceptions = IllegalArgumentException.class)
|
||||
public void voidLookupClass() {
|
||||
Lookup lookup = MethodHandles.publicLookup();
|
||||
lookup.in(void.class);
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user