Class StreamWriterToReceiver
- java.lang.Object
- 
- net.sf.saxon.event.StreamWriterToReceiver
 
- 
- All Implemented Interfaces:
- javax.xml.stream.XMLStreamWriter
 - Direct Known Subclasses:
- BuildingStreamWriterImpl
 
 public class StreamWriterToReceiver extends java.lang.Object implements javax.xml.stream.XMLStreamWriterThis class implements the XmlStreamWriter interface, translating the events into Saxon Receiver events. The Receiver can be anything: a serializer, a schema validator, a tree builder.This class does not itself perform "namespace repairing" as defined in the interface Javadoc (also referred to as "prefix defaulting" in the StaX JSR specification). In normal use, however, the events emitted by this class are piped into a NamespaceReducerwhich performs a function very similar to namespace repairing; specifically, it ensures that when elements and attribute are generated with a given namespace URI and local name, then namespace declarations are generated automatically without any explicit need to call thewriteNamespace(String, String)method.The class will check all names, URIs, and character content for conformance against XML well-formedness rules unless the checkValuesoption is set to false.The implementation of this class is influenced not only by the Javadoc documentation of the XMLStreamWriterinterface (which is woefully inadequate), but also by the helpful but unofficial interpretation of the spec to be found at http://veithen.github.io/2009/11/01/understanding-stax.htmlProvided that the sequence of events sent to this class is legitimate, the events sent to the supplied Receivershould constitute a regular sequence as defined in the documentation of classRegularSequenceChecker.- Since:
- 9.3. Rewritten May 2015 to fix bug 2357. Further modified in 9.7.0.2 in light of the discussion of bug 2398, and the interpretation of the spec cited above.
 
- 
- 
Constructor SummaryConstructors Constructor Description StreamWriterToReceiver(Receiver receiver)Constructor.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()voidflush()javax.xml.namespace.NamespaceContextgetNamespaceContext()Return the current namespace context.java.lang.StringgetPrefix(java.lang.String uri)java.lang.ObjectgetProperty(java.lang.String name)ReceivergetReceiver()Get the Receiver to which this StreamWriterToReceiver is writing eventsbooleanisCheckValues()Ask whether names and values are to be checked for conformance with XML rulesvoidsetCheckValues(boolean check)Say whether names and values are to be checked for conformance with XML rulesvoidsetDefaultNamespace(java.lang.String uri)voidsetNamespaceContext(javax.xml.namespace.NamespaceContext context)voidsetPrefix(java.lang.String prefix, java.lang.String uri)voidwriteAttribute(java.lang.String localName, java.lang.String value)voidwriteAttribute(java.lang.String namespaceURI, java.lang.String localName, java.lang.String value)voidwriteAttribute(java.lang.String prefix, java.lang.String namespaceURI, java.lang.String localName, java.lang.String value)voidwriteCData(java.lang.String data)voidwriteCharacters(char[] text, int start, int len)voidwriteCharacters(java.lang.String text)voidwriteComment(java.lang.String data)voidwriteDefaultNamespace(java.lang.String namespaceURI)Emits a default namespace declarationvoidwriteDTD(java.lang.String dtd)voidwriteEmptyElement(java.lang.String localName)voidwriteEmptyElement(java.lang.String namespaceURI, java.lang.String localName)voidwriteEmptyElement(java.lang.String prefix, java.lang.String localName, java.lang.String namespaceURI)voidwriteEndDocument()voidwriteEndElement()voidwriteEntityRef(java.lang.String name)voidwriteNamespace(java.lang.String prefix, java.lang.String namespaceURI)Emits a namespace declaration event.voidwriteProcessingInstruction(java.lang.String target)voidwriteProcessingInstruction(java.lang.String target, java.lang.String data)voidwriteStartDocument()voidwriteStartDocument(java.lang.String version)voidwriteStartDocument(java.lang.String encoding, java.lang.String version)voidwriteStartElement(java.lang.String localName)Generate a start element event for an element in no namespace.voidwriteStartElement(java.lang.String namespaceURI, java.lang.String localName)Generate a start element event.voidwriteStartElement(java.lang.String prefix, java.lang.String localName, java.lang.String namespaceURI)Generate a start element event.
 
- 
- 
- 
Constructor Detail- 
StreamWriterToReceiverpublic StreamWriterToReceiver(Receiver receiver) Constructor. Creates a StreamWriter as a front-end to a given Receiver.- Parameters:
- receiver- the Receiver that is to receive the events generated by this StreamWriter.
 
 
- 
 - 
Method Detail- 
getReceiverpublic Receiver getReceiver() Get the Receiver to which this StreamWriterToReceiver is writing events- Returns:
- the destination Receiver
 
 - 
setCheckValuespublic void setCheckValues(boolean check) Say whether names and values are to be checked for conformance with XML rules- Parameters:
- check- true if names and values are to be checked. Default is false;
 
 - 
