public class NativeJavaClass extends NativeJavaObject implements Function
NativeJavaArray,
NativeJavaObject,
NativeJavaPackage,
Serialized FormisAdapter, javaObject, members, parent, prototype, staticTypeNOT_FOUND| Constructor and Description |
|---|
NativeJavaClass() |
NativeJavaClass(Scriptable scope,
java.lang.Class<?> cl) |
NativeJavaClass(Scriptable scope,
java.lang.Class<?> cl,
boolean isAdapter) |
| Modifier and Type | Method and Description |
|---|---|
java.lang.Object |
call(Context cx,
Scriptable scope,
Scriptable thisObj,
java.lang.Object[] args)
Call the function.
|
Scriptable |
construct(Context cx,
Scriptable scope,
java.lang.Object[] args)
Call the function as a constructor.
|
java.lang.Object |
get(java.lang.String name,
Scriptable start)
Get a named property from the object.
|
java.lang.String |
getClassName()
Get the name of the set of objects implemented by this Java class.
|
java.lang.Class<?> |
getClassObject() |
java.lang.Object |
getDefaultValue(java.lang.Class<?> hint)
Get the default value of the object with a given hint.
|
java.lang.Object[] |
getIds()
Get an array of property ids.
|
boolean |
has(java.lang.String name,
Scriptable start)
Indicates whether or not a named property is defined in an object.
|
boolean |
hasInstance(Scriptable value)
Determines if prototype is a wrapped Java object and performs a Java "instanceof".
|
protected void |
initMembers() |
void |
put(java.lang.String name,
Scriptable start,
java.lang.Object value)
Sets a named property in this object.
|
java.lang.String |
toString() |
canConvert, coerceType, createInterfaceAdapter, delete, delete, delete, get, get, getParentScope, getPrototype, has, has, put, put, setParentScope, setPrototype, unwrap, wrapclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitdelete, delete, get, getParentScope, getPrototype, has, put, setParentScope, setPrototypepublic NativeJavaClass()
public NativeJavaClass(Scriptable scope, java.lang.Class<?> cl)
public NativeJavaClass(Scriptable scope, java.lang.Class<?> cl, boolean isAdapter)
protected void initMembers()
initMembers in class NativeJavaObjectpublic java.lang.String getClassName()
ScriptableSee ECMA 8.6.2 and 15.2.4.2.
getClassName in interface ScriptablegetClassName in class NativeJavaObjectpublic boolean has(java.lang.String name,
Scriptable start)
ScriptableDoes not traverse the prototype chain.
The property is specified by a String name as defined for the get method.
has in interface Scriptablehas in class NativeJavaObjectname - the name of the propertystart - the object in which the lookup beganScriptable.get(String, Scriptable),
ScriptableObject.getProperty(Scriptable, String)public java.lang.Object get(java.lang.String name,
Scriptable start)
ScriptableLooks property up in this object and returns the associated value if found. Returns NOT_FOUND if not found. Note that this method is not expected to traverse the prototype chain. This is different from the ECMA [[Get]] operation.
Depending on the property selector, the runtime will call this method or the form of
get that takes an integer:
| JavaScript code | Java code |
|---|---|
| a.b | a.get("b", a) |
| a["foo"] | a.get("foo", a) |
| a[3] | a.get(3, a) |
| a["3"] | a.get(3, a) |
| a[3.0] | a.get(3, a) |
| a["3.0"] | a.get("3.0", a) |
| a[1.1] | a.get("1.1", a) |
| a[-4] | a.get(-4, a) |
The values that may be returned are limited to the following:
get in interface Scriptableget in class NativeJavaObjectname - the name of the propertystart - the object in which the lookup beganContext.getUndefinedValue()public void put(java.lang.String name,
Scriptable start,
java.lang.Object value)
ScriptableThe property is specified by a string name as defined for get.
The possible values that may be passed in are as defined for get. A class
that implements this method may choose to ignore calls to set certain properties, in which
case those properties are effectively read-only.
For properties defined in a prototype chain, use putProperty in
ScriptableObject.
Note that if a property a is defined in the prototype p of an object
o, then evaluating o.a = 23 will cause set to be called on
the prototype p with o as the start parameter. To preserve JavaScript
semantics, it is the Scriptable object's responsibility to modify o.
This design allows properties to be defined in prototypes and implemented in terms of getters and setters of Java values without consuming slots in each instance.
The values that may be set are limited to the following:
Arbitrary Java objects may be wrapped in a Scriptable by first calling
Context.toObject. This allows the property of a JavaScript object to contain an
arbitrary Java object as a value.
Note that has will be called by the runtime first before set is
called to determine in which object the property is defined. Note that this method is not
expected to traverse the prototype chain, which is different from the ECMA [[Put]] operation.
put in interface Scriptableput in class NativeJavaObjectname - the name of the propertystart - the object whose property is being setvalue - value to set the property toScriptable.has(String, Scriptable),
Scriptable.get(String, Scriptable),
ScriptableObject.putProperty(Scriptable, String, Object),
Context.toObject(Object, Scriptable)public java.lang.Object[] getIds()
ScriptableNot all property ids need be returned. Those properties whose ids are not returned are considered non-enumerable.
getIds in interface ScriptablegetIds in class NativeJavaObjectpublic java.lang.Class<?> getClassObject()
public java.lang.Object getDefaultValue(java.lang.Class<?> hint)
ScriptableA hint of null means "no hint".
See ECMA 8.6.2.6.
getDefaultValue in interface ScriptablegetDefaultValue in class NativeJavaObjecthint - the type hintpublic java.lang.Object call(Context cx, Scriptable scope, Scriptable thisObj, java.lang.Object[] args)
FunctionNote that the array of arguments is not guaranteed to have length greater than 0.
call in interface Callablecall in interface Functioncx - the current Context for this threadscope - the scope to execute the function relative to. This is set to the value returned
by getParentScope() except when the function is called from a closure.thisObj - the JavaScript this objectargs - the array of argumentspublic Scriptable construct(Context cx, Scriptable scope, java.lang.Object[] args)
FunctionThis method is invoked by the runtime in order to satisfy a use of the JavaScript
new operator. This method is expected to create a new object and return it.
construct in interface Constructableconstruct in interface Functioncx - the current Context for this threadscope - an enclosing scope of the caller except when the function is called from a
closure.args - the array of argumentspublic java.lang.String toString()
toString in class java.lang.Objectpublic boolean hasInstance(Scriptable value)
hasInstance in interface ScriptablehasInstance in class NativeJavaObjectvalue - The value that appeared on the LHS of the instanceof operator