Package net.sf.saxon.ma.map
Class MapType
- java.lang.Object
- 
- net.sf.saxon.type.AnyFunctionType
- 
- net.sf.saxon.ma.map.MapType
 
 
- 
- All Implemented Interfaces:
- FunctionItemType,- ItemType
 
 public class MapType extends AnyFunctionType An instance of this class represents a specific map item type, for example map(x:integer, element(employee))
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface net.sf.saxon.type.ItemTypeItemType.WithSequenceTypeCache
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static MapTypeANY_MAP_TYPEstatic MapTypeEMPTY_MAP_TYPEstatic SequenceTypeOPTIONAL_MAP_ITEMA type that allows a sequence of zero or one map itemsstatic SequenceTypeSEQUENCE_OF_MAPSstatic SequenceTypeSINGLE_MAP_ITEM- 
Fields inherited from class net.sf.saxon.type.AnyFunctionTypeANY_FUNCTION
 
- 
 - 
Constructor SummaryConstructors Constructor Description MapType(AtomicType keyType, SequenceType valueType)MapType(AtomicType keyType, SequenceType valueType, boolean mustBeEmpty)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanequals(java.lang.Object other)Test whether this function type equals another function typejava.util.Optional<java.lang.String>explainMismatch(Item item, TypeHierarchy th)Get extra diagnostic information about why a supplied item does not conform to this item type, if available.SequenceType[]getArgumentTypes()Get the argument types of this map, viewed as a functionintgetArity()Get the arity (number of arguments) of this function typejava.lang.StringgetBasicAlphaCode()Get an alphabetic code representing the type, or at any rate, the nearest built-in type from which this type is derived.doublegetDefaultPriority()Get the default priority when this ItemType is used as an XSLT patternGenregetGenre()Determine the Genre (top-level classification) of this typeAtomicTypegetKeyType()Get the type of the keysSequenceTypegetResultType()Get the result type of this map, viewed as a functionSequenceTypegetValueType()Get the type of the indexed valuesinthashCode()Returns a hash code value for the object.booleanisArrayType()Ask whether this function item type is an array type.booleanisAtomizable(TypeHierarchy th)Ask whether values of this type are atomizablebooleanisMapType()Ask whether this function item type is a map type.ExpressionmakeFunctionSequenceCoercer(Expression exp, RoleDiagnostic role)Create an expression whose effect is to apply function coercion to coerce a function from this type to another typebooleanmatches(Item item, TypeHierarchy th)Test whether a given item conforms to this typeAffinityrelationship(FunctionItemType other, TypeHierarchy th)Determine the relationship of one function item type to anotherjava.lang.StringtoExportString()Return a string representation of this ItemType suitable for use in stylesheet export files.java.lang.StringtoString()Produce a representation of this type name for use in error messages.- 
Methods inherited from class net.sf.saxon.type.AnyFunctionTypegetAnnotationAssertions, getAtomizedItemType, getInstance, getPrimitiveItemType, getPrimitiveType, getUType, isAtomicType, isPlainType
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface net.sf.saxon.type.ItemTypegetFullAlphaCode, getNormalizedDefaultPriority, isTrueItemType
 
- 
 
- 
- 
- 
Field Detail- 
ANY_MAP_TYPEpublic static final MapType ANY_MAP_TYPE 
 - 
EMPTY_MAP_TYPEpublic static final MapType EMPTY_MAP_TYPE 
 - 
OPTIONAL_MAP_ITEMpublic static final SequenceType OPTIONAL_MAP_ITEM A type that allows a sequence of zero or one map items
 - 
SINGLE_MAP_ITEMpublic static final SequenceType SINGLE_MAP_ITEM 
 - 
SEQUENCE_OF_MAPSpublic static final SequenceType SEQUENCE_OF_MAPS 
 
- 
 - 
Constructor Detail- 
MapTypepublic MapType(AtomicType keyType, SequenceType valueType) 
 - 
MapTypepublic MapType(AtomicType keyType, SequenceType valueType, boolean mustBeEmpty) 
 
- 
 - 
Method Detail- 
getGenrepublic Genre getGenre() Determine the Genre (top-level classification) of this type- Returns:
- the Genre to which this type belongs, specifically Genre.MAP
 
 - 
getKeyTypepublic AtomicType getKeyType() Get the type of the keys- Returns:
- the type to which all keys must conform
 
 - 
getValueTypepublic SequenceType getValueType() Get the type of the indexed values- Returns:
- the type to which all associated values must conform
 
 - 
isMapTypepublic boolean isMapType() Ask whether this function item type is a map type. In this case function coercion (to the map type) will never succeed.- Specified by:
- isMapTypein interface- FunctionItemType
- Overrides:
- isMapTypein class- AnyFunctionType
- Returns:
- true if this FunctionItemType is a map type
 
 - 