isCheckValuespublic boolean isCheckValues() Ask whether names and values are to be checked for conformance with XML rules- Returns:
- true if names and values are to be checked. Default is false;
 
 - 
writeStartElementpublic void writeStartElement(java.lang.String localName) throws javax.xml.stream.XMLStreamExceptionGenerate a start element event for an element in no namespace. Note: the element will be in no namespace, even ifsetDefaultNamespace(String)has been called; this is Saxon's interpretation of the intended effect of the StAX specification.- Specified by:
- writeStartElementin interface- javax.xml.stream.XMLStreamWriter
- Parameters:
- localName- local name of the tag, may not be null
- Throws:
- javax.xml.stream.XMLStreamException- if names are being checked and the name is invalid, or if an error occurs downstream
- java.lang.NullPointerException- if the supplied local name is null
 
 - 
writeStartElementpublic void writeStartElement(java.lang.String namespaceURI, java.lang.String localName) throws javax.xml.stream.XMLStreamExceptionGenerate a start element event. The name of the element is determined by the supplied namespace URI and local name. The prefix used for the element is determined by the in-scope prefixes established usingsetPrefix(String, String)and/orsetDefaultNamespace(String)if these include the specified namespace URI; otherwise the namespace will become the default namespace and there will therefore be no prefix.- Specified by:
- writeStartElementin interface- javax.xml.stream.XMLStreamWriter
- Parameters:
- namespaceURI- the namespace URI of the element name. Must not be null. A zero-length string means the element is in no namespace.
- localName- local part of the element name. Must not be null
- Throws:
- javax.xml.stream.XMLStreamException- if names are being checked and are found to be invalid, or if an error occurs downstream in the pipeline.
- java.lang.NullPointerException- if either argument is null
 
 - 
writeStartElementpublic void writeStartElement(java.lang.String prefix, java.lang.String localName, java.lang.String namespaceURI) throws javax.xml.stream.XMLStreamExceptionGenerate a start element event. The name of the element is determined by the supplied namespace URI and local name, and the prefix will be as supplied in the call.- Specified by:
- writeStartElementin interface- javax.xml.stream.XMLStreamWriter
- Parameters:
- prefix- the prefix of the element, must not be null. If the prefix is supplied as a zero-length string, the element will nave no prefix (that is, the namespace URI will become the default namespace).
- localName- local name of the element, must not be null
- namespaceURI- the uri to bind the prefix to, must not be null. If the value is a zero-length string, the element will be in no namespace; in this case any prefix is ignored.
- Throws:
- java.lang.NullPointerException- if any of the arguments is null.
- javax.xml.stream.XMLStreamException- if names are being checked and are found to be invalid, or if an error occurs downstream in the pipeline.
 
 - 
writeEmptyElementpublic void writeEmptyElement(java.lang.String namespaceURI, java.lang.String localName) throws javax.xml.stream.XMLStreamException- Specified by:
- writeEmptyElementin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeEmptyElementpublic void writeEmptyElement(java.lang.String prefix, java.lang.String localName, java.lang.String namespaceURI) throws javax.xml.stream.XMLStreamException- Specified by:
- writeEmptyElementin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeEmptyElementpublic void writeEmptyElement(java.lang.String localName) throws javax.xml.stream.XMLStreamException- Specified by:
- writeEmptyElementin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeEndElementpublic void writeEndElement() throws javax.xml.stream.XMLStreamException- Specified by:
- writeEndElementin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeEndDocumentpublic void writeEndDocument() throws javax.xml.stream.XMLStreamException- Specified by:
- writeEndDocumentin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
closepublic void close() throws javax.xml.stream.XMLStreamException- Specified by:
- closein interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
flushpublic void flush() - Specified by:
- flushin interface- javax.xml.stream.XMLStreamWriter
 
 - 
writeAttributepublic void writeAttribute(java.lang.String localName, java.lang.String value)- Specified by:
- writeAttributein interface- javax.xml.stream.XMLStreamWriter
 
 - 
writeAttributepublic void writeAttribute(java.lang.String prefix, java.lang.String namespaceURI, java.lang.String localName, java.lang.String value)- Specified by:
- writeAttributein interface- javax.xml.stream.XMLStreamWriter
 
 - 
writeAttributepublic void writeAttribute(java.lang.String namespaceURI, java.lang.String localName, java.lang.String value)- Specified by:
- writeAttributein interface- javax.xml.stream.XMLStreamWriter
 
 - 
