Package net.sf.saxon.om
Class SequenceTool
java.lang.Object
net.sf.saxon.om.SequenceTool
Utility class for manipulating sequences. Some of these methods should be regarded
 as temporary scaffolding while the model is in transition.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intConstant returned by compareTo() method to indicate an indeterminate ordering between two values
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic ItemStatic method to make an Item from a Valuestatic AttributeMapConstruct an AttributeMap given a list ofAttributeInfoobjects representing the individual attributes.static ObjectconvertToJava(Item item) Convert an XPath value to a Java object.static FocusIteratorfocusTracker(SequenceIterator basis) Factory method to create a FocusIterator wrapping a supplied SequenceIteratorstatic Sequence[]Make an array of general-purpose Sequence objects with supplied contentsstatic intgetCardinality(Sequence sequence) Get the cardinality of a sequencestatic ItemTypegetItemType(Sequence sequence, TypeHierarchy th) Get the item type of the items in a sequence.static intGet the length of a sequence (the number of items it contains)static intgetLength(SequenceIterator iterator) Get the number of items in the sequence identified by aSequenceIterator.static UnicodeStringgetStringValue(Sequence sequence) Get the string value of a sequence.static UTypeGet the UType of the items in a sequence.static booleanhasLength(SequenceIterator iter, int length) Ask whether the length of a sequence is exactly Nstatic booleanisUnrepeatable(Sequence seq) static ItemGet the item at a given offset in a sequence.static GroundedValueitemOrEmpty(Item item) Helper method to convert an Item or null to a Sequencestatic Sequence[]makeSequenceArray(int length) Make an array of general-purpose Sequence objects of a given lengthstatic voidProcess a supplied value by copying it to the current output destinationstatic booleanDetermine whether two sequences have the same number of items.static StringGet the string value of a sequence.static voidsupply(SequenceIterator iter, ItemConsumer<? super Item> consumer) Supply the (remaining) items in a sequence to a consumer of itemsstatic booleansupportsGetLength(SequenceIterator iterator) Ask whether a SequenceIterator supports the capability to callgetLength()to establish the number of items in the sequence.static GroundedValuetoGroundedValue(SequenceIterator iterator) Produce a GroundedValue containing the same values as a supplied sequence.static SequencetoLazySequence(SequenceIterator iterator) Construct a sequence capable of returning the same items as an iterator, without incurring the cost of evaluating the iterator and storing all the items.static SequencetoMemoSequence(SequenceIterator iterator) Produce a Sequence containing the same values as a supplied sequence; the input is read progressively as required, and saved in a buffer as it is read in case it is needed again.
- 
Field Details- 
INDETERMINATE_ORDERINGpublic static final int INDETERMINATE_ORDERINGConstant returned by compareTo() method to indicate an indeterminate ordering between two values- See Also:
 
 
- 
- 
Constructor Details- 
SequenceToolpublic SequenceTool()
 
- 
- 
Method Details- 
toGroundedValueProduce a GroundedValue containing the same values as a supplied sequence.- Parameters:
- iterator- the supplied sequence. The iterator may or may not be consumed as a result of passing it to this method.
- Returns:
- a GroundedValue containing the same items
- Throws:
- UncheckedXPathException- if a failure occurs reading the input iterator
 
- 
toMemoSequenceProduce a Sequence containing the same values as a supplied sequence; the input is read progressively as required, and saved in a buffer as it is read in case it is needed again. But if the iterator is already backed by a grounded value, we return that value.- Parameters:
- iterator- the supplied sequence. The iterator may or may not be consumed as a result of passing it to this method.
- Returns:
- a Sequence containing the same items
- Throws:
- XPathException- if a failure occurs reading the input iterator
 
- 
toLazySequenceConstruct a sequence capable of returning the same items as an iterator, without incurring the cost of evaluating the iterator and storing all the items.- Parameters:
- iterator- the supplied sequence. The iterator may or may not be consumed as a result of passing it to this method.
- Returns:
- a Sequence containing the same items as the supplied iterator
- Throws:
- XPathException- if a failure occurs reading the input iterator
 
- 
supportsGetLengthAsk whether a SequenceIterator supports the capability to callgetLength()to establish the number of items in the sequence.- Parameters:
- iterator- the iterator we are asking about
- Returns:
- true if the iterator is a LastPositionFinderwith this capability. Note that some iterators implement this interface, but do not actually have the capability to determine the length, because they delegate to another iterator.
 
- 
getLengthGet the number of items in the sequence identified by aSequenceIterator. This method can only be used ifsupportsGetLength(SequenceIterator)has been called and returns true. The length is returned regardless of the current position of the iterator. The state of the iterator is not changed- Parameters:
- iterator- the iterator we are asking about
- Returns:
- the number of items in the sequence
- Throws:
- UnsupportedOperationException- if the iterator does not have this capability
 
- 
supplySupply the (remaining) items in a sequence to a consumer of items- Parameters:
- iter- a sequence iterator, which will be consumed by calling this method
- consumer- the consumer which will be called to process the remaining items in the sequence, in turn
- Throws:
- UncheckedXPathException- if the computation of the input sequence reports an XPathException, or if the consumer throws an XPathException
 
- 
isUnrepeatable
- 
getLengthGet the length of a sequence (the number of items it contains)- Parameters:
- sequence- the sequence
- Returns:
- the length in items
- Throws:
- XPathException- if an error occurs (due to lazy evaluation)
 
