Package net.sf.saxon.ma.map
Class DictionaryMap
- java.lang.Object
- 
- net.sf.saxon.ma.map.DictionaryMap
 
- 
 public class DictionaryMap extends java.lang.Object implements MapItem A simple implementation of MapItem where the strings are keys, and modification is unlikely. This implementation is used in a number of cases where it can be determined that it is suitable, for example when parsing JSON input, or when creating a fixed map to use in an options argument.
- 
- 
Constructor SummaryConstructors Constructor Description DictionaryMap()Create an empty dictionary, to which entries can be added usinginitialPut(String, GroundedValue), provided this is done before the map is exposed to the outside world.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description MapItemaddEntry(AtomicValue key, GroundedValue value)Create a new map containing the existing entries in the map plus an additional entry, without modifying the original.booleanconforms(AtomicType keyType, SequenceType valueType, TypeHierarchy th)Ask whether the map conforms to a given map typeGroundedValueget(AtomicValue key)Get an entry from the MapItemTypegetItemType(TypeHierarchy th)Get the type of the map.UTypegetKeyUType()Get the lowest common item type of the keys in the mapvoidinitialAppend(java.lang.String key, GroundedValue value)During initial construction of the map, append a value to a possibly existing key-value pairvoidinitialPut(java.lang.String key, GroundedValue value)During initial construction of the map, add a key-value pairbooleanisEmpty()Ask whether the map is emptyAtomicIterator<StringValue>keys()Get the set of all key values in the map.java.lang.Iterable<KeyValuePair>keyValuePairs()Get the set of all key-value pairs in the mapMapItemremove(AtomicValue key)Remove an entry from the mapintsize()Get the size of the map- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface net.sf.saxon.om.GroundedValueasIterable, concatenate, containsNode, materialize
 - 
Methods inherited from interface net.sf.saxon.om.ItemgetLength, head, isStreamed, iterate, reduce, subsequence
 - 
Methods inherited from interface net.sf.saxon.ma.map.MapItematomize, call, deepEquals, effectiveBooleanValue, export, getAnnotations, getArity, getDescription, getFunctionItemType, getFunctionName, getGenre, getOperandRoles, getStringValue, getStringValueCS, getTypedValue, isArray, isMap, isTrustedResultType, itemAt, makeNewContext, toShortString
 - 
Methods inherited from interface net.sf.saxon.om.SequencemakeRepeatable
 
- 
 
- 
- 
- 
Constructor Detail- 
DictionaryMappublic DictionaryMap() Create an empty dictionary, to which entries can be added usinginitialPut(String, GroundedValue), provided this is done before the map is exposed to the outside world.
 
- 
 - 
Method Detail- 
initialPutpublic void initialPut(java.lang.String key, GroundedValue value)During initial construction of the map, add a key-value pair
 - 
initialAppendpublic void initialAppend(java.lang.String key, GroundedValue value)During initial construction of the map, append a value to a possibly existing key-value pair
 - 
getpublic GroundedValue get(AtomicValue key) Get an entry from the Map
 - 
sizepublic int size() Get the size of the map
 - 
isEmptypublic boolean isEmpty() Ask whether the map is empty
 - 
keyspublic AtomicIterator<StringValue> keys() Get the set of all key values in the map.
 - 
keyValuePairspublic java.lang.Iterable<KeyValuePair> keyValuePairs() Get the set of all key-value pairs in the map- Specified by:
- keyValuePairsin interface- MapItem
- Returns:
- an iterable containing all the key-value pairs
 
 - 
addEntrypublic MapItem addEntry(AtomicValue key, GroundedValue value) Create a new map containing the existing entries in the map plus an additional entry, without modifying the original. If there is already an entry with the specified key, this entry is replaced by the new entry.
 - 
removepublic MapItem remove(AtomicValue key) Remove an entry from the map
 - 
conformspublic boolean conforms(AtomicType keyType, SequenceType valueType, TypeHierarchy th) Ask whether the map conforms to a given map type
 - 
getItemTypepublic ItemType getItemType(TypeHierarchy th) Get the type of the map. This method is used largely for diagnostics, to report the type of a map when it differs from the required type.- Specified by:
- getItemTypein interface- MapItem
- Parameters:
- th- the type hierarchy cache
- Returns:
- the type of this map
 
 - 
getKeyUTypepublic UType getKeyUType() Get the lowest common item type of the keys in the map- Specified by:
- getKeyUTypein interface- MapItem
- Returns:
- the most specific type to which all the keys belong. If the map is empty, return UType.VOID
 
 
- 
 
-