8148148: Remove pluggable CodeStore API

Reviewed-by: attila, mhaupt
This commit is contained in:
Hannes Wallnöfer 2016-03-07 13:28:51 +01:00
parent b90601cb8f
commit eee630daaa

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2010, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -34,13 +34,10 @@ import java.io.IOException;
import java.io.ObjectInputStream; import java.io.ObjectInputStream;
import java.io.ObjectOutputStream; import java.io.ObjectOutputStream;
import java.io.Serializable; import java.io.Serializable;
import java.security.AccessControlException;
import java.security.AccessController; import java.security.AccessController;
import java.security.PrivilegedActionException; import java.security.PrivilegedActionException;
import java.security.PrivilegedExceptionAction; import java.security.PrivilegedExceptionAction;
import java.util.Iterator;
import java.util.Map; import java.util.Map;
import java.util.ServiceLoader;
import jdk.nashorn.internal.codegen.OptimisticTypesPersistence; import jdk.nashorn.internal.codegen.OptimisticTypesPersistence;
import jdk.nashorn.internal.codegen.types.Type; import jdk.nashorn.internal.codegen.types.Type;
import jdk.nashorn.internal.runtime.logging.DebugLogger; import jdk.nashorn.internal.runtime.logging.DebugLogger;
@ -54,11 +51,6 @@ import jdk.nashorn.internal.runtime.options.Options;
@Logger(name="codestore") @Logger(name="codestore")
public abstract class CodeStore implements Loggable { public abstract class CodeStore implements Loggable {
/**
* Permission needed to provide a CodeStore instance via ServiceLoader.
*/
public final static String NASHORN_PROVIDE_CODE_STORE = "nashorn.provideCodeStore";
private DebugLogger log; private DebugLogger log;
/** /**
@ -85,23 +77,6 @@ public abstract class CodeStore implements Loggable {
* @return The instance, or null if code store could not be created * @return The instance, or null if code store could not be created
*/ */
public static CodeStore newCodeStore(final Context context) { public static CodeStore newCodeStore(final Context context) {
final Class<CodeStore> baseClass = CodeStore.class;
try {
// security check first
final SecurityManager sm = System.getSecurityManager();
if (sm != null) {
sm.checkPermission(new RuntimePermission(NASHORN_PROVIDE_CODE_STORE));
}
final ServiceLoader<CodeStore> services = ServiceLoader.load(baseClass);
final Iterator<CodeStore> iterator = services.iterator();
if (iterator.hasNext()) {
final CodeStore store = iterator.next();
store.initLogger(context).info("using code store provider ", store.getClass().getCanonicalName());
return store;
}
} catch (final AccessControlException e) {
context.getLogger(CodeStore.class).warning("failed to load code store provider ", e);
}
try { try {
final CodeStore store = new DirectoryCodeStore(context); final CodeStore store = new DirectoryCodeStore(context);
store.initLogger(context); store.initLogger(context);