Class MapLikeType
- All Implemented Interfaces:
JsonSerializable
,Serializable
,Type
- Direct Known Subclasses:
MapType
Map
, but that do not
have enough introspection functionality to allow for some level of generic
handling. This specifically allows framework to check for configuration and
annotation settings used for Map types, and pass these to custom handlers
that may be more familiar with actual type.- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface edu.internet2.middleware.grouperClientExt.com.fasterxml.jackson.databind.JsonSerializable
JsonSerializable.Base
-
Field Summary
Modifier and TypeFieldDescriptionprotected final JavaType
Type of keys of Map.protected final JavaType
Type of values of Map.Fields inherited from class edu.internet2.middleware.grouperClientExt.com.fasterxml.jackson.databind.type.TypeBase
_bindings, _superClass, _superInterfaces
Fields inherited from class edu.internet2.middleware.grouperClientExt.com.fasterxml.jackson.databind.JavaType
_asStatic, _class, _hash, _typeHandler, _valueHandler
-
Constructor Summary
ModifierConstructorDescriptionprotected
MapLikeType
(TypeBase base, JavaType keyT, JavaType valueT) protected
MapLikeType
(Class<?> mapType, TypeBindings bindings, JavaType superClass, JavaType[] superInts, JavaType keyT, JavaType valueT, Object valueHandler, Object typeHandler, boolean asStatic) -
Method Summary
Modifier and TypeMethodDescriptionprotected JavaType
Deprecated.protected String
static MapLikeType
Deprecated.boolean
Method for accessing content type of this type, if type has such a thing: simple types do not, structured types do (like arrays, Collections and Maps)Internal accessor that should not be used by any code outside of jackson-databind: only used internally by databind.Internal accessor that should not be used by any code outside of jackson-databind: only used internally by databind.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.Method for accessing key type for this type, assuming type has such a concept (only Map types do)boolean
Helper method that checks whether this type, or its (optional) key or content type hasJavaType.getValueHandler()
orJavaType.getTypeHandler()
; that is, are there any non-standard handlers associated with this type object.boolean
boolean
boolean
Deprecated.Since 2.12 just use instanceofrefine
(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.toString()
static MapLikeType
upgradeFrom
(JavaType baseType, JavaType keyT, JavaType valueT) Factory method that can be used to "upgrade" a basic type into collection-like one; usually done viaTypeModifier
withContentType
(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.withHandlersFrom
(JavaType src) Internal method that should not be used by any code outside of jackson-databind: only used internally by databind.withKeyType
(JavaType keyType) 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 edu.internet2.middleware.grouperClientExt.com.fasterxml.jackson.databind.type.TypeBase
_bogusSuperClass, _classSignature, _hasNTypeParameters, containedType, containedTypeCount, containedTypeName, findSuperType, findTypeParameters, getBindings, getInterfaces, getSuperClass, serialize, serializeWithType, toCanonical
Methods inherited from class edu.internet2.middleware.grouperClientExt.com.fasterxml.jackson.databind.JavaType
containedTypeOrUnknown, forcedNarrowBy, getErasedSignature, getGenericSignature, getParameterSource, getRawClass, getReferencedType, getTypeHandler, getValueHandler, hasContentType, hasGenericTypes, hashCode, hasRawClass, hasValueHandler, isAbstract, isArrayType, isCollectionLikeType, isConcrete, isEnumImplType, isEnumType, isFinal, isInterface, isJavaLangObject, isPrimitive, isRecordType, isThrowable, isTypeOrSubTypeOf, isTypeOrSuperTypeOf, useStaticType
Methods inherited from class edu.internet2.middleware.grouperClientExt.com.fasterxml.jackson.core.type.ResolvedType
isReferenceType
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
Methods inherited from interface java.lang.reflect.Type
getTypeName
-
Field Details
-
_keyType
Type of keys of Map. -
_valueType
Type of values of Map.
-
-
Constructor Details
-
MapLikeType
-
MapLikeType
- Since:
- 2.7
-
-
Method Details
-
upgradeFrom
Factory method that can be used to "upgrade" a basic type into collection-like one; usually done viaTypeModifier
- Since:
- 2.7
-
construct
Deprecated. -
_narrow
Deprecated. -
withKeyType
- Since:
- 2.7
-
withContentType
Description copied from class:JavaType
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. If content type is already set to given type,this
is returned. If type does not have a content type (which is the case withSimpleType
),IllegalArgumentException
will be thrown.- Specified by:
withContentType
in classJavaType
- Returns:
- Newly created type instance
-
withTypeHandler
Description copied from class:JavaType
Internal 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.
- Specified by:
withTypeHandler
in classJavaType
- 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:JavaType
Internal 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.
- Specified by:
withContentTypeHandler
in classJavaType
- 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:JavaType
Internal 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.
- Specified by:
withValueHandler
in classJavaType
- 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:JavaType
Internal 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.
- Specified by:
withContentValueHandler
in classJavaType
- Parameters:
h
- Handler to pass to new instance created- Returns:
- Newly created type instance with same type information, specified handler
-
withHandlersFrom
Description copied from class:JavaType
Internal 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 try to copy handlers that the specified source type instance had, if any; this must be done recursively where necessary (as content types may be structured).
- Overrides:
withHandlersFrom
in classJavaType
-
withStaticTyping
Description copied from class:JavaType
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. 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).- Specified by:
withStaticTyping
in classJavaType
-
refine
public JavaType refine(Class<?> rawType, TypeBindings bindings, JavaType superClass, JavaType[] superInterfaces) Description copied from class:JavaType
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. -
buildCanonicalName
- Overrides:
buildCanonicalName
in classTypeBase
-
isContainerType
public boolean isContainerType()- Specified by:
isContainerType
in classJavaType
- Returns:
- True if type represented is a container type; this includes array, Map and Collection types.
-
isMapLikeType
public boolean isMapLikeType()- Overrides:
isMapLikeType
in classJavaType
- Returns:
- True if type is either true
Map
type, or something similar (meaning it has at least two type parameter; first one describing key type, second value type)
-
getKeyType
Description copied from class:ResolvedType
Method for accessing key type for this type, assuming type has such a concept (only Map types do)- Overrides:
getKeyType
in classJavaType
- Returns:
- Key type of this type, if any;
null
if none
-
getContentType
Description copied from class:ResolvedType
Method for accessing content type of this type, if type has such a thing: simple types do not, structured types do (like arrays, Collections and Maps)- Overrides:
getContentType
in classJavaType
- Returns:
- Content type of this type, if any;
null
if none
-
getContentValueHandler
Description copied from class:JavaType
Internal accessor that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.- Overrides:
getContentValueHandler
in classJavaType
- Returns:
- Content value handler associated with this type, if any.
-
getContentTypeHandler
Description copied from class:JavaType
Internal accessor that should not be used by any code outside of jackson-databind: only used internally by databind. May be removed from Jackson 3.0.- Overrides:
getContentTypeHandler
in classJavaType
- Returns:
- Content type handler associated with this type, if any.
-
hasHandlers
public boolean hasHandlers()Description copied from class:JavaType
Helper method that checks whether this type, or its (optional) key or content type hasJavaType.getValueHandler()
orJavaType.getTypeHandler()
; that is, are there any non-standard handlers associated with this type object.- Overrides:
hasHandlers
in classJavaType
-
getErasedSignature
Description copied from class:JavaType
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.- Specified by:
getErasedSignature
in classTypeBase
- Parameters:
sb
- StringBuilder to append signature to- Returns:
- StringBuilder that was passed in; returned to allow call chaining
-
getGenericSignature
- Specified by:
getGenericSignature
in classTypeBase
- Parameters:
sb
- StringBuilder to append signature to- Returns:
- StringBuilder that was passed in; returned to allow call chaining
-
withKeyTypeHandler
-
withKeyValueHandler
-
isTrueMapType
Deprecated.Since 2.12 just use instanceofMethod that can be used for checking whether this type is a "real" Collection type; meaning whether it represents a parameterized subtype ofCollection
or just something that acts like one. -
toString
-
equals
-