net.sf.saxon.evpull.EventAnnotationStripper Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of saxon-he Show documentation
Show all versions of saxon-he Show documentation
An OSGi bundle for Saxon-HE
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2013 Saxonica Limited.
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
package net.sf.saxon.evpull;
import net.sf.saxon.om.NodeInfo;
import net.sf.saxon.trans.XPathException;
import net.sf.saxon.tree.wrapper.VirtualUntypedCopy;
import net.sf.saxon.type.Type;
/**
* This class is an EventIterator that filters a stream of pull events setting
* the type annotation on element nodes to xs:untyped and on attribute nodes to
* xs:untypedAtomic
*/
public class EventAnnotationStripper implements EventIterator {
private EventIterator base;
/**
* Create an EventAnnotationStripper
* @param base the stream of events whose type annotations are to be stripped (set to untyped)
*/
public EventAnnotationStripper(EventIterator base) {
this.base = EventStackIterator.flatten(base);
}
/**
* Get the next event in the sequence
*
* @return the next event, or null when the sequence is exhausted. Note that since an EventIterator is
* itself a PullEvent, this method may return a nested iterator.
* @throws net.sf.saxon.trans.XPathException
* if a dynamic evaluation error occurs
*/
public PullEvent next() throws XPathException {
PullEvent pe = base.next();
if (pe instanceof StartElementEvent) {
StartElementEvent see = (StartElementEvent)pe;
see.stripTypeAnnotations();
return see;
} else if (pe instanceof NodeInfo) {
// Make a virtual untyped copy of the node
switch (((NodeInfo)pe).getNodeKind()) {
case Type.ELEMENT:
case Type.ATTRIBUTE:
return VirtualUntypedCopy.makeVirtualUntypedCopy((NodeInfo)pe, (NodeInfo)pe);
default:
return pe;
}
} else {
return pe;
}
}
/**
* Determine whether the EventIterator returns a flat sequence of events, or whether it can return
* nested event iterators
*
* @return true if the next() method is guaranteed never to return an EventIterator
*/
public boolean isFlatSequence() {
return true;
}
}