|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectcom.google.javascript.rhino.jstype.JSType
com.google.javascript.rhino.jstype.ObjectType
com.google.javascript.rhino.jstype.EnumType
public class EnumType
An enum type representing a branded collection of elements. Each element
is referenced by its name, and has an EnumElementType type.
| Nested Class Summary |
|---|
| Nested classes/interfaces inherited from class com.google.javascript.rhino.jstype.JSType |
|---|
JSType.TypePair |
| Field Summary |
|---|
| Fields inherited from class com.google.javascript.rhino.jstype.JSType |
|---|
EMPTY_TYPE_COMPONENT, ENUMDECL, NOT_A_CLASS, NOT_A_TYPE, NOT_ENUMDECL, UNKNOWN_NAME |
| Method Summary | ||
|---|---|---|
boolean |
canBeCalled()
This predicate is used to test whether a given type can be used as the 'function' in a function call. |
|
boolean |
defineElement(String name,
Node definingNode)
Defines a new element on this enum. |
|
FunctionType |
getConstructor()
Gets this object's constructor. |
|
String |
getDisplayName()
Returns a user meaningful label for the JSType instance. |
|
Set<String> |
getElements()
Gets the elements defined on this enum. |
|
EnumElementType |
getElementsType()
Gets the elements' type. |
|
ObjectType |
getImplicitPrototype()
Gets the implicit prototype (a.k.a. |
|
JSDocInfo |
getOwnPropertyJSDocInfo(String propertyName)
Gets the docInfo on the specified property on this type. |
|
Set<String> |
getOwnPropertyNames()
Returns the names of all the properties directly on this type. |
|
int |
getPropertiesCount()
Gets the number of properties of this object. |
|
Node |
getPropertyNode(String propertyName)
Gets the node corresponding to the definition of the specified property. |
|
JSType |
getPropertyType(String propertyName)
Gets the property type of the property whose name is given. |
|
String |
getReferenceName()
Gets the reference name for this object. |
|
boolean |
hasCachedValues()
Returns true if any cached valeus have been set for this type. |
|
boolean |
hasOwnProperty(String propertyName)
Checks whether the property whose name is given is present directly on the object. |
|
boolean |
hasProperty(String propertyName)
Checks whether the property whose name is given is present on the object. |
|
boolean |
hasReferenceName()
Returns true if the object is named. |
|
boolean |
isEnumType()
|
|
boolean |
isNativeObjectType()
Whether this is a built-in object. |
|
boolean |
isPropertyInExterns(String propertyName)
Checks whether the property was defined in the externs. |
|
boolean |
isPropertyTypeDeclared(String property)
Checks whether the property's type is declared. |
|
boolean |
isPropertyTypeInferred(String property)
Checks whether the property's type is inferred. |
|
boolean |
isSubtype(JSType that)
Checks whether this is a subtype of that. |
|
boolean |
matchesNumberContext()
This predicate is used to test whether a given type can appear in a numeric context, such as an operand of a multiply operator. |
|
boolean |
matchesObjectContext()
This predicate is used to test whether a given type can appear in an Object context, such as the expression in a with statement. |
|
boolean |
matchesStringContext()
This predicate is used to test whether a given type can appear in a String context, such as an operand of a string concat (+) operator. |
|
void |
setPropertyJSDocInfo(String propertyName,
JSDocInfo info,
boolean inExterns)
Sets the docInfo for the specified property from the JSDocInfo on its definition. |
|
TernaryValue |
testForEquality(JSType that)
Compares this and that. |
|
String |
toString()
|
|
JSType |
unboxesTo()
Gets the type to which this type unboxes. |
|
|
visit(Visitor<T> visitor)
Visit this type with the given visitor. |
|
| Methods inherited from class com.google.javascript.rhino.jstype.ObjectType |
|---|
cast, clearCachedValues, createDelegateSuffix, defineDeclaredProperty, defineInferredProperty, findPropertyType, getCtorImplementedInterfaces, getIndexType, getJSDocInfo, getNormalizedReferenceName, getParameterType, getPossibleToBooleanOutcomes, getPropertyNames, isObject, isUnknownType, setJSDocInfo |
| Methods inherited from class java.lang.Object |
|---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
| Method Detail |
|---|
public boolean isEnumType()
isEnumType in class JSTypepublic ObjectType getImplicitPrototype()
ObjectType[[Prototype]] property).
public Set<String> getElements()
public boolean defineElement(String name,
Node definingNode)
name - the name of the new elementdefiningNode - the Node that defines this new element
public EnumElementType getElementsType()
public TernaryValue testForEquality(JSType that)
JSTypethis and that.
testForEquality in class ObjectTypeTernaryValue.TRUE if the comparison of values of
this type and that always succeed (such as
undefined compared to null)TernaryValue.FALSE if the comparison of values of
this type and that always fails (such as
undefined compared to number)TernaryValue.UNKNOWN if the comparison can succeed or
fail depending on the concrete valuespublic boolean isSubtype(JSType that)
JSTypethis is a subtype of that.Subtyping rules:
(T<sub>1</sub>, …, T<sub>n</sub>) <: U if and only
T<sub>k</sub> <: U for all k ∈ 1..n.U <: (T<sub>1</sub>, …, T<sub>n</sub>) if and only
if U <: T<sub>k</sub> for some index k.O<sub>1</sub> is a subtype
of an object O<sub>2</sub> if it has more properties
than O<sub>2</sub> and all common properties are
pairwise subtypes.
this <: thatpublic String toString()
public String getDisplayName()
JSType
getDisplayName in class ObjectTypepublic <T> T visit(Visitor<T> visitor)
JSType
visit in class ObjectTypeVisitorpublic FunctionType getConstructor()
ObjectType
null if it is a native
object (constructed natively v.s. by instantiation of a function)public boolean matchesNumberContext()
JSType
public boolean matchesStringContext()
JSTypeString context, such as an operand of a string concat (+) operator.
All types have at least the potential for converting to String.
When we add externally defined types, such as a browser OM, we may choose
to add types that do not automatically convert to String.
public boolean matchesObjectContext()
JSTypeObject context, such as the expression in a with statement.
Most types we will encounter, except notably null, have at least
the potential for converting to Object. Host defined objects can
get peculiar.
public int getPropertiesCount()
getPropertiesCount in class ObjectTypepublic boolean hasProperty(String propertyName)
ObjectType
hasProperty in class ObjectTypepublic boolean hasOwnProperty(String propertyName)
ObjectType
hasOwnProperty in class ObjectTypepublic Set<String> getOwnPropertyNames()
ObjectType
getOwnPropertyNames in class ObjectTypepublic boolean isPropertyTypeDeclared(String property)
ObjectType
isPropertyTypeDeclared in class ObjectTypepublic boolean isPropertyTypeInferred(String property)
ObjectType
isPropertyTypeInferred in class ObjectTypepublic JSType getPropertyType(String propertyName)
ObjectType
getPropertyType in class ObjectTypeUnknownType. This method never
returns null.public boolean isPropertyInExterns(String propertyName)
ObjectType
isPropertyInExterns in class ObjectTypepublic Node getPropertyNode(String propertyName)
ObjectType
getPropertyNode in class ObjectTypepropertyName - the name of the property
Node corresponding to the property or null.public JSDocInfo getOwnPropertyJSDocInfo(String propertyName)
ObjectType
getOwnPropertyJSDocInfo in class ObjectType
public void setPropertyJSDocInfo(String propertyName,
JSDocInfo info,
boolean inExterns)
ObjectTypeJSDocInfo on its definition.
setPropertyJSDocInfo in class ObjectTypeinfo - JSDocInfo for the property definition. May be
null.inExterns - true if this property was defined in an externs
file. TightenTypes assumes that any function passed to an externs
property could be called, so setting this incorrectly could result
in live code being removed.public JSType unboxesTo()
JSType
unboxesTo in class JSTypenull if this type does not unbox.public boolean canBeCalled()
JSType
canBeCalled in class JSTypetrue if this type might be callable.public String getReferenceName()
ObjectType
getReferenceName in class ObjectTypenull if this is an anonymous
objectpublic boolean hasReferenceName()
ObjectType
hasReferenceName in class ObjectTypepublic boolean hasCachedValues()
ObjectType
hasCachedValues in class ObjectTypepublic boolean isNativeObjectType()
isNativeObjectType in class ObjectType
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||