bsh

Class BshClassManager

public class BshClassManager extends Object

BshClassManager manages all classloading in BeanShell. It also supports a dynamically loaded extension (bsh.classpath package) which allows classpath extension and class file reloading. Currently the extension relies on 1.2 for BshClassLoader and weak references. See http://www.beanshell.org/manual/classloading.html for details on the bsh classloader architecture.

Bsh has a multi-tiered class loading architecture. No class loader is used unless/until the classpath is modified or a class is reloaded.

Nested Class Summary
static interfaceBshClassManager.Listener
Field Summary
protected HashtableabsoluteClassCache
Global cache for things we know are classes.
protected HashtableabsoluteNonClasses
Global cache for things we know are *not* classes.
protected HashtableresolvedObjectMethods
Caches for resolved object and static methods.
protected HashtableresolvedStaticMethods
Method Summary
voidaddClassPath(URL path)
voidaddListener(BshClassManager.Listener l)
voidcacheClassInfo(String name, Class value)
Cache info about whether name is a class or not.
voidcacheResolvedMethod(Class clas, Object[] args, Method method)
Cache a resolved (possibly overloaded) method based on the argument types used to invoke it, subject to classloader change.
booleanclassExists(String name)
ClassclassForName(String name)
Load the specified class by name, taking into account added classpath and reloaded classes, etc.
protected voidclassLoaderChanged()
protected voidclearCaches()
Clear the caches in BshClassManager
protected static UtilEvalErrorcmUnavailable()
static BshClassManagercreateClassManager()
Create a new instance of the class manager.
protected voiddoSuperImport()
Support for "import *;" Hide details in here as opposed to NameSpace.
voiddump(PrintWriter pw)
protected StringgetClassNameByUnqName(String name)
Return the name or null if none is found, Throw an ClassPathException containing detail if name is ambigous.
MethodgetResolvedMethod(Class clas, String methodName, Object[] args, boolean onlyStatic)
Return a previously cached resolved method.
URLgetResource(String path)
Get a resource URL using the BeanShell classpath
InputStreamgetResourceAsStream(String path)
Get a resource stream using the BeanShell classpath
protected booleanhasSuperImport()
A "super import" ("import *") operation has been performed.
protected static ErrornoClassDefFound(String className, Error e)
Annotate the NoClassDefFoundError with some info about the class we were trying to load.
ClassplainClassForName(String name)
Perform a plain Class.forName() or call the externally provided classloader.
voidreloadAllClasses()
Overlay the entire path with a new class loader.
voidreloadClasses(String[] classNames)
Reloading classes means creating a new classloader and using it whenever we are asked for classes in the appropriate space.
voidreloadPackage(String pack)
Reload all classes in the specified package: e.g.
voidremoveListener(BshClassManager.Listener l)
voidreset()
Clear all loaders and start over.
voidsetClassLoader(ClassLoader externalCL)
Set an external class loader.
voidsetClassPath(URL[] cp)
Set a new base classpath and create a new base classloader.

Field Detail

absoluteClassCache

protected transient Hashtable absoluteClassCache
Global cache for things we know are classes. Note: these should probably be re-implemented with Soft references. (as opposed to strong or Weak)

absoluteNonClasses

protected transient Hashtable absoluteNonClasses
Global cache for things we know are *not* classes. Note: these should probably be re-implemented with Soft references. (as opposed to strong or Weak)

resolvedObjectMethods

protected transient Hashtable resolvedObjectMethods
Caches for resolved object and static methods. We keep these maps separate to support fast lookup in the general case where the method may be either.

resolvedStaticMethods

protected transient Hashtable resolvedStaticMethods

Method Detail

addClassPath

public void addClassPath(URL path)

addListener

public void addListener(BshClassManager.Listener l)

cacheClassInfo

public void cacheClassInfo(String name, Class value)
Cache info about whether name is a class or not.

Parameters: value if value is non-null, cache the class if value is null, set the flag that it is *not* a class to speed later resolution

cacheResolvedMethod

public void cacheResolvedMethod(Class clas, Object[] args, Method method)
Cache a resolved (possibly overloaded) method based on the argument types used to invoke it, subject to classloader change. Static and Object methods are cached separately to support fast lookup in the general case where either will do.

classExists

public boolean classExists(String name)

classForName

public Class classForName(String name)
Load the specified class by name, taking into account added classpath and reloaded classes, etc.

Returns: the class or null

classLoaderChanged

protected void classLoaderChanged()

clearCaches

protected void clearCaches()
Clear the caches in BshClassManager

See Also: public void #reset() for external usage

cmUnavailable

protected static UtilEvalError cmUnavailable()

createClassManager

public static BshClassManager createClassManager()
Create a new instance of the class manager. Class manager instnaces are now associated with the interpreter.

See Also: bsh.Interpreter.getClassManager() bsh.Interpreter.setClassLoader( ClassLoader )

doSuperImport

protected void doSuperImport()
Support for "import *;" Hide details in here as opposed to NameSpace.

dump

public void dump(PrintWriter pw)

getClassNameByUnqName

protected String getClassNameByUnqName(String name)
Return the name or null if none is found, Throw an ClassPathException containing detail if name is ambigous.

getResolvedMethod

public Method getResolvedMethod(Class clas, String methodName, Object[] args, boolean onlyStatic)
Return a previously cached resolved method.

Parameters: onlyStatic specifies that only a static method may be returned.

Returns: the Method or null

getResource

public URL getResource(String path)
Get a resource URL using the BeanShell classpath

Parameters: path should be an absolute path

getResourceAsStream

public InputStream getResourceAsStream(String path)
Get a resource stream using the BeanShell classpath

Parameters: path should be an absolute path

hasSuperImport

protected boolean hasSuperImport()
A "super import" ("import *") operation has been performed.

noClassDefFound

protected static Error noClassDefFound(String className, Error e)
Annotate the NoClassDefFoundError with some info about the class we were trying to load.

plainClassForName

public Class plainClassForName(String name)
Perform a plain Class.forName() or call the externally provided classloader. If a BshClassManager implementation is loaded the call will be delegated to it, to allow for additional hooks.

This simply wraps that bottom level class lookup call and provides a central point for monitoring and handling certain Java version dependent bugs, etc.

Returns: the class

See Also: BshClassManager

reloadAllClasses

public void reloadAllClasses()
Overlay the entire path with a new class loader. Set the base path to the user path + base path. No point in including the boot class path (can't reload thos).

reloadClasses

public void reloadClasses(String[] classNames)
Reloading classes means creating a new classloader and using it whenever we are asked for classes in the appropriate space. For this we use a DiscreteFilesClassLoader

reloadPackage

public void reloadPackage(String pack)
Reload all classes in the specified package: e.g. "com.sun.tools" The special package name "" can be used to refer to unpackaged classes.

removeListener

public void removeListener(BshClassManager.Listener l)

reset

public void reset()
Clear all loaders and start over. No class loading.

setClassLoader

public void setClassLoader(ClassLoader externalCL)
Set an external class loader. BeanShell will use this at the same point it would otherwise use the plain Class.forName(). i.e. if no explicit classpath management is done from the script (addClassPath(), setClassPath(), reloadClasses()) then BeanShell will only use the supplied classloader. If additional classpath management is done then BeanShell will perform that in addition to the supplied external classloader. However BeanShell is not currently able to reload classes supplied through the external classloader.

setClassPath

public void setClassPath(URL[] cp)
Set a new base classpath and create a new base classloader. This means all types change.
B) 2000 pat@pat.net :-)