writeNamespacepublic void writeNamespace(java.lang.String prefix, java.lang.String namespaceURI) throws javax.xml.stream.XMLStreamExceptionEmits a namespace declaration event.If the prefix argument to this method is the empty string, "xmlns", or null this method will delegate to writeDefaultNamespace. This method does not change the name of any element or attribute; its only use is to write additional or redundant namespace declarations. With this implementation of XMLStreamWriter, this method is needed only to generate namespace declarations for prefixes that do not appear in element or attribute names. If an attempt is made to generate a namespace declaration that conflicts with the prefix-uri bindings in scope for element and attribute names, an exception occurs. - Specified by:
- writeNamespacein interface- javax.xml.stream.XMLStreamWriter
- Parameters:
- prefix- the prefix to bind this namespace to
- namespaceURI- the uri to bind the prefix to
- Throws:
- java.lang.IllegalStateException- if the current state does not allow Namespace writing
- javax.xml.stream.XMLStreamException- if things go wrong
 
 - 
writeDefaultNamespacepublic void writeDefaultNamespace(java.lang.String namespaceURI) Emits a default namespace declarationThis method does not change the name of any element or attribute; its only use is to write additional or redundant namespace declarations. With this implementation of XMLStreamWriter, this method is needed only to generate namespace declarations for prefixes that do not appear in element or attribute names. If an attempt is made to generate a namespace declaration that conflicts with the prefix-uri bindings in scope for element and attribute names, an exception occurs. - Specified by:
- writeDefaultNamespacein interface- javax.xml.stream.XMLStreamWriter
- Parameters:
- namespaceURI- the uri to bind the default namespace to
- Throws:
- java.lang.IllegalStateException- if the current state does not allow Namespace writing
 
 - 
writeCommentpublic void writeComment(java.lang.String data) throws javax.xml.stream.XMLStreamException- Specified by:
- writeCommentin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeProcessingInstructionpublic void writeProcessingInstruction(java.lang.String target) throws javax.xml.stream.XMLStreamException- Specified by:
- writeProcessingInstructionin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeProcessingInstructionpublic void writeProcessingInstruction(java.lang.String target, java.lang.String data) throws javax.xml.stream.XMLStreamException- Specified by:
- writeProcessingInstructionin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeCDatapublic void writeCData(java.lang.String data) throws javax.xml.stream.XMLStreamException- Specified by:
- writeCDatain interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeDTDpublic void writeDTD(java.lang.String dtd) throws javax.xml.stream.XMLStreamException- Specified by:
- writeDTDin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeEntityRefpublic void writeEntityRef(java.lang.String name) - Specified by:
- writeEntityRefin interface- javax.xml.stream.XMLStreamWriter
 
 - 
writeStartDocumentpublic void writeStartDocument() throws javax.xml.stream.XMLStreamException- Specified by:
- writeStartDocumentin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeStartDocumentpublic void writeStartDocument(java.lang.String version) throws javax.xml.stream.XMLStreamException- Specified by:
- writeStartDocumentin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeStartDocumentpublic void writeStartDocument(java.lang.String encoding, java.lang.String version) throws javax.xml.stream.XMLStreamException- Specified by:
- writeStartDocumentin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeCharacterspublic void writeCharacters(java.lang.String text) throws javax.xml.stream.XMLStreamException- Specified by:
- writeCharactersin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
writeCharacterspublic void writeCharacters(char[] text, int start, int len) throws javax.xml.stream.XMLStreamException- Specified by:
- writeCharactersin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- javax.xml.stream.XMLStreamException
 
 - 
getPrefixpublic java.lang.String getPrefix(java.lang.String uri) - Specified by:
- getPrefixin interface- javax.xml.stream.XMLStreamWriter
 
 - 
setPrefixpublic void setPrefix(java.lang.String prefix, java.lang.String uri)- Specified by:
- setPrefixin interface- javax.xml.stream.XMLStreamWriter
 
 - 
setDefaultNamespacepublic void setDefaultNamespace(java.lang.String uri) - Specified by:
- setDefaultNamespacein interface- javax.xml.stream.XMLStreamWriter
 
 - 
setNamespaceContextpublic void setNamespaceContext(javax.xml.namespace.NamespaceContext context) - Specified by:
- setNamespaceContextin interface- javax.xml.stream.XMLStreamWriter
 
 - 
getNamespaceContextpublic javax.xml.namespace.NamespaceContext getNamespaceContext() Return the current namespace context.The specification of this method is hopelessly vague. This method returns a namespace context that contains the namespaces declared using setPrefix(String, String)calls that are in-scope at the time, overlaid on the root namespace context that was defined usingsetNamespaceContext(NamespaceContext). The namespaces bound usingsetPrefix(String, String)are copied, and are therefore unaffected by subsequent changes, but the root namespace context is not copied, because the NamespaceContext interface provides no way of doing so.- Specified by:
- getNamespaceContextin interface- javax.xml.stream.XMLStreamWriter
- Returns:
- a copy of the current namespace context.
 
 - 
getPropertypublic java.lang.Object getProperty(java.lang.String name) throws java.lang.IllegalArgumentException- Specified by:
- getPropertyin interface- javax.xml.stream.XMLStreamWriter
- Throws:
- java.lang.IllegalArgumentException
 
 
- 
 
-