java.lang.Object
tools.jackson.core.type.ResolvedType
tools.jackson.databind.JavaType
tools.jackson.databind.type.TypeBase
tools.jackson.databind.type.SimpleType
tools.jackson.databind.type.IterationType
- All Implemented Interfaces:
Serializable,Type,JacksonSerializable
Specialized
SimpleType for types that are allow iteration
over Collection(-like) types: this includes types like
Iterator.
Iterated (content) type is accessible using getContentType().- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface tools.jackson.databind.JacksonSerializable
JacksonSerializable.Base -
Field Summary
FieldsFields inherited from class tools.jackson.databind.type.TypeBase
_bindings, _superClass, _superInterfacesFields inherited from class tools.jackson.databind.JavaType
_asStatic, _class, _hash, _typeHandler, _valueHandler -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedIterationType(Class<?> cls, TypeBindings bindings, JavaType superClass, JavaType[] superInts, JavaType iteratedType, Object valueHandler, Object typeHandler, boolean asStatic) protectedIterationType(TypeBase base, JavaType iteratedType) Constructor used when upgrading into this type (viaupgradeFrom(tools.jackson.databind.JavaType, tools.jackson.databind.JavaType), the usual way forIterationTypes to come into existence. -
Method Summary
Modifier and TypeMethodDescriptionprotected Stringstatic IterationTypeconstruct(Class<?> cls, TypeBindings bindings, JavaType superClass, JavaType[] superInts, JavaType iteratedType) Method for accessing signature without generic type information, in form compatible with all versions of JVM, and specifically used for type descriptions when generating byte code.booleanAccessor that allows determining whetherJavaType.getContentType()should return a non-null value (that is, there is a "content type") or not.booleanMethod that returns true if this instance is of typeIterationType.refine(Class<?> rawType, TypeBindings bindings, JavaType superClass, JavaType[] superInterfaces) Mutant factory method that will try to create and return a sub-type instance for known parameterized types; for other types will return `null` to indicate that no just refinement makes necessary sense, without trying to detect special status through implemented interfaces.static IterationTypeupgradeFrom(JavaType baseType, JavaType iteratedType) Factory method that can be used to "upgrade" a basic type into iteration type; usually done viaTypeModifierwithContentType(JavaType contentType) Mutant factory method that may be called on structured types that have a so-called content type (element of arrays, value type of Maps, referenced type of referential types), and will construct a new instance that is identical to this instance, except that it has specified content type, instead of current one.Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.Method that can be called to get a type instance that indicates that values of the type should be handled using "static typing" for purposes of serialization (as opposed to "dynamic" aka runtime typing): meaning that no runtime information is needed for determining serializers to use.Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.Methods inherited from class tools.jackson.databind.type.SimpleType
constructUnsafe, equals, isContainerType, toStringMethods inherited from class tools.jackson.databind.type.TypeBase
_classSignature, _hasNTypeParameters, containedType, containedTypeCount, findSuperType, findTypeParameters, getBindings, getInterfaces, getSuperClass, serialize, serializeWithType, toCanonicalMethods inherited from class tools.jackson.databind.JavaType
containedTypeOrUnknown, getContentTypeHandler, getContentValueHandler, getErasedSignature, getGenericSignature, getKeyType, getRawClass, getReferencedType, getTypeHandler, getValueHandler, hasGenericTypes, hasHandlers, hashCode, hasRawClass, hasValueHandler, isAbstract, isArrayType, isCollectionLikeType, isConcrete, isEnumImplType, isEnumType, isFinal, isInterface, isJavaLangObject, isMapLikeType, isPrimitive, isRecordType, isThrowable, isTypeOrSubTypeOf, isTypeOrSuperTypeOf, useStaticType, withHandlersFromMethods inherited from class tools.jackson.core.type.ResolvedType
isReferenceTypeMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface java.lang.reflect.Type
getTypeName
-
Field Details
-
_iteratedType
-
-
Constructor Details
-
IterationType
-
IterationType
Constructor used when upgrading into this type (viaupgradeFrom(tools.jackson.databind.JavaType, tools.jackson.databind.JavaType), the usual way forIterationTypes to come into existence. Sets up what is considered the "base" iteration type
-
-
Method Details
-
upgradeFrom
Factory method that can be used to "upgrade" a basic type into iteration type; usually done viaTypeModifier- Parameters:
baseType- Resolved non-iteration type (usuallySimpleType) that is being upgradediteratedType- Iterated type; usually the first and only type parameter, but not necessarily
-
construct
public static IterationType construct(Class<?> cls, TypeBindings bindings, JavaType superClass, JavaType[] superInts, JavaType iteratedType) -
withContentType
Description copied from class:JavaTypeMutant factory method that may be called on structured types that have a so-called content type (element of arrays, value type of Maps, referenced type of referential types), and will construct a new instance that is identical to this instance, except that it has specified content type, instead of current one. If content type is already set to given type,thisis returned. If type does not have a content type (which is the case withSimpleType),IllegalArgumentExceptionwill be thrown.- Overrides:
withContentTypein classSimpleType- Returns:
- Newly created type instance
-
withTypeHandler
Description copied from class:JavaTypeInternal method that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.This mutant factory method will construct a new instance that is identical to this instance, except that it will have specified type handler assigned.
- Overrides:
withTypeHandlerin classSimpleType- Parameters:
h- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withContentTypeHandler
Description copied from class:JavaTypeInternal method that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.This mutant factory method will construct a new instance that is identical to this instance, except that it will have specified content type (element type for arrays, value type for Maps and so forth) handler assigned.
- Overrides:
withContentTypeHandlerin classSimpleType- Parameters:
h- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withValueHandler
Description copied from class:JavaTypeInternal method that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.This mutant factory method will construct a new instance that is identical to this instance, except that it will have specified value handler assigned.
- Overrides:
withValueHandlerin classSimpleType- Parameters:
h- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withContentValueHandler
Description copied from class:JavaTypeInternal method that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.Mutant factory method that will construct a new instance that is identical to this instance, except that it will have specified content value handler assigned.
- Overrides:
withContentValueHandlerin classSimpleType- Parameters:
h- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withStaticTyping
Description copied from class:JavaTypeMethod that can be called to get a type instance that indicates that values of the type should be handled using "static typing" for purposes of serialization (as opposed to "dynamic" aka runtime typing): meaning that no runtime information is needed for determining serializers to use. The main use case is to allow forcing of specific root value serialization type, and specifically in resolving serializers for contained types (element types for arrays, Collections and Maps).- Overrides:
withStaticTypingin classSimpleType
-
refine
public JavaType refine(Class<?> rawType, TypeBindings bindings, JavaType superClass, JavaType[] superInterfaces) Description copied from class:JavaTypeMutant factory method that will try to create and return a sub-type instance for known parameterized types; for other types will return `null` to indicate that no just refinement makes necessary sense, without trying to detect special status through implemented interfaces.- Overrides:
refinein classSimpleType
-
buildCanonicalName
- Overrides:
buildCanonicalNamein classSimpleType
-
getContentType
- Overrides:
getContentTypein classJavaType
-
hasContentType
public boolean hasContentType()Description copied from class:JavaTypeAccessor that allows determining whetherJavaType.getContentType()should return a non-null value (that is, there is a "content type") or not. True ifJavaType.isContainerType()orResolvedType.isReferenceType()return true.- Overrides:
hasContentTypein classSimpleType
-
isIterationType
public boolean isIterationType()Description copied from class:JavaTypeMethod that returns true if this instance is of typeIterationType.- Overrides:
isIterationTypein classJavaType- Returns:
- True if this type is considered "iteration type"
-
getErasedSignature
Description copied from class:JavaTypeMethod for accessing signature without generic type information, in form compatible with all versions of JVM, and specifically used for type descriptions when generating byte code.- Overrides:
getErasedSignaturein classSimpleType- Parameters:
sb- StringBuilder to append signature to- Returns:
- StringBuilder that was passed in; returned to allow call chaining
-
getGenericSignature
- Overrides:
getGenericSignaturein classSimpleType- Parameters:
sb- StringBuilder to append signature to- Returns:
- StringBuilder that was passed in; returned to allow call chaining
-