Class JavaEngine
- All Implemented Interfaces:
PropertyChangeListener,EventListener,BSFEngine
The Java code must be written script-style -- that is, just the body of the function, without class or method headers or footers. The JavaEngine will generate those via a "boilerplate" wrapper:
import java.lang.*;
import java.util.*;
public class $$CLASSNAME$$ {
static public Object BSFJavaEngineEntry(org.apache.bsf.BSFManager bsf) {
// Your code will be placed here
}
}
$$CLASSNAME$$ will be replaced by a generated classname of the form
BSFJava*, and the bsf parameter can be used to retrieve application
objects registered with the Bean Scripting Framework.
If you use the placeholder string $$CLASSNAME$$ elsewhere in your script -- including within text strings -- BSFJavaEngine will replace it with the generated name of the class before the Java code is compiled.
Hazards:
NOTE that it is your responsibility to convert the code into an acceptable Java string. If you're invoking the JavaEngine directly (as in the JSPLikeInJava example) that means \"quoting\" characters that would otherwise cause trouble.
ALSO NOTE that it is your responsibility to return an object, or null in lieu thereof!
Since the code has to be compiled to a Java classfile, invoking it involves a fair amount of computation to load and execute the compiler. We are currently making an attempt to manage that by caching the class after it has been loaded, but the indexing is fairly primitive. It has been suggested that the Bean Scripting Framework may want to support preload-and-name-script and execute-preloaded-script-by-name options to provide better control over when and how much overhead occurs.
- Author:
- Joe Kesselman, Rony G. Flatscher (added BSF_Log[Factory] to allow BSF to run without org.apache.commons.logging present)
-
Field Summary
Fields inherited from class org.apache.bsf.util.BSFEngineImpl
classLoader, classPath, declaredBeans, lang, mgr, tempDir -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionThis is used by an application to call into the scripting engine to make a function/method call.voidcompileScript(String source, int lineNo, int columnNo, Object script, CodeBuffer cb) Default impl of compileScript - generates code that'll create a new manager, and execute the script.This is used by an application to evaluate a string containing some expression.voidinitialize(BSFManager mgr, String lang, Vector declaredBeans) initialize the engine; called right after construction by the manager.Methods inherited from class org.apache.bsf.util.BSFEngineImpl
apply, compileApply, compileExpr, declareBean, exec, iexec, propertyChange, terminate, undeclareBean
-
Constructor Details
-
JavaEngine
public JavaEngine()Constructor.
-
-
Method Details
-
call
Description copied from interface:BSFEngineThis is used by an application to call into the scripting engine to make a function/method call. The "object" argument is the object whose method is to be called, if that applies. For non-OO languages, this is typically ignored and should be given as null. For pretend-OO languages such as VB, this would be the (String) name of the object. The arguments are given in the args array.- Parameters:
object- object on which to make the callmethod- name of the method / procedure to callargs- the arguments to be given to the procedure- Throws:
BSFException- if anything goes wrong while eval'ing a BSFException is thrown. The reason indicates the problem.
-
compileScript
public void compileScript(String source, int lineNo, int columnNo, Object script, CodeBuffer cb) throws BSFException Description copied from class:BSFEngineImplDefault impl of compileScript - generates code that'll create a new manager, and execute the script.- Specified by:
compileScriptin interfaceBSFEngine- Overrides:
compileScriptin classBSFEngineImpl- Parameters:
source- (context info) the source of this script (e.g., filename)lineNo- (context info) the line number in source for scriptcolumnNo- (context info) the column number in source for scriptscript- the script to compilecb- the CodeBuffer to compile into- Throws:
BSFException- if anything goes wrong while compiling a BSFException is thrown. The reason indicates the problem.
-
eval
This is used by an application to evaluate a string containing some expression. It should store the "bsf" handle where the script can get to it, for callback purposes.Note that Java compilation imposes serious overhead, but in exchange you get full Java performance once the classes have been created (minus the cache lookup cost).
Nobody knows whether javac is threadsafe. I'm going to serialize access to protect it.
There is no published API for invoking javac as a class. There's a trick that seems to work for Java 1.1.x, but it stopped working in Java 1.2. We will attempt to use it, then if necessary fall back on invoking javac via the command line.
- Parameters:
source- (context info) the source of this expression (e.g., filename)lineNo- (context info) the line number in source for exprcolumnNo- (context info) the column number in source for exproscript- the expression to evaluate- Throws:
BSFException- if anything goes wrong while eval'ing a BSFException is thrown. The reason indicates the problem.
-
initialize
Description copied from class:BSFEngineImplinitialize the engine; called right after construction by the manager. Declared beans are simply kept in a vector and that's it. Subclasses must do whatever they want with it.- Specified by:
initializein interfaceBSFEngine- Overrides:
initializein classBSFEngineImpl- Parameters:
mgr- The BSFManager that's hosting this engine.lang- Language string which this engine is handling.declaredBeans- Vector of BSFDeclaredObject containing beans that should be declared into the language runtime at init time as best as possible.- Throws:
BSFException- if anything goes wrong while init'ing a BSFException is thrown. The reason indicates the problem.
-