- All Implemented Interfaces:
Serializable,BshClassManager.Listener,NameSource
Variables are maintained internally in the normal fashion to support meta-information (such as variable type and visibility modifiers), but exported and imported in a synchronized way. Variables are exported each time they are written by BeanShell. Imported variables from the map appear in the BeanShell namespace as untyped variables with no modifiers and shadow any previously defined variables in the scope.
Note: this class is inherentely dependent on Java 1.2, however it is not used directly by the core as other than type NameSpace, so no dependency is introduced.
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.gjt.sp.jedit.bsh.NameSource
NameSource.Listener -
Field Summary
Fields inherited from class org.gjt.sp.jedit.bsh.NameSpace
importedClasses, JAVACODE -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidclear()Clear all variables, methods, and imports from this namespace and clear all values from the external map (via Map clear()).protected voidgetAllNamesAux(Vector vec) Helper for implementing NameSourceVariable[]getMap()Get the map view of this namespace.Get the bsh method matching the specified signature declared in this name space or a parent.protected VariablegetVariableImpl(String name, boolean recurse) Locate a variable and return the Variable object with optional recursion through parent name spaces.String[]Get the names of variables defined in this namespace.protected voidputExternalMap(String name, Object value) Place an unwrapped value in the external map.voidSet the external Map which to which this namespace synchronizes.voidNote: this is primarily for internal use.voidsetTypedVariable(String name, Class type, Object value, Modifiers modifiers) Declare a variable in the local scope and set its initial value.voidunsetVariable(String name) Remove the variable from the namespace.Methods inherited from class org.gjt.sp.jedit.bsh.NameSpace
addCommandPath, addNameSourceListener, classLoaderChanged, doSuperImport, get, getAllNames, getClass, getClassManager, getCommand, getCommand, getGlobal, getImportedMethod, getImportedVar, getInvocationLine, getInvocationText, getMethod, getMethodNames, getMethods, getName, getParent, getSuper, getVariable, getVariable, identifierToClass, importClass, importCommands, importObject, importPackage, importStatic, invokeMethod, invokeMethod, loadDefaultImports, nameSpaceChanged, prune, removeCommandPath, setName, setParent, setTypedVariable, setVariable, setVariable, toString, unwrapVariable
-
Constructor Details
-
ExternalNameSpace
public ExternalNameSpace() -
ExternalNameSpace
-
-
Method Details
-
getMap
Get the map view of this namespace. -
setMap
Set the external Map which to which this namespace synchronizes. The previous external map is detached from this namespace. Previous map values are retained in the external map, but are removed from the BeanShell namespace. -
unsetVariable
Description copied from class:NameSpaceRemove the variable from the namespace.- Overrides:
unsetVariablein classNameSpace
-
getVariableNames
Description copied from class:NameSpaceGet the names of variables defined in this namespace. (This does not show variables in parent namespaces).- Overrides:
getVariableNamesin classNameSpace
-
getVariableImpl
Description copied from class:NameSpaceLocate a variable and return the Variable object with optional recursion through parent name spaces.If this namespace is static, return only static variables.
- Overrides:
getVariableImplin classNameSpace- Returns:
- the Variable value or null if it is not defined
- Throws:
UtilEvalError
-
getDeclaredVariables
- Overrides:
getDeclaredVariablesin classNameSpace
-
setTypedVariable
public void setTypedVariable(String name, Class type, Object value, Modifiers modifiers) throws UtilEvalError Description copied from class:NameSpaceDeclare a variable in the local scope and set its initial value. Value may be null to indicate that we would like the default value for the variable type. (e.g. 0 for integer types, null for object types). An existing typed variable may only be set to the same type. If an untyped variable of the same name exists it will be overridden with the new typed var. The set will perform a Types.getAssignableForm() on the value if necessary.Note: this method is primarily intended for use internally. If you use this method outside of the bsh package and wish to set variables with primitive values you will have to wrap them using bsh.Primitive.
- Overrides:
setTypedVariablein classNameSpace- Parameters:
value- If value is null, you'll get the default value for the typemodifiers- may be null- Throws:
UtilEvalError- See Also:
-
setMethod
Description copied from class:NameSpaceNote: this is primarily for internal use.- Overrides:
setMethodin classNameSpace- Throws:
UtilEvalError- See Also:
-
getMethod
Description copied from class:NameSpaceGet the bsh method matching the specified signature declared in this name space or a parent.Note: this method is primarily intended for use internally. If you use this method outside of the bsh package you will have to be familiar with BeanShell's use of the Primitive wrapper class.
- Overrides:
getMethodin classNameSpace- Parameters:
declaredOnly- if true then only methods declared directly in this namespace will be found and no inherited or imported methods will be visible.- Returns:
- the BshMethod or null if not found
- Throws:
UtilEvalError- See Also:
-
getAllNamesAux
Description copied from class:NameSpaceHelper for implementing NameSource- Overrides:
getAllNamesAuxin classNameSpace
-
clear
public void clear()Clear all variables, methods, and imports from this namespace and clear all values from the external map (via Map clear()). -
putExternalMap
Place an unwrapped value in the external map. BeanShell primitive types are represented by their object wrappers, so it is not possible to differentiate between wrapper types and primitive types via the external Map.
-