public class ForEachGroupPartitionAction extends ItemFeed
The feed is capable of handling a select expression that selects non-peer nodes (that is, one selected node that is a descendant of another). A top-level selected node is processed directly to the output receiver; a nested node is processed to create a temporary result tree, which is then appended to the output sequence when the processing of the outer selected node is complete.
| Modifier and Type | Field and Description | 
|---|---|
| protected XPathContext | bodyContext | 
| boolean | feedAppliesToWholeGroup | 
| Constructor and Description | 
|---|
| ForEachGroupPartitionAction(WatchManager watchManager,
                           ForEachGroup expression,
                           Feed result,
                           XPathContext context) | 
| Modifier and Type | Method and Description | 
|---|---|
| void | close()Finish evaluating the expression. | 
| void | endSelectedParentNode(Location locationId)Signal that the endElement event has occurred for the element whose startElement
 event caused the Watch to be activated. | 
| protected Inversion | getInversion() | 
| SequenceReceiver | getReceiver()Get a receiver to which start and end events for documents and elements can be
 written. | 
| protected void | makeBodyContext() | 
| void | open(Terminator terminator)Start evaluating the expression. | 
| void | processItem(Item<?> node)Signal that an item (other than an element) that matches the selection
 has been found. | 
| void | setInversion(Inversion inversion) | 
| Receiver | startSelectedParentNode(FleetingParentNode node,
                       Location locationId)Signal that an element (or document node) has been found that matches the selection that this
 Watch is looking for. | 
dynamicError, getContext, getExpression, getPipelineConfiguration, getResult, getTerminator, hasFailed, processItems, setExpression, setHasFailed, setPipelineConfiguration, setTerminatorprotected XPathContext bodyContext
public boolean feedAppliesToWholeGroup
public ForEachGroupPartitionAction(WatchManager watchManager, ForEachGroup expression, Feed result, XPathContext context)
public void setInversion(Inversion inversion)
protected Inversion getInversion()
public SequenceReceiver getReceiver()
ItemFeedgetReceiver in interface FeedgetReceiver in class ItemFeedpublic void open(Terminator terminator) throws XPathException
ItemFeedopen in interface Feedopen in class ItemFeedterminator - used to achieve early exitXPathException - if a dynamic error occursprotected void makeBodyContext()
public Receiver startSelectedParentNode(FleetingParentNode node, Location locationId) throws XPathException
startSelectedParentNode in interface FeedstartSelectedParentNode in class ItemFeednode - the element or document node whose start event has been matchedlocationId - the location associated with the element or document node (may be
                   the location of the instruction that created it)XPathException - if a dynamic error occurs while processing the start-element eventpublic void processItem(Item<?> node) throws XPathException
processItem in interface FeedprocessItem in class ItemFeednode - the item that was matched.XPathException - May be raised if a dynamic error occurspublic void endSelectedParentNode(Location locationId) throws XPathException
endSelectedParentNode in interface FeedendSelectedParentNode in class ItemFeedlocationId - the location of the node in the source, or of the instruction that created itValidationException - May be raised if the constraint implemented by this
                                               Watch is violated @param locationId the location of the node in the source, or of the instruction that created itXPathException - May be raised if a constraint implemented by this
                        Watch is violatedpublic void close()
           throws XPathException
ItemFeedclose in interface Feedclose in class ItemFeedXPathException - if a dynamic error occursCopyright (c) 2004-2020 Saxonica Limited. All rights reserved.