Class ContextFactory
- java.lang.Object
- 
- org.mozilla.javascript.ContextFactory
 
- 
- Direct Known Subclasses:
- ShellContextFactory
 
 public class ContextFactory extends java.lang.ObjectFactory class that Rhino runtime uses to create newContextinstances. AContextFactorycan also notify listeners about context creation and release.When the Rhino runtime needs to create new Contextinstance during execution ofContext.enter()orContext, it will callmakeContext()of the current global ContextFactory. SeegetGlobal()andinitGlobal(ContextFactory).It is also possible to use explicit ContextFactory instances for Context creation. This is useful to have a set of independent Rhino runtime instances under single JVM. See call(ContextAction).The following example demonstrates Context customization to terminate scripts running more then 10 seconds and to provide better compatibility with JavaScript code using MSIE-specific features. import org.mozilla.javascript.*; class MyFactory extends ContextFactory { // CustomContextto store execution time. private static class MyContext extends Context { long startTime; } static { // Initialize GlobalFactory with custom factory ContextFactory.initGlobal(new MyFactory()); } // OverridemakeContext()protected Context makeContext() { MyContext cx = new MyContext(); // Make Rhino runtime to call observeInstructionCount // each 10000 bytecode instructions cx.setInstructionObserverThreshold(10000); return cx; } // OverridehasFeature(Context, int)public boolean hasFeature(Context cx, int featureIndex) { // Turn on maximum compatibility with MSIE scripts switch (featureIndex) { caseContext.FEATURE_NON_ECMA_GET_YEAR: return true; caseContext.FEATURE_MEMBER_EXPR_AS_FUNCTION_NAME: return true; caseContext.FEATURE_RESERVED_KEYWORD_AS_IDENTIFIER: return true; caseContext.FEATURE_PARENT_PROTO_PROPERTIES: return false; } return super.hasFeature(cx, featureIndex); } // OverrideobserveInstructionCount(Context, int)protected void observeInstructionCount(Context cx, int instructionCount) { MyContext mcx = (MyContext)cx; long currentTime = System.currentTimeMillis(); if (currentTime - mcx.startTime > 10*1000) { // More then 10 seconds from Context creation time: // it is time to stop the script. // Throw Error instance to ensure that script will never // get control back through catch or finally. throw new Error(); } } // OverridedoTopCall(Callable, Context, Scriptable, Scriptable, Object[])protected Object doTopCall(Callable callable, Context cx, Scriptable scope, Scriptable thisObj, Object[] args) { MyContext mcx = (MyContext)cx; mcx.startTime = System.currentTimeMillis(); return super.doTopCall(callable, cx, scope, thisObj, args); } }
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static interfaceContextFactory.GlobalSetterstatic interfaceContextFactory.ListenerListener ofContextcreation and release events.
 - 
Constructor SummaryConstructors Constructor Description ContextFactory()
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddListener(ContextFactory.Listener listener)<T> Tcall(ContextAction<T> action)CallContextAction.run(Context cx)using theContextinstance associated with the current thread.protected voidcheckNotSealed()protected GeneratedClassLoadercreateClassLoader(java.lang.ClassLoader parent)Create class loader for generated classes.protected java.lang.ObjectdoTopCall(Callable callable, Context cx, Scriptable scope, Scriptable thisObj, java.lang.Object[] args)Execute top call to script or function.Contextenter()Deprecated.useenterContext()insteadContextenterContext()Get a context associated with the current thread, creating one if need be.ContextenterContext(Context cx)Get a Context associated with the current thread, using the given Context if need be.voidexit()Deprecated.UseContext.exit()instead.java.lang.ClassLoadergetApplicationClassLoader()Get ClassLoader to use when searching for Java classes.protected XMLLib.FactorygetE4xImplementationFactory()Provides a defaultXMLLib.Factoryto be used by theContextinstances produced by this factory.static ContextFactorygetGlobal()Get global ContextFactory.static ContextFactory.GlobalSettergetGlobalSetter()static booleanhasExplicitGlobal()Check if global factory was set.protected booleanhasFeature(Context cx, int featureIndex)Implementation ofContext.hasFeature(int featureIndex).voidinitApplicationClassLoader(java.lang.ClassLoader loader)Set explicit class loader to use when searching for Java classes.static voidinitGlobal(ContextFactory factory)Set global ContextFactory.booleanisSealed()Checks if this is a sealed ContextFactory.protected ContextmakeContext()Create newContextinstance to be associated with the current thread.protected voidobserveInstructionCount(Context cx, int instructionCount)Implementation ofContext.observeInstructionCount(int instructionCount).protected voidonContextCreated(Context cx)protected voidonContextReleased(Context cx)voidremoveListener(ContextFactory.Listener listener)voidseal()Seal this ContextFactory so any attempt to modify it like to add or remove its listeners will throw an exception.
 
- 
- 
- 
Method Detail- 
getGlobalpublic static ContextFactory getGlobal() Get global ContextFactory.- See Also:
- hasExplicitGlobal(),- initGlobal(ContextFactory)
 
 - 
hasExplicitGlobalpublic static boolean hasExplicitGlobal() Check if global factory was set. Return true to indicate thatinitGlobal(ContextFactory)was already called and false to indicate that the global factory was not explicitly set.- See Also:
- getGlobal(),- initGlobal(ContextFactory)
 
 - 
initGlobalpublic static void initGlobal(ContextFactory factory) Set global ContextFactory. The method can only be called once.- See Also:
- getGlobal(),- hasExplicitGlobal()
 
 - 
getGlobalSetterpublic static ContextFactory.GlobalSetter getGlobalSetter() 
 - 
makeContextprotected Context makeContext() Create newContextinstance to be associated with the current thread. This is a callback method used by Rhino to createContextinstance when it is necessary to associate one with the current execution thread.makeContext()is allowed to callContext.seal(Object)on the result to preventContextchanges by hostile scripts or applets.
 - 
hasFeatureprotected boolean hasFeature(Context cx, int featureIndex) Implementation ofContext.hasFeature(int featureIndex). This can be used to customizeContextwithout introducing additional subclasses.
 - 
getE4xImplementationFactoryprotected XMLLib.Factory getE4xImplementationFactory() Provides a defaultXMLLib.Factoryto be used by theContextinstances produced by this factory. SeeContext.getE4xImplementationFactory()for details.May return null, in which case E4X functionality is not supported in Rhino. The default implementation now prefers the DOM3 E4X implementation. 
 - 
createClassLoaderprotected GeneratedClassLoader createClassLoader(java.lang.ClassLoader parent) Create class loader for generated classes. This method creates an instance of the default implementation ofGeneratedClassLoader. Rhino uses this interface to load generated JVM classes when noSecurityControlleris installed. Application can override the method to provide custom class loading.
 - 
getApplicationClassLoaderpublic final java.lang.ClassLoader getApplicationClassLoader() Get ClassLoader to use when searching for Java classes. Unless it was explicitly initialized withinitApplicationClassLoader(ClassLoader)the method returns null to indicate that Thread.getContextClassLoader() should be used.
 - 
initApplicationClassLoaderpublic final void initApplicationClassLoader(java.lang.ClassLoader loader) Set explicit class loader to use when searching for Java classes.- See Also:
- getApplicationClassLoader()
 
 - 
doTopCallprotected java.lang.Object doTopCall(Callable callable, Context cx, Scriptable scope, Scriptable thisObj, java.lang.Object[] args) Execute top call to script or function. When the runtime is about to execute a script or function that will create the first stack frame with scriptable code, it calls this method to perform the real call. In this way execution of any script happens inside this function.
 - 
observeInstructionCountprotected void observeInstructionCount(Context cx, int instructionCount) Implementation ofContext.observeInstructionCount(int instructionCount). This can be used to customizeContextwithout introducing additional subclasses.
 - 
onContextCreatedprotected void onContextCreated(Context cx) 
 - 
onContextReleasedprotected void onContextReleased(Context cx) 
 - 
addListenerpublic final void addListener(ContextFactory.Listener listener) 
 - 
removeListenerpublic final void removeListener(ContextFactory.Listener listener) 
 - 
isSealedpublic final boolean isSealed() Checks if this is a sealed ContextFactory.- See Also:
- seal()
 
 - 
sealpublic final void seal() Seal this ContextFactory so any attempt to modify it like to add or remove its listeners will throw an exception.- See Also:
- isSealed()
 
 - 
checkNotSealedprotected final void checkNotSealed() 
 - 
callpublic final <T> T call(ContextAction<T> action) CallContextAction.run(Context cx)using theContextinstance associated with the current thread. If no Context is associated with the thread, thenmakeContext()will be called to construct new Context instance. The instance will be temporary associated with the thread during call toContextAction.run(Context).
 - 
enterContextpublic Context enterContext() Get a context associated with the current thread, creating one if need be. The Context stores the execution state of the JavaScript engine, so it is required that the context be entered before execution may begin. Once a thread has entered a Context, then getCurrentContext() may be called to find the context that is associated with the current thread.Calling enterContext()will return either the Context currently associated with the thread, or will create a new context and associate it with the current thread. Each call toenterContext()must have a matching call toContext.exit().Context cx = contextFactory.enterContext(); try { ... cx.evaluateString(...); } finally { Context.exit(); }Instead of usingenterContext(),exit()pair consider usingcall(ContextAction)which guarantees proper association of Context instances with the current thread. With this method the above example becomes:ContextFactory.call(new ContextAction() { public Object run(Context cx) { ... cx.evaluateString(...); return null; } });- Returns:
- a Context associated with the current thread
- See Also:
- Context.getCurrentContext(),- Context.exit(),- call(ContextAction)
 
 - 
enter@Deprecated public final Context enter() Deprecated.useenterContext()instead- Returns:
- a Context associated with the current thread
 
 - 
exit@Deprecated public final void exit() Deprecated.UseContext.exit()instead.
 - 
enterContextpublic final Context enterContext(Context cx) Get a Context associated with the current thread, using the given Context if need be.The same as enterContext()except thatcxis associated with the current thread and returned if the current thread has no associated context andcxis not associated with any other thread.- Parameters:
- cx- a Context to associate with the thread if possible
- Returns:
- a Context associated with the current thread
- Throws:
- java.lang.IllegalStateException- if- cxis already associated with a different thread
- See Also:
- enterContext(),- call(ContextAction)
 
 
- 
 
-