All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.saxon.evpull.package.html Maven / Gradle / Ivy











Package overview for net.sf.saxon.evpull




This package provides classes that implement a StAX-like pull pipeline in which a recieving component makes calls on a provider component to supply information from the XML stream one event at a time. The object that is supplied in response to these calls is a {@link net.sf.saxon.evpull.PullEvent}, and a component that can be invoked to deliver a sequence of these objects is a {@link net.sf.saxon.evpull.EventIterator}.

An {@link net.sf.saxon.evpull.EventIterator} is itself a {@link net.sf.saxon.evpull.PullEvent}, so an event provider may return a sequence of events in response to a single call by returning an iterator. A sequence of events containing no iterators is referred to as a flat sequence, and any sequence of events can be converted to a flat sequence by inserting an {@link net.sf.saxon.evpull.EventStackIterator} into the pipeline.

Pull processing is not used extensively in Saxon, and is generally not used at all unless explicitly requested. It can be requested, for example, by supplying a {@link net.sf.saxon.evpull.PullEventSource} object to an interface that expects an XML document to be supplied as a JAXP {@link javax.xml.transform.Source}. It is also used in XQJ when methods such as {@link javax.xml.xquery.XQDataFactory#createItemFromDocument} are used to construct an XML document from a supplied {@link javax.xml.stream.XMLStreamReader}. In such cases Saxon uses the class {@link net.sf.saxon.evpull.StaxToEventBridge} to convert StAX events to its own {@link net.sf.saxon.evpull.PullEvent} events. Conversion in the opposite direction uses the class {@link net.sf.saxon.evpull.EventToStaxBridge}.

It is possible to request pull-mode evaluation of XQuery code using the method {@link net.sf.saxon.query.XQueryExpression#iterateEvents}. This causes any document and element node constructors to be evaluated in pull mode, returning events representing start/end document/element rather than actually constructing the result tree in memory. The relevant expressions in the expression tree provide an iterateEvents() method to support this mode of execution.

A sequence of events is said to be composed if it consists entirely of items (that is, a node is passed as a single event, rather than by walking the tree); it is said to be decomposed if if consists entirely of StAX-like events. In general, the classes in this package handle sequences that mix both styles. A fully-composed sequence, however, is normally handled using the {@link net.sf.saxon.om.SequenceIterator} interface rather than by the classes in this package. The {@link net.sf.saxon.evpull.SequenceComposer} returns a full composed event stream from a decomposed or mixed stream, constructing tree fragments when necessary to achieve this; the {@link net.sf.saxon.evpull.Decomposer} does the inverse, walking any tree fragments to deliver the corresponding start-element and end-element events.

The class {@link net.sf.saxon.evpull.EventIteratorOverSequence} converts a stream of items obtained from a {@link net.sf.saxon.om.SequenceIterator} into a composed stream of {@link net.sf.saxon.evpull.PullEvent} events.

The class {@link net.sf.saxon.evpull.EventIteratorToReceiver} reads a sequence of events from a pull pipeline and outputs the same sequence of events to a push pipeline using the {@link net.sf.saxon.event.Receiver} interface.

The package {@link net.sf.saxon.pull} represents an earlier attempt at pull-mode processing in Saxon. It is retained because it provides some capabilities not yet present in this package.


Michael H. Kay
Saxonica Limited
30 July 2010





© 2015 - 2025 Weber Informatics LLC | Privacy Policy