blob: eb4a2d3d18fdbd0ddd52cea2ed49e10572ad33fc [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.tinkerpop.gremlin.jsr223;
import javax.script.Bindings;
import java.util.List;
/**
* The {@code ScriptEngineManager} implements a discovery, instantiation and configuration mechanism for
* {@link GremlinScriptEngine} classes and also maintains a collection of key/value pairs storing state shared by all
* engines created by it. This class uses the {@code ServiceProvider} mechanism to enumerate all the
* implementations of <code>GremlinScriptEngineFactory</code>. The <code>ScriptEngineManager</code> provides a method
* to return a list of all these factories as well as utility methods which look up factories on the basis of language
* name, file extension and mime type.
* <p/>
* The {@code Bindings} of key/value pairs, referred to as the "Global Scope" maintained by the manager is available
* to all instances of @code ScriptEngine} created by the {@code GremlinScriptEngineManager}. The values
* in the {@code Bindings} are generally exposed in all scripts.
* <p/>
* This interface is based quite heavily on the workings of the {@code ScriptEngineManager} supplied in the
* {@code javax.script} packages, but adds some additional features that are specific to Gremlin and TinkerPop.
* Unfortunately, it's not easily possible to extend {@code ScriptEngineManager} directly as there certain behaviors
* don't appear to be be straightforward to implement and member variables are all private. It is important to note
* that this interface is designed to provide support for "Gremlin-enabled" {@code ScriptEngine} instances (i.e. those
* that extend from {@link GremlinScriptEngine}) and is not meant to manage just any {@code ScriptEngine} instance
* that may be on the path.
*
* @author Stephen Mallette (http://stephen.genoprime.com)
*/
public interface GremlinScriptEngineManager {
/**
* Stores the specified {@code Bindings} as a global for all {@link GremlinScriptEngine} objects created by it.
*
* @throws IllegalArgumentException if bindings is null.
*/
public void setBindings(final Bindings bindings);
/**
* Gets the bindings of the {@code Bindings} in global scope.
*/
public Bindings getBindings();
/**
* Sets the specified key/value pair in the global scope. The key may not be null or empty.
*
* @throws IllegalArgumentException if key is null or empty.
*/
public void put(final String key, final Object value);
/**
* Gets the value for the specified key in the global scope.
*/
public Object get(final String key);
/**
* Looks up and creates a {@link GremlinScriptEngine} for a given name. The algorithm first searches for a
* {@link GremlinScriptEngineFactory} that has been registered as a handler for the specified name using the
* {@link #registerEngineExtension(String, GremlinScriptEngineFactory)} method. If one is not found, it searches
* the set of {@code GremlinScriptEngineFactory} instances stored by the constructor for one with the specified
* name. If a {@code ScriptEngineFactory} is found by either method, it is used to create instance of
* {@link GremlinScriptEngine}.
*
* @param shortName The short name of the {@link GremlinScriptEngine} implementation returned by the
* {@link GremlinScriptEngineFactory#getNames} method.
* @return A {@link GremlinScriptEngine} created by the factory located in the search. Returns {@code null}
* if no such factory was found. The global scope of this manager is applied to the newly created
* {@link GremlinScriptEngine}
* @throws NullPointerException if shortName is {@code null}.
*/
public GremlinScriptEngine getEngineByName(final String shortName);
/**
* Look up and create a {@link GremlinScriptEngine} for a given extension. The algorithm
* used by {@link #getEngineByName(String)} is used except that the search starts by looking for a
* {@link GremlinScriptEngineFactory} registered to handle the given extension using
* {@link #registerEngineExtension(String, GremlinScriptEngineFactory)}.
*
* @return The engine to handle scripts with this extension. Returns {@code null} if not found.
* @throws NullPointerException if extension is {@code null}.
*/
public GremlinScriptEngine getEngineByExtension(final String extension);
/**
* Look up and create a {@link GremlinScriptEngine} for a given mime type. The algorithm used by
* {@link #getEngineByName(String)} is used except that the search starts by looking for a
* {@link GremlinScriptEngineFactory} registered to handle the given mime type using
* {@link #registerEngineMimeType(String, GremlinScriptEngineFactory)}.
*
* @param mimeType The given mime type
* @return The engine to handle scripts with this mime type. Returns {@code null} if not found.
* @throws NullPointerException if mime-type is {@code null}.
*/
public GremlinScriptEngine getEngineByMimeType(final String mimeType);
/**
* Returns a list whose elements are instances of all the {@link GremlinScriptEngineFactory} classes
* found by the discovery mechanism.
*
* @return List of all discovered {@link GremlinScriptEngineFactory} objects.
*/
public List<GremlinScriptEngineFactory> getEngineFactories();
/**
* Add {@link GremlinPlugin} instances to customize newly created {@link GremlinScriptEngine} instances.
*/
public void addPlugin(final GremlinPlugin plugin);
/**
* Registers a {@link GremlinScriptEngineFactory} to handle a language name. Overrides any such association found
* using the discovery mechanism.
*
* @param name The name to be associated with the {@link GremlinScriptEngineFactory}
* @param factory The class to associate with the given name.
* @throws NullPointerException if any of the parameters is null.
*/
public void registerEngineName(final String name, final GremlinScriptEngineFactory factory);
/**
* Registers a {@link GremlinScriptEngineFactory} to handle a mime type. Overrides any such association found using
* the discovery mechanism.
*
* @param type The mime type to be associated with the {@link GremlinScriptEngineFactory}.
* @param factory The class to associate with the given mime type.
* @throws NullPointerException if any of the parameters is null.
*/
public void registerEngineMimeType(final String type, final GremlinScriptEngineFactory factory);
/**
* Registers a {@link GremlinScriptEngineFactory} to handle an extension. Overrides any such association found
* using the discovery mechanism.
*
* @param extension The extension type to be associated with the {@link GremlinScriptEngineFactory}
* @param factory The class to associate with the given extension.
* @throws NullPointerException if any of the parameters is null.
*/
public void registerEngineExtension(final String extension, final GremlinScriptEngineFactory factory);
/**
* Get the list of {@link Customizer} instances filtered by the {@code scriptEngineName}.
*/
public List<Customizer> getCustomizers(final String scriptEngineName);
}