- 
hasLengthAsk whether the length of a sequence is exactly NNote: this is more efficient than counting the items and testing whether the result is N, because the sequence only needs to be read as far as the Nth item. - Parameters:
- iter- an iterator over the sequence in question (which is typically consumed)
- length- the supposed length
- Returns:
- true if and only if the length of the sequence is the supposed length
- Throws:
- XPathException- if an error is detected
 
- 
sameLengthDetermine whether two sequences have the same number of items. This is more efficient than comparing the counts, because the longer sequence is evaluated only as far as the length of the shorter sequence. The method consumes the supplied iterators.- Parameters:
- a- iterator over the first sequence
- b- iterator over the second sequence
- Returns:
- true if the lengths of the two sequences are the same
 
- 
itemAtGet the item at a given offset in a sequence. Uses zero-base indexing- Parameters:
- sequence- the input sequence
- index- the 0-based subscript
- Returns:
- the n'th item if it exists, or null otherwise
- Throws:
- UncheckedXPathException- for example if the value is a closure that needs to be evaluated, and evaluation fails
 
- 
asItemStatic method to make an Item from a Value- Parameters:
- sequence- the value to be converted
- Returns:
- null if the value is an empty sequence; or the only item in the value if it is a singleton sequence
- Throws:
- XPathException- if the supplied Sequence contains multiple items
 
- 
focusTrackerFactory method to create a FocusIterator wrapping a supplied SequenceIterator- Parameters:
- basis- the SequenceIterator to be wrapped. This must be positioned at the start.
- Returns:
- a FocusIterator that returns the same items as the supplied iterator, while tracking position() and current().
 
- 
convertToJavaConvert an XPath value to a Java object. An atomic value is returned as an instance of the best available Java class. If the item is a node, the node is "unwrapped", to return the underlying node in the original model (which might be, for example, a DOM or JDOM node).- Parameters:
- item- the item to be converted
- Returns:
- the value after conversion
- Throws:
- XPathException- if an error occurs: for example, if the XPath value is an integer and is too big to fit in a Java long
 
- 
getStringValueGet the string value of a sequence. For an item, this is same as the result of calling the XPath string() function. For a sequence of more than one item, it is the concatenation of the individual string values of the items in the sequence, space-separated.- Parameters:
- sequence- the input sequence
- Returns:
- a string representation of the items in the supplied sequence
- Throws:
- XPathException- if the sequence contains an item with no string value, for example a function item
 
- 
stringifyGet the string value of a sequence. For an item, this is same as the result of calling the XPath string() function. For a sequence of more than one item, it is the concatenation of the individual string values of the items in the sequence, space-separated.- Parameters:
- sequence- the input sequence
- Returns:
- a string representation of the items in the supplied sequence
- Throws:
- XPathException- if the sequence contains an item with no string value, for example a function item
 
- 
getItemTypeGet the item type of the items in a sequence. If the sequence is heterogeneous, the method returns the lowest common supertype. If the sequence is empty, it returns ErrorType (the type to which no instance can belong)- Parameters:
- sequence- the input sequence
- th- the Type Hierarchy cache
- Returns:
- the lowest common supertype of the types of the items in the sequence
 
- 
getUTypeGet the UType of the items in a sequence. If the sequence is heterogeneous, the method returns the lowest common supertype. If the sequence is empty, it returns ErrorType (the type to which no instance can belong)- Parameters:
- sequence- the input sequence
- Returns:
- the lowest common supertype of the types of the items in the sequence
 
- 
getCardinalityGet the cardinality of a sequence- Parameters:
- sequence- the supplied sequence
- Returns:
- the cardinality, as one of the constants StaticProperty.ALLOWS_ZERO(for an empty sequence)StaticProperty.EXACTLY_ONE(for a singleton), orStaticProperty.ALLOWS_ONE_OR_MORE(for a sequence with more than one item)
 
- 
processpublic static void process(Sequence value, Outputter output, Location locationId) throws XPathException Process a supplied value by copying it to the current output destination- Parameters:
- value- the sequence to be processed
- output- the destination for the result
- locationId- (can be set to -1 if absent) information about the location of the value, which can be resolved by reference to the PipelineConfiguration of the current output destination
- Throws:
- XPathException- if an error occurs (for example if the value is a closure that needs to be evaluated)
 
- 
makeSequenceArrayMake an array of general-purpose Sequence objects of a given length- Parameters:
- length- the length of the returned array
- Returns:
- the new array
 
- 
fromItemsMake an array of general-purpose Sequence objects with supplied contents- Parameters:
- items- the contents for the array
- Returns:
- the new array
 
- 
attributeMapFromListConstruct an AttributeMap given a list ofAttributeInfoobjects representing the individual attributes.- Parameters:
- list- the list of attributes. It is the caller's responsibility to ensure that this list contains no duplicates. The method may detect this, but is not guaranteed to do so. Calling- AttributeMap.verify()after constructing the attribute map verifies that there are no duplicates. The order of items in the input list is not necessarily preserved.
- Returns:
- an AttributeMap containing the specified attributes.
- Throws:
- IllegalArgumentException- if duplicate attributes are detected
 
- 
itemOrEmptyHelper method to convert an Item or null to a Sequence- Parameters:
- item- the item to convert
- Returns:
- the converted sequence
 
 
-