|
|||||||||
| 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.RecordType
public class RecordType
A record (structural) type. Subtyping: The subtyping of a record type is defined via structural comparison of a record type's properties. For example, a record type of the form { a : TYPE_1 } is a supertype of a record type of the form { b : TYPE_2, a : TYPE_1 } because B can be assigned to A and matches all constraints. Similarly, a defined type can be assigned to a record type so long as that defined type matches all property constraints of the record type. A record type of the form { a : A, b : B } can be assigned to a record of type { a : A }.
| 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. |
FunctionType |
getConstructor()
Gets this object's constructor. |
JSType |
getGreatestSubtype(JSType that)
Gets the greatest subtype of this and that. |
ObjectType |
getImplicitPrototype()
Gets the implicit prototype (a.k.a. |
JSType |
getLeastSupertype(JSType that)
Gets the least supertype of this and that. |
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 |
isEquivalentTo(JSType other)
Checks if two types are equivalent. |
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 |
isRecordType()
|
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. |
String |
toString()
|
JSType |
unboxesTo()
Gets the type to which this type unboxes. |
| Methods inherited from class com.google.javascript.rhino.jstype.ObjectType |
|---|
cast, clearCachedValues, createDelegateSuffix, defineDeclaredProperty, defineInferredProperty, findPropertyType, getCtorImplementedInterfaces, getDisplayName, getIndexType, getJSDocInfo, getNormalizedReferenceName, getParameterType, getPossibleToBooleanOutcomes, getPropertyNames, isObject, isUnknownType, setJSDocInfo, testForEquality, visit |
| Methods inherited from class java.lang.Object |
|---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
| Method Detail |
|---|
public boolean isEquivalentTo(JSType other)
JSType
isEquivalentTo in class JSTypepublic ObjectType getImplicitPrototype()
ObjectType[[Prototype]] property).
public JSType getLeastSupertype(JSType that)
JSTypethis and that.
The least supertype is the join (∨) or supremum of both types in the
type lattice.Examples:
number ∨ * = *number ∨ Object = (number, Object)Number ∨ Object = Object
getLeastSupertype in class JSTypethis ∨ thatpublic JSType getGreatestSubtype(JSType that)
JSTypethis and that.
The greatest subtype is the meet (∧) or infimum of both types in the
type lattice.Examples
Number ∧ Any = Anynumber ∧ Object = AnyNumber ∧ Object = Number
getGreatestSubtype in class JSTypethis ∨ thatpublic boolean isRecordType()
isRecordType in class JSTypepublic 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 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 boolean matchesNumberContext()
JSType
matchesNumberContext in class JSTypepublic 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.
matchesStringContext in class JSTypepublic JSType unboxesTo()
JSType
unboxesTo in class JSTypenull if this type does not unbox.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.
matchesObjectContext in class JSTypepublic boolean canBeCalled()
JSType
canBeCalled in class JSTypetrue if this type might be callable.public FunctionType getConstructor()
ObjectType
getConstructor in class ObjectTypenull if it is a native
object (constructed natively v.s. by instantiation of a function)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 | ||||||||