isArrayTypepublic boolean isArrayType() Ask whether this function item type is an array type. In this case function coercion (to the array type) will never succeed.- Specified by:
- isArrayTypein interface- FunctionItemType
- Overrides:
- isArrayTypein class- AnyFunctionType
- Returns:
- true if this FunctionItemType is an array type
 
 - 
getBasicAlphaCodepublic java.lang.String getBasicAlphaCode() Get an alphabetic code representing the type, or at any rate, the nearest built-in type from which this type is derived. The codes are designed so that for any two built-in types A and B, alphaCode(A) is a prefix of alphaCode(B) if and only if A is a supertype of B.- Specified by:
- getBasicAlphaCodein interface- ItemType
- Overrides:
- getBasicAlphaCodein class- AnyFunctionType
- Returns:
- the alphacode for the nearest containing built-in type
 
 - 
isAtomizablepublic boolean isAtomizable(TypeHierarchy th) Ask whether values of this type are atomizable- Specified by:
- isAtomizablein interface- ItemType
- Overrides:
- isAtomizablein class- AnyFunctionType
- Parameters:
- th- The type hierarchy cache
- Returns:
- true if some or all instances of this type can be successfully atomized; false * if no instances of this type can be atomized
 
 - 
getDefaultPrioritypublic double getDefaultPriority() Get the default priority when this ItemType is used as an XSLT pattern- Specified by:
- getDefaultPriorityin interface- ItemType
- Overrides:
- getDefaultPriorityin class- AnyFunctionType
- Returns:
- the default priority
 
 - 
matchespublic boolean matches(Item item, TypeHierarchy th) Test whether a given item conforms to this type- Specified by:
- matchesin interface- ItemType
- Overrides:
- matchesin class- AnyFunctionType
- Parameters:
- item- The item to be tested
- th-
- Returns:
- true if the item is an instance of this type; false otherwise
 
 - 
getAritypublic int getArity() Get the arity (number of arguments) of this function type- Returns:
- the number of argument types in the function signature
 
 - 
getArgumentTypespublic SequenceType[] getArgumentTypes() Get the argument types of this map, viewed as a function- Specified by:
- getArgumentTypesin interface- FunctionItemType
- Overrides:
- getArgumentTypesin class- AnyFunctionType
- Returns:
- the list of argument types of this map, viewed as a function
 
 - 
getResultTypepublic SequenceType getResultType() Get the result type of this map, viewed as a function- Specified by:
- getResultTypein interface- FunctionItemType
- Overrides:
- getResultTypein class- AnyFunctionType
- Returns:
- the result type of this map, viewed as a function
 
 - 
toStringpublic java.lang.String toString() Produce a representation of this type name for use in error messages.- Specified by:
- toStringin interface- ItemType
- Overrides:
- toStringin class- AnyFunctionType
- Returns:
- a string representation of the type, in notation resembling but not necessarily identical to XPath syntax
 
 - 
toExportStringpublic java.lang.String toExportString() Return a string representation of this ItemType suitable for use in stylesheet export files. This differs from the result of toString() in that it will not contain any references to anonymous types. Note that it may also use the Saxon extended syntax for union types and tuple types. The default implementation returns the result of calling#toString().- Returns:
- the string representation as an instance of the XPath SequenceType construct
 
 - 
equalspublic boolean equals(java.lang.Object other) Test whether this function type equals another function type- Overrides:
- equalsin class- java.lang.Object
 
 - 
hashCodepublic int hashCode() Returns a hash code value for the object.- Overrides:
- hashCodein class- java.lang.Object
 
 - 
relationshippublic Affinity relationship(FunctionItemType other, TypeHierarchy th) Determine the relationship of one function item type to another- Specified by:
- relationshipin interface- FunctionItemType
- Overrides:
- relationshipin class- AnyFunctionType
- Returns:
- for example Affinity.SUBSUMES,Affinity.SAME_TYPE
 
 - 
explainMismatchpublic java.util.Optional<java.lang.String> explainMismatch(Item item, TypeHierarchy th) Get extra diagnostic information about why a supplied item does not conform to this item type, if available. If extra information is returned, it should be in the form of a complete sentence, minus the closing full stop. No information should be returned for obvious cases.- Parameters:
- item- the item that doesn't match this type
- th- the type hierarchy cache
- Returns:
- optionally, a message explaining why the item does not match the type
 
 - 
makeFunctionSequenceCoercerpublic Expression makeFunctionSequenceCoercer(Expression exp, RoleDiagnostic role) throws XPathException Description copied from class:AnyFunctionTypeCreate an expression whose effect is to apply function coercion to coerce a function from this type to another type- Specified by:
- makeFunctionSequenceCoercerin interface- FunctionItemType
- Overrides:
- makeFunctionSequenceCoercerin class- AnyFunctionType
- Parameters:
- exp- the expression that delivers the supplied sequence of function items (the ones in need of coercion)
- role- information for use in diagnostics
- Returns:
- the sequence of coerced functions, each on a function that calls the corresponding original function after checking the parameters
- Throws:
- XPathException
 
 
- 
 
-