Class ProxyObjectType
- Direct Known Subclasses:
NamedType,TemplateType,TemplatizedType
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class com.google.javascript.rhino.jstype.JSType
JSType.HasPropertyKind, JSType.Nullability, JSType.SubtypingMode, JSType.TypePair, JSType.WithSourceRef -
Field Summary
Fields inherited from class com.google.javascript.rhino.jstype.JSType
templateTypeMap -
Method Summary
Modifier and TypeMethodDescriptionfinal booleanThis predicate is used to test whether a given type can be used as the 'function' in a function call.final JSTypeGets the least supertype of this that's not a union.protected JSTypefindPropertyTypeWithoutConsideringTemplateTypes(Property.Key propertyName) Looks up a property on this type, but without properly replacing any templates in the result.final @Nullable FunctionTypeGets this object's constructor.Gets the interfaces extended by the interface associated with this type.Gets the interfaces implemented by the ctor associated with this type.final @Nullable ObjectTypeGets the implicit prototype (a.k.a.final JSDocInfoGets the docInfo for this type.final @Nullable FunctionTypefinal JSType.HasPropertyKindgetPropertyKind(Property.Key propertyName, boolean autobox) Checks whether the property is present on the object.Gets the reference name for this object.intReturn the number of template parameters declared for this type.Returns the template type map associated with this type.@Nullable com.google.common.collect.ImmutableList<JSType> Gets the declared default element type.final JSTypebooleanfinal booleanfinal booleanfinal booleanWhether this type is aFunctionTypethat is a constructor or a named type that points to such a type.final booleanisDict()Returns true iffthiscan be adict.final booleanWhether this type is an Instance object of some constructor.final booleanWhether this type is aFunctionTypethat is an interface or a named type that points to such a type.final booleanWhether this is a built-in object.booleanWhether this type is a nominal type (a named instance object or a named enum).final booleanfinal booleanfinal booleanisNoType()final booleanTests whether this type is nullable.final booleanWhether this type is aFunctionTypethat is an ordinary function (i.e.final booleanisStruct()Returns true iffthiscan be astruct.final booleanfinal booleanWe treat this as the unknown type if any of its implicit prototype properties is unknown.final booleanTests whether this type is voidable.final booleanDuring type definition, was one of the supertypes of this type a forward reference?final voidmatchConstraint(JSType constraint) Modify this type so that it matches the specified type.final booleanThis predicate is used to test whether a given type can appear in a numeric context, such as an operand of a multiply operator.final booleanThis predicate is used to test whether a given type can appear in anObjectcontext, such as the expression in a with statement.final booleanThis predicate is used to test whether a given type can appear in aStringcontext, such as an operand of a string concat (+) operator.final booleanThis predicate is used to test whether a given type can appear in asymbolcontext such as property access.final voidsetJSDocInfo(JSDocInfo info) Sets the docInfo for this type from the givenJSDocInfo.final voidsetPropertyJSDocInfo(Property.Key propertyName, JSDocInfo info) Sets the docInfo for the specified property from theJSDocInfoon its definition.booleansetValidator(com.google.common.base.Predicate<JSType> validator) Certain types have constraints on them at resolution-time.final TritestForEquality(JSType that) Comparesthisandthat.final EnumElementTypeDowncasts this to an EnumElementType, or returns null if this is not an EnumElementType.final EnumTypeDowncasts this to an EnumType, or returns null if this is not an EnumType.final FunctionTypeDowncasts this to a FunctionType, or returns null if this is not a function.final KnownSymbolTypefinal RecordTypeDowncasts this to a RecordType, or returns null if this is not a RecordType.Downcasts this to a TemplateType, or returns null if this is not a template type.Downcasts this to a TemplatizedType, or returns null if this is not a templatized type.final UnionTypeDowncasts this to a UnionType, or returns null if this is not a UnionType.<T> TVisit this type with the given visitor.final <T> TvisitReferenceType(Visitor<T> visitor) Methods inherited from class com.google.javascript.rhino.jstype.ObjectType
cast, clearCachedValues, createDelegateSuffix, defineDeclaredProperty, defineDeclaredProperty, defineInferredProperty, defineInferredProperty, defineSynthesizedProperty, findClosestDefinition, findClosestDefinition, getAllKeys, getClosestDefiningType, getDisplayName, getEnumeratedTypeOfEnumObject, getImplicitPrototypeChain, getNormalizedReferenceName, getOwnPropertyDefSite, getOwnPropertyDefSite, getOwnPropertyJSDocInfo, getOwnPropertyJSDocInfo, getOwnPropertyKeys, getOwnPropertyKind, getOwnPropertyKind, getOwnPropertyKnownSymbols, getOwnPropertyNames, getOwnSlot, getOwnSlot, getPossibleToBooleanOutcomes, getPropertiesCount, getPropertyDefSite, getPropertyDefSite, getPropertyJSDocInfo, getPropertyJSDocInfo, getPropertyNames, getPropertyNode, getPropertyNode, getPropertyType, getPropertyType, getPropertyTypeMap, getRawType, getSlot, getSlot, getSuperClassConstructor, hasCachedValues, hasOwnDeclaredProperty, hasOwnDeclaredProperty, hasOwnProperty, hasOwnProperty, hasReferenceName, isFunctionPrototypeType, isObject, isPropertyInExterns, isPropertyTypeDeclared, isPropertyTypeDeclared, isPropertyTypeInferred, isPropertyTypeInferred, setPropertyJSDocInfo, setPropertyNode, setPropertyNodeMethods inherited from class com.google.javascript.rhino.jstype.JSType
areSimilar, assertFunctionType, assertObjectType, autobox, autoboxesTo, canCastTo, canTestForEqualityWith, canTestForShallowEqualityWith, containsReferenceAncestor, dereference, differsFrom, equals, findPropertyType, findPropertyType, getEnumeratedTypeOfEnumElement, getGreatestSubtype, getLeastSupertype, getPropertyKind, getPropertyKind, getPropertyKind, getRestrictedTypeGivenOutcome, getTypeParameters, getTypesUnderEquality, getTypesUnderInequality, getTypesUnderShallowEquality, getTypesUnderShallowInequality, getUnionMembers, hasAnyTemplateTypes, hasDisplayName, hashCode, hasProperty, hasProperty, isArrayType, isBigIntObjectType, isBigIntOrNumber, isBigIntValueType, isBooleanObjectType, isBooleanValueType, isBoxableScalar, isDateType, isEmptyType, isEnumElementType, isEnumType, isExplicitlyVoidable, isFunctionType, isGlobalThisType, isKnownSymbolValueType, isLiteralObject, isNamedType, isNominalConstructorOrInterface, isNullType, isNumber, isNumberObjectType, isNumberValueType, isObjectType, isOnlyBigInt, isRawTypeOfTemplatizedType, isReadonlyArrayType, isRecordType, isRegexpType, isResolved, isSomeUnknownType, isString, isStringObjectType, isStringValueType, isStructuralInterface, isSubtype, isSubtype, isSubtypeOf, isSubtypeOf, isSubtypeWithoutStructuralTyping, isSuccessfullyResolved, isSymbol, isSymbolObjectType, isSymbolValueType, isTemplateType, isTemplatizedType, isUnionType, isUnsuccessfullyResolved, isVoidType, mergeSupertypeTemplateTypes, resolve, restrictByNotNull, restrictByNotNullOrUndefined, restrictByNotUndefined, toAnnotationString, toMaybeFunctionType, toMaybeNamedType, toMaybeObjectType, toObjectType, toString
-
Method Details
-
getPropertyKind
Description copied from class:JSTypeChecks whether the property is present on the object.- Overrides:
getPropertyKindin classObjectType- Parameters:
propertyName- The property name.autobox- Whether to check for the presents on an autoboxed type
-
loosenTypecheckingDueToForwardReferencedSupertype
public final boolean loosenTypecheckingDueToForwardReferencedSupertype()Description copied from class:JSTypeDuring type definition, was one of the supertypes of this type a forward reference?This is a hack to work around the fact that inheritance chains and template types aren't wired up correctly when this happens, which causes various false positives in checks. The known bugs associated are b/145145406, b/144327372, and b/132980305.
This method should only be used to suppress potential false positives caused by one of the above bugs, in the case where we think suppressing typechecking is preferable to emitting a false positive.
- Overrides:
loosenTypecheckingDueToForwardReferencedSupertypein classJSType
-
setValidator
Description copied from class:JSTypeCertain types have constraints on them at resolution-time. For example, a type in an@extendsannotation must be an object. Clients should inject a validator that emits a warning if the type does not validate, and return false.- Overrides:
setValidatorin classJSType
-
getReferenceName
Description copied from class:ObjectTypeGets the reference name for this object. This includes named types like constructors, prototypes, and enums. It notably does not include literal types like strings and booleans and structural types.Returning an empty string means something different than returning null. An empty string may indicate an anonymous constructor, which we treat differently than a literal type without a reference name. e.g. in
InstanceObjectType.appendTo(TypeStringBuilder)- Specified by:
getReferenceNamein classObjectType- Returns:
- the object's name or
nullif this is an anonymous object
-
matchesNumberContext
public final boolean matchesNumberContext()Description copied from class:JSTypeThis predicate is used to test whether a given type can appear in a numeric context, such as an operand of a multiply operator.- Overrides:
matchesNumberContextin classJSType
-
matchesStringContext
public final boolean matchesStringContext()Description copied from class:JSTypeThis predicate is used to test whether a given type can appear in aStringcontext, such as an operand of a string concat (+) operator. All types have at least the potential for converting toString. When we add externally defined types, such as a browser OM, we may choose to add types that do not automatically convert toString.- Overrides:
matchesStringContextin classJSType
-
matchesSymbolContext
public final boolean matchesSymbolContext()Description copied from class:JSTypeThis predicate is used to test whether a given type can appear in asymbolcontext such as property access.- Overrides:
matchesSymbolContextin classJSType
-
matchesObjectContext
public final boolean matchesObjectContext()Description copied from class:JSTypeThis predicate is used to test whether a given type can appear in anObjectcontext, such as the expression in a with statement. Most types we will encounter, except notablynull, have at least the potential for converting toObject. Host defined objects can get peculiar.- Overrides:
matchesObjectContextin classJSType
-
canBeCalled
public final boolean canBeCalled()Description copied from class:JSTypeThis predicate is used to test whether a given type can be used as the 'function' in a function call.- Overrides:
canBeCalledin classJSType- Returns:
trueif this type might be callable.
-
isStructuralType
public final boolean isStructuralType()- Overrides:
isStructuralTypein classObjectType
-
isNoType
public final boolean isNoType() -
isNoObjectType
public final boolean isNoObjectType()- Overrides:
isNoObjectTypein classJSType
-
isNoResolvedType
public final boolean isNoResolvedType()- Overrides:
isNoResolvedTypein classJSType
-
isUnknownType
public final boolean isUnknownType()Description copied from class:ObjectTypeWe treat this as the unknown type if any of its implicit prototype properties is unknown.- Overrides:
isUnknownTypein classObjectType
-
isCheckedUnknownType
public final boolean isCheckedUnknownType()- Overrides:
isCheckedUnknownTypein classJSType
-
isNullable
public final boolean isNullable()Description copied from class:JSTypeTests whether this type is nullable.- Overrides:
isNullablein classJSType
-
isVoidable
public final boolean isVoidable()Description copied from class:JSTypeTests whether this type is voidable.- Overrides:
isVoidablein classJSType
-
toMaybeEnumType
Description copied from class:JSTypeDowncasts this to an EnumType, or returns null if this is not an EnumType.- Overrides:
toMaybeEnumTypein classJSType
-
isConstructor
public final boolean isConstructor()Description copied from class:JSTypeWhether this type is aFunctionTypethat is a constructor or a named type that points to such a type.- Overrides:
isConstructorin classJSType
-
isNominalType
public boolean isNominalType()Description copied from class:JSTypeWhether this type is a nominal type (a named instance object or a named enum).- Overrides:
isNominalTypein classJSType
-
isInstanceType
public final boolean isInstanceType()Description copied from class:JSTypeWhether this type is an Instance object of some constructor. Does not necessarily mean this is anInstanceObjectType.- Overrides:
isInstanceTypein classJSType
-
isInterface
public final boolean isInterface()Description copied from class:JSTypeWhether this type is aFunctionTypethat is an interface or a named type that points to such a type.- Overrides:
isInterfacein classJSType
-
isOrdinaryFunction
public final boolean isOrdinaryFunction()Description copied from class:JSTypeWhether this type is aFunctionTypethat is an ordinary function (i.e. not a constructor, nominal interface, or record interface), or a named type that points to such a type.- Overrides:
isOrdinaryFunctionin classJSType
-
isAllType
public final boolean isAllType() -
isStruct
public final boolean isStruct()Description copied from class:JSTypeReturns true iffthiscan be astruct. UnionType overrides the method, assumethisis not a union here. -
isDict
public final boolean isDict()Description copied from class:JSTypeReturns true iffthiscan be adict. UnionType overrides the method, assumethisis not a union here. -
isNativeObjectType
public final boolean isNativeObjectType()Description copied from class:ObjectTypeWhether this is a built-in object.- Overrides:
isNativeObjectTypein classObjectType
-
toMaybeRecordType
Description copied from class:JSTypeDowncasts this to a RecordType, or returns null if this is not a RecordType.- Overrides:
toMaybeRecordTypein classJSType
-
toMaybeUnionType
Description copied from class:JSTypeDowncasts this to a UnionType, or returns null if this is not a UnionType. Named in honor of Haskell's Maybe type constructor.- Overrides:
toMaybeUnionTypein classJSType
-
toMaybeFunctionType
Description copied from class:JSTypeDowncasts this to a FunctionType, or returns null if this is not a function.For the purposes of this function, we define a MaybeFunctionType as any type in the sub-lattice { x | LEAST_FUNCTION_TYPE <= x <= GREATEST_FUNCTION_TYPE } This definition excludes bottom types like NoType and NoObjectType.
This definition is somewhat arbitrary and axiomatic, but this is the definition that makes the most sense for the most callers.
- Overrides:
toMaybeFunctionTypein classJSType
-
toMaybeEnumElementType
Description copied from class:JSTypeDowncasts this to an EnumElementType, or returns null if this is not an EnumElementType.- Overrides:
toMaybeEnumElementTypein classJSType
-
toMaybeKnownSymbolType
- Overrides:
toMaybeKnownSymbolTypein classJSType
-
testForEquality
Description copied from class:JSTypeComparesthisandthat.- Overrides:
testForEqualityin classObjectType- Returns:
Tri.TRUEif the comparison of values ofthistype andthatalways succeed (such asundefinedcompared tonull)Tri.FALSEif the comparison of values ofthistype andthatalways fails (such asundefinedcompared tonumber)Tri.UNKNOWNif the comparison can succeed or fail depending on the concrete values
-
getOwnerFunction
- Overrides:
getOwnerFunctionin classObjectType
-
getCtorImplementedInterfaces
Description copied from class:ObjectTypeGets the interfaces implemented by the ctor associated with this type. Intended to be overridden by subclasses.- Overrides:
getCtorImplementedInterfacesin classObjectType
-
getCtorExtendedInterfaces
Description copied from class:ObjectTypeGets the interfaces extended by the interface associated with this type. Intended to be overridden by subclasses.- Overrides:
getCtorExtendedInterfacesin classObjectType
-
getImplicitPrototype
Description copied from class:ObjectTypeGets the implicit prototype (a.k.a. the[[Prototype]]property).- Specified by:
getImplicitPrototypein classObjectType
-
findPropertyTypeWithoutConsideringTemplateTypes
Description copied from class:JSTypeLooks up a property on this type, but without properly replacing any templates in the result.Subclasses can override this if they need more complicated logic for property lookup than just autoboxing to an object.
This is only for use by
findPropertyType(JSType). Call that method instead if you need to lookup a property on a random JSType- Overrides:
findPropertyTypeWithoutConsideringTemplateTypesin classObjectType
-
getJSDocInfo
Description copied from class:ObjectTypeGets the docInfo for this type.- Overrides:
getJSDocInfoin classObjectType
-
setJSDocInfo
Description copied from class:ObjectType- Overrides:
setJSDocInfoin classObjectType
-
setPropertyJSDocInfo
Description copied from class:ObjectTypeSets the docInfo for the specified property from theJSDocInfoon its definition.- Overrides:
setPropertyJSDocInfoin classObjectType- Parameters:
info-JSDocInfofor the property definition. May benull.
-
getConstructor
Description copied from class:ObjectTypeGets this object's constructor.- Specified by:
getConstructorin classObjectType- Returns:
- this object's constructor or
nullif it is a native object (constructed natively v.s. by instantiation of a function)
-
getTemplateTypes
Description copied from class:ObjectTypeGets the declared default element type.- Overrides:
getTemplateTypesin classObjectType- See Also:
-
getTemplateParamCount
public int getTemplateParamCount()Description copied from class:JSTypeReturn the number of template parameters declared for this type.In general, this value corresponds to the number of `@template` declarations on the type definition. It does not include template parameters from superclasses or superinterfaces.
- Overrides:
getTemplateParamCountin classJSType
-
visitReferenceType
-
visit
Description copied from class:JSTypeVisit this type with the given visitor.- Overrides:
visitin classObjectType- Returns:
- the value returned by the visitor
- See Also:
-
getTypeOfThis
- Overrides:
getTypeOfThisin classObjectType
-
collapseUnion
Description copied from class:JSTypeGets the least supertype of this that's not a union.- Overrides:
collapseUnionin classJSType
-
matchConstraint
Description copied from class:JSTypeModify this type so that it matches the specified type.This is useful for reverse type-inference, where we want to infer that an object literal matches its constraint (much like how the java compiler does reverse-inference to figure out generics).
- Overrides:
matchConstraintin classJSType
-
toMaybeTemplatizedType
Description copied from class:JSTypeDowncasts this to a TemplatizedType, or returns null if this is not a templatized type.- Overrides:
toMaybeTemplatizedTypein classJSType
-
toMaybeTemplateType
Description copied from class:JSTypeDowncasts this to a TemplateType, or returns null if this is not a template type.- Overrides:
toMaybeTemplateTypein classJSType
-
hasAnyTemplateTypesInternal
public boolean hasAnyTemplateTypesInternal() -
getTemplateTypeMap
Description copied from class:JSTypeReturns the template type map associated with this type.- Overrides:
getTemplateTypeMapin classJSType
-