Package org.apache.tools.ant.util
Class ScriptRunnerBase
- java.lang.Object
- 
- org.apache.tools.ant.util.ScriptRunnerBase
 
- 
- Direct Known Subclasses:
- JavaxScriptRunner,- ScriptRunner
 
 public abstract class ScriptRunnerBase extends java.lang.ObjectThis is a common abstract base case for script runners. These classes need to implement executeScript, evaluateScript and supportsLanguage.- Since:
- Ant 1.7.0
 
- 
- 
Constructor SummaryConstructors Constructor Description ScriptRunnerBase()
 - 
Method SummaryModifier and Type Method Description voidaddBean(java.lang.String key, java.lang.Object bean)Add a single object into the script context.voidaddBeans(java.util.Map<java.lang.String,?> dictionary)Add a list of named objects to the list to be exported to the scriptvoidaddText(java.lang.String text)Set the script text.voidbindToComponent(ProjectComponent component)Bind the runner to a project component.voidbindToComponentMinimum(ProjectComponent component)Bind the runner to a project component.protected voidcheckLanguage()Check if the language attribute is set.voidclearScript()Clear the current script text content.abstract java.lang.ObjectevaluateScript(java.lang.String execName)Evaluate the script.abstract voidexecuteScript(java.lang.String execName)Do the work.protected java.util.Map<java.lang.String,java.lang.Object>getBeans()Get the beans used for the script.booleangetCompiled()Get the compiled attribute.booleangetKeepEngine()Get the keep engine attribute.java.lang.StringgetLanguage()Get the script languageabstract java.lang.StringgetManagerName()Get the name of the manager prefix used for this scriptrunner.ProjectgetProject()Get the project for this runner.java.lang.StringgetScript()Get the current script text content.protected java.lang.ClassLoadergetScriptClassLoader()Get the classloader used to load the script engine.voidloadResource(Resource sourceResource)Add a resource to the source list.voidloadResources(ResourceCollection collection)Add all resources in a resource collection to the source list.protected java.lang.ClassLoaderreplaceContextLoader()Replace the current context classloader with the script context classloader.protected voidrestoreContextLoader(java.lang.ClassLoader origLoader)Restore the context loader with the original context classloader.voidsetCompiled(boolean compiled)Whether to use script compilation if available.voidsetEncoding(java.lang.String encoding)Set encoding of the script from an external file; optional.voidsetKeepEngine(boolean keepEngine)Whether to keep the script engine between calls.voidsetLanguage(java.lang.String language)Defines the language (required).voidsetProject(Project project)Set the project for this runner.voidsetScriptClassLoader(java.lang.ClassLoader classLoader)Set the script classloader.voidsetSrc(java.io.File file)Load the script from an external file; optional.abstract booleansupportsLanguage()Check if a script engine can be created for this language.
 
- 
- 
- 
Method Detail- 
addBeanspublic void addBeans(java.util.Map<java.lang.String,?> dictionary) Add a list of named objects to the list to be exported to the script- Parameters:
- dictionary- a map of objects to be placed into the script context indexed by String names.
 
 - 
addBeanpublic void addBean(java.lang.String key, java.lang.Object bean)Add a single object into the script context.- Parameters:
- key- the name in the context this object is to stored under.
- bean- the object to be stored in the script context.
 
 - 
getBeansprotected java.util.Map<java.lang.String,java.lang.Object> getBeans() Get the beans used for the script.- Returns:
- the map of beans.
 
 - 
executeScriptpublic abstract void executeScript(java.lang.String execName) Do the work.- Parameters:
- execName- the name that will be passed to BSF for this script execution.
 
 - 
evaluateScriptpublic abstract java.lang.Object evaluateScript(java.lang.String execName) Evaluate the script.- Parameters:
- execName- the name that will be passed to the scripting engine for this script execution.
- Returns:
- the result of evaluating the script.
 
 - 
supportsLanguagepublic abstract boolean supportsLanguage() Check if a script engine can be created for this language.- Returns:
- true if a script engine can be created, false otherwise.
 
 - 
getManagerNamepublic abstract java.lang.String getManagerName() Get the name of the manager prefix used for this scriptrunner.- Returns:
- the prefix string.
 
 - 
setLanguagepublic void setLanguage(java.lang.String language) Defines the language (required).- Parameters:
- language- the scripting language name for the script.
 
 - 
getLanguagepublic java.lang.String getLanguage() Get the script language- Returns:
- the script language
 
 - 
setScriptClassLoaderpublic void setScriptClassLoader(java.lang.ClassLoader classLoader) Set the script classloader.- Parameters:
- classLoader- the classloader to use.
 
 - 
getScriptClassLoaderprotected java.lang.ClassLoader getScriptClassLoader() Get the classloader used to load the script engine.- Returns:
- the classloader.
 
 - 
setKeepEnginepublic void setKeepEngine(boolean keepEngine) Whether to keep the script engine between calls.- Parameters:
- keepEngine- if true, keep the engine.
 
 - 
getKeepEnginepublic boolean getKeepEngine() Get the keep engine attribute.- Returns:
- the attribute.
 
 - 
setCompiledpublic final void setCompiled(boolean compiled) Whether to use script compilation if available.- Parameters:
- compiled- if true, compile the script if possible.
- Since:
- Ant 1.10.2
 
 - 
getCompiledpublic final boolean getCompiled() Get the compiled attribute.- Returns:
- the attribute.
- Since:
- Ant 1.10.2
 
 - 
setEncodingpublic void setEncoding(java.lang.String encoding) Set encoding of the script from an external file; optional.- Parameters:
- encoding- encoding of the external file containing the script source.
- Since:
- Ant 1.10.2
 
 - 
setSrcpublic void setSrc(java.io.File file) Load the script from an external file; optional.- Parameters:
- file- the file containing the script source.
 
 - 
loadResourcepublic void loadResource(Resource sourceResource) Add a resource to the source list.- Parameters:
- sourceResource- the resource to load
- Throws:
- BuildException- if the resource cannot be read
- Since:
- Ant 1.7.1
 
 - 
loadResourcespublic void loadResources(ResourceCollection collection) Add all resources in a resource collection to the source list.- Parameters:
- collection- the resource to load
- Throws:
- BuildException- if a resource cannot be read
- Since:
- Ant 1.7.1
 
 - 
addTextpublic void addText(java.lang.String text) Set the script text. Properties in the text are not expanded!- Parameters:
- text- a component of the script text to be added.
 
 - 
getScriptpublic java.lang.String getScript() Get the current script text content.- Returns:
- the script text.
 
 - 
clearScriptpublic void clearScript() Clear the current script text content.
 - 
setProjectpublic void setProject(Project project) Set the project for this runner.- Parameters:
- project- the project.
 
 - 
getProjectpublic Project getProject() Get the project for this runner.- Returns:
- the project.
 
 - 
bindToComponentpublic void bindToComponent(ProjectComponent component) Bind the runner to a project component. Properties, targets and references are all added as beans; project is bound to project, and self to the component.- Parameters:
- component- to become- self
 
 - 
bindToComponentMinimumpublic void bindToComponentMinimum(ProjectComponent component) Bind the runner to a project component. The project and self are the only beans set.- Parameters:
- component- to become- self
 
 - 
checkLanguageprotected void checkLanguage() Check if the language attribute is set.- Throws:
- BuildException- if it is not.
 
 - 
replaceContextLoaderprotected java.lang.ClassLoader replaceContextLoader() Replace the current context classloader with the script context classloader.- Returns:
- the current context classloader.
 
 - 
restoreContextLoaderprotected void restoreContextLoader(java.lang.ClassLoader origLoader) Restore the context loader with the original context classloader. script context loader.- Parameters:
- origLoader- the original context classloader.
 
 
- 
 
-