mirror of https://github.com/apache/lucene.git
LUCENE-6921: Remove not necessary doPrivilegedCheck and update docs.
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1718082 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
9d4c415450
commit
889bf7f953
|
@ -23,8 +23,6 @@ import java.io.BufferedReader;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.security.AccessController;
|
|
||||||
import java.security.PrivilegedAction;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
|
@ -64,26 +62,22 @@ public final class SPIClassIterator<S> implements Iterator<Class<? extends S>> {
|
||||||
* Utility method to check if some class loader is a (grand-)parent of or the same as another one.
|
* Utility method to check if some class loader is a (grand-)parent of or the same as another one.
|
||||||
* This means the child will be able to load all classes from the parent, too.
|
* This means the child will be able to load all classes from the parent, too.
|
||||||
* <p>
|
* <p>
|
||||||
* If Lucene's codebase doesn't have enough permissions to do the check, {@code false} is returned.
|
* If caller's codesource doesn't have enough permissions to do the check, {@code false} is returned
|
||||||
|
* (this is fine, because if we get a {@code SecurityException} it is for sure no parent).
|
||||||
*/
|
*/
|
||||||
public static boolean isParentClassLoader(final ClassLoader parent, final ClassLoader child) {
|
public static boolean isParentClassLoader(final ClassLoader parent, final ClassLoader child) {
|
||||||
if (parent == child) {
|
try {
|
||||||
return true; // don't try to use AccessController for performance
|
ClassLoader cl = child;
|
||||||
}
|
while (cl != null) {
|
||||||
return AccessController.doPrivileged((PrivilegedAction<Boolean>) () -> {
|
if (cl == parent) {
|
||||||
try {
|
return true;
|
||||||
ClassLoader cl = child;
|
|
||||||
while (cl != null) {
|
|
||||||
if (cl == parent) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
cl = cl.getParent();
|
|
||||||
}
|
}
|
||||||
return false;
|
cl = cl.getParent();
|
||||||
} catch (SecurityException se) {
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
});
|
return false;
|
||||||
|
} catch (SecurityException se) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private SPIClassIterator(Class<S> clazz, ClassLoader loader) {
|
private SPIClassIterator(Class<S> clazz, ClassLoader loader) {
|
||||||
|
|
Loading…
Reference in New Issue