Class ToTextStream
- All Implemented Interfaces:
DOMSerializer,ExtendedContentHandler,ExtendedLexicalHandler,SerializationHandler,Serializer,ContentHandler,DTDHandler,ErrorHandler,DeclHandler,LexicalHandler
public class ToTextStream extends ToStream
-
Field Summary
Fields Modifier and Type Field Description static StringCDATA_CONTINUETo insert ]]> in a CDATA section by ending the last CDATA section with ]] and starting the next CDATA section with >static StringCDATA_DELIMITER_CLOSEThe constant "]]>"static StringCDATA_DELIMITER_OPENstatic StringDEFAULT_SAX_SERIALIZERstatic StringEMPTYSTRINGstatic StringENTITY_AMPstatic StringENTITY_CRLFstatic StringENTITY_GTstatic StringENTITY_LTstatic StringENTITY_QUOTstatic StringXML_PREFIXstatic StringXMLNS_PREFIXstatic StringXMLNS_URIstatic StringXMLVERSION10static StringXMLVERSION11Define the XML version.Fields inherited from class org.apache.xml.serializer.ToStream
m_cdataStartCalled, m_charInfo, m_disableOutputEscapingStates, m_escaping, m_inDoctype, m_ispreserve, m_isprevtext, m_lineSep, m_lineSepLen, m_lineSepUse, m_preserves, m_spaceBeforeCloseFields inherited from class org.apache.xml.serializer.SerializerBase
m_attrBuff, m_attributes, m_CdataElems, m_cdataTagOpen, m_charsBuff, m_doctypePublic, m_doctypeSystem, m_doIndent, m_elemContext, m_indentAmount, m_inEntityRef, m_inExternalDTD, m_mediatype, m_needToCallStartDocument, m_prefixMap, m_shouldNotWriteXMLHeader, m_sourceLocator, m_standaloneWasSpecified, m_StringOfCDATASections, m_tracer, m_version, m_writer, PKG_NAME, PKG_PATHFields inherited from interface org.apache.xml.serializer.ExtendedContentHandler
HTML_ATTREMPTY, HTML_ATTRURL, NO_BAD_CHARS -
Constructor Summary
Constructors Constructor Description ToTextStream()Default constructor. -
Method Summary
Modifier and Type Method Description voidaddAttribute(String name, String value)From XSLTCvoidaddAttribute(String uri, String localName, String rawName, String type, String value, boolean XSLAttribute)Adds the given attribute to the set of collected attributes , but only if there is a currently open element.voidaddUniqueAttribute(String qName, String value, int flags)Add a unique attributevoidcdata(char[] ch, int start, int length)Receive notification of cdata.voidcharacters(char[] ch, int start, int length)Receive notification of character data.voidcharacters(String characters)From XSLTCvoidcharactersRaw(char[] ch, int start, int length)If available, when the disable-output-escaping attribute is used, output raw text without escaping.voidcomment(char[] ch, int start, int length)Report an XML comment anywhere in the document.voidcomment(String data)Called when a Comment is to be constructed.voidendCDATA()Report the end of a CDATA section.voidendDocument()Receive notification of the end of a document.voidendElement(String elemName)Receive notification of the end of an element.voidendElement(String namespaceURI, String localName, String name)Receive notification of the end of an element.voidentityReference(String name)Receive notivication of a entityReference.voidflushPending()This method flushes any pending events, which can be startDocument() closing the opening tag of an element, or closing an open CDATA section.voidignorableWhitespace(char[] ch, int start, int length)Receive notification of ignorable whitespace in element content.voidnamespaceAfterStartElement(String prefix, String uri)This method is used when a prefix/uri namespace mapping is indicated after the element was started with a startElement() and before and endElement().voidprocessingInstruction(String target, String data)Receive notification of a processing instruction.protected voidstartDocumentInternal()Receive notification of the beginning of a document.voidstartElement(String elementNamespaceURI, String elementLocalName, String elementName)From XSLTCvoidstartElement(String namespaceURI, String localName, String name, Attributes atts)Receive notification of the beginning of an element.voidstartPrefixMapping(String prefix, String uri)Begin the scope of a prefix-URI Namespace mapping just before another element is about to start.booleanstartPrefixMapping(String prefix, String uri, boolean shouldFlush)Handle a prefix/uri mapping, which is associated with a startElement() that is soon to follow.Methods inherited from class org.apache.xml.serializer.ToStream
addAttributeAlways, addCdataSectionElements, attributeDecl, closeCDATA, closeStartTag, elementDecl, endDTD, endNonEscaping, endPrefixMapping, ensureAttributesNamespaceIsDeclared, escapingNotNeeded, externalEntityDecl, firePseudoAttributes, flushWriter, getIndentAmount, getOutputFormat, getOutputStream, getWriter, indent, indent, internalEntityDecl, notationDecl, outputLineSep, processAttributes, reset, serialize, setCdataSectionElements, setContentHandler, setDTDEntityExpansion, setEncoding, setEscaping, setIndentAmount, setLineSepUse, setNewLine, setOutputFormat, setOutputStream, setTransformer, setWriter, shouldIndent, skippedEntity, startCDATA, startDTD, startElement, startEntity, startNonEscaping, unparsedEntityDecl, writeAttrString, writeUTF16SurrogateMethods inherited from class org.apache.xml.serializer.SerializerBase
addAttribute, addAttributes, addXSLAttribute, asContentHandler, asDOM3Serializer, asDOMSerializer, characters, close, documentIsEmpty, endEntity, error, fatalError, fireCDATAEvent, fireCharEvent, fireCommentEvent, fireEndDoc, fireEndElem, fireEndEntity, fireEntityReference, fireEscapingEvent, fireStartDoc, fireStartElem, fireStartEntity, getDoctypePublic, getDoctypeSystem, getEncoding, getIndent, getLocalName, getMediaType, getNamespaceMappings, getNamespaceURI, getNamespaceURIFromPrefix, getOmitXMLDeclaration, getOutputProperty, getOutputPropertyDefault, getOutputPropertyNonDefault, getPrefix, getPrefixPart, getStandalone, getTransformer, getVersion, initCDATA, isCdataSection, patchName, setDoctype, setDoctypePublic, setDoctypeSystem, setDocumentLocator, setIndent, setMediaType, setNamespaceMappings, setOmitXMLDeclaration, setOutputProperty, setOutputPropertyDefault, setSourceLocator, setStandalone, setStandaloneInternal, setVersion, startDocument, warning
-
Field Details
-
CDATA_CONTINUE
To insert ]]> in a CDATA section by ending the last CDATA section with ]] and starting the next CDATA section with >- See Also:
- Constant Field Values
-
CDATA_DELIMITER_CLOSE
The constant "]]>"- See Also:
- Constant Field Values
-
CDATA_DELIMITER_OPEN
- See Also:
- Constant Field Values
-
EMPTYSTRING
- See Also:
- Constant Field Values
-
ENTITY_AMP
- See Also:
- Constant Field Values
-
ENTITY_CRLF
- See Also:
- Constant Field Values
-
ENTITY_GT
- See Also:
- Constant Field Values
-
ENTITY_LT
- See Also:
- Constant Field Values
-
ENTITY_QUOT
- See Also:
- Constant Field Values
-
XML_PREFIX
- See Also:
- Constant Field Values
-
XMLNS_PREFIX
- See Also:
- Constant Field Values
-
XMLNS_URI
- See Also:
- Constant Field Values
-
DEFAULT_SAX_SERIALIZER
-
XMLVERSION11
Define the XML version.- See Also:
- Constant Field Values
-
XMLVERSION10
- See Also:
- Constant Field Values
-
-
Constructor Details
-
ToTextStream
public ToTextStream()Default constructor.
-
-
Method Details
-
startDocumentInternal
Receive notification of the beginning of a document.The SAX parser will invoke this method only once, before any other methods in this interface or in DTDHandler (except for setDocumentLocator).
- Overrides:
startDocumentInternalin classSerializerBase- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.SAXException
-
endDocument
Receive notification of the end of a document.The SAX parser will invoke this method only once, and it will be the last method invoked during the parse. The parser shall not invoke this method until it has either abandoned parsing (because of an unrecoverable error) or reached the end of input.
- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.SAXException- See Also:
ContentHandler.startDocument()
-
startElement
public void startElement(String namespaceURI, String localName, String name, Attributes atts) throws SAXExceptionReceive notification of the beginning of an element.The Parser will invoke this method at the beginning of every element in the XML document; there will be a corresponding endElement() event for every startElement() event (even when the element is empty). All of the element's content will be reported, in order, before the corresponding endElement() event.
If the element name has a namespace prefix, the prefix will still be attached. Note that the attribute list provided will contain only attributes with explicit values (specified or defaulted): #IMPLIED attributes will be omitted.
- Specified by:
startElementin interfaceContentHandler- Overrides:
startElementin classToStream- Parameters:
namespaceURI- The Namespace URI, or the empty string if the element has no Namespace URI or if Namespace processing is not being performed.localName- The local name (without prefix), or the empty string if Namespace processing is not being performed.name- The qualified name (with prefix), or the empty string if qualified names are not available.atts- The attributes attached to the element, if any.- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.SAXException- See Also:
endElement(java.lang.String, java.lang.String, java.lang.String),AttributeList
-
endElement
Receive notification of the end of an element.The SAX parser will invoke this method at the end of every element in the XML document; there will be a corresponding startElement() event for every endElement() event (even when the element is empty).
If the element name has a namespace prefix, the prefix will still be attached to the name.
- Specified by:
endElementin interfaceContentHandler- Overrides:
endElementin classToStream- Parameters:
namespaceURI- The Namespace URI, or the empty string if the element has no Namespace URI or if Namespace processing is not being performed.localName- The local name (without prefix), or the empty string if Namespace processing is not being performed.name- The qualified name (with prefix), or the empty string if qualified names are not available.- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.SAXException
-
characters
Receive notification of character data.The Parser will call this method to report each chunk of character data. SAX parsers may return all contiguous character data in a single chunk, or they may split it into several chunks; however, all of the characters in any single event must come from the same external entity, so that the Locator provides useful information.
The application must not attempt to read from the array outside of the specified range.
Note that some parsers will report whitespace using the ignorableWhitespace() method rather than this one (validating parsers must do so).
- Specified by:
charactersin interfaceContentHandler- Overrides:
charactersin classToStream- Parameters:
ch- The characters from the XML document.start- The start position in the array.length- The number of characters to read from the array.- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.- See Also:
ignorableWhitespace(char[], int, int),Locator
-
charactersRaw
If available, when the disable-output-escaping attribute is used, output raw text without escaping.- Overrides:
charactersRawin classToStream- Parameters:
ch- The characters from the XML document.start- The start position in the array.length- The number of characters to read from the array.- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.
-
cdata
Receive notification of cdata.The Parser will call this method to report each chunk of character data. SAX parsers may return all contiguous character data in a single chunk, or they may split it into several chunks; however, all of the characters in any single event must come from the same external entity, so that the Locator provides useful information.
The application must not attempt to read from the array outside of the specified range.
Note that some parsers will report whitespace using the ignorableWhitespace() method rather than this one (validating parsers must do so).
- Overrides:
cdatain classToStream- Parameters:
ch- The characters from the XML document.start- The start position in the array.length- The number of characters to read from the array.- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.- See Also:
ignorableWhitespace(char[], int, int),Locator
-
ignorableWhitespace
Receive notification of ignorable whitespace in element content.Validating Parsers must use this method to report each chunk of ignorable whitespace (see the W3C XML 1.0 recommendation, section 2.10): non-validating parsers may also use this method if they are capable of parsing and using content models.
SAX parsers may return all contiguous whitespace in a single chunk, or they may split it into several chunks; however, all of the characters in any single event must come from the same external entity, so that the Locator provides useful information.
The application must not attempt to read from the array outside of the specified range.
- Specified by:
ignorableWhitespacein interfaceContentHandler- Overrides:
ignorableWhitespacein classToStream- Parameters:
ch- The characters from the XML document.start- The start position in the array.length- The number of characters to read from the array.- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.SAXException- See Also:
characters(char[], int, int)
-
processingInstruction
Receive notification of a processing instruction.The Parser will invoke this method once for each processing instruction found: note that processing instructions may occur before or after the main document element.
A SAX parser should never report an XML declaration (XML 1.0, section 2.8) or a text declaration (XML 1.0, section 4.3.1) using this method.
- Parameters:
target- The processing instruction target.data- The processing instruction data, or null if none was supplied.- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.SAXException
-
comment
Called when a Comment is to be constructed. Note that Xalan will normally invoke the other version of this method. %REVIEW% In fact, is this one ever needed, or was it a mistake?- Specified by:
commentin interfaceExtendedLexicalHandler- Overrides:
commentin classSerializerBase- Parameters:
data- The comment data.- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.- See Also:
ExtendedLexicalHandler.comment(String)
-
comment
Report an XML comment anywhere in the document. This callback will be used for comments inside or outside the document element, including comments in the external DTD subset (if read).- Specified by:
commentin interfaceLexicalHandler- Overrides:
commentin classToStream- Parameters:
ch- An array holding the characters in the comment.start- The starting position in the array.length- The number of characters to use from the array.- Throws:
SAXException- The application may raise an exception.
-
entityReference
Receive notivication of a entityReference.- Specified by:
entityReferencein interfaceExtendedContentHandler- Overrides:
entityReferencein classSerializerBase- Parameters:
name- non-null reference to the name of the entity.- Throws:
SAXException
-
addAttribute
public void addAttribute(String uri, String localName, String rawName, String type, String value, boolean XSLAttribute)Description copied from class:SerializerBaseAdds the given attribute to the set of collected attributes , but only if there is a currently open element. An element is currently open if a startElement() notification has occured but the start of the element has not yet been written to the output. In the stream case this means that we have not yet been forced to close the elements opening tag by another notification, such as a character notification.- Specified by:
addAttributein interfaceExtendedContentHandler- Overrides:
addAttributein classSerializerBase- Parameters:
uri- the URI of the attributelocalName- the local name of the attributerawName- the qualified name of the attributetype- the type of the attribute (probably CDATA)value- the value of the attributeXSLAttribute- true if this attribute is coming from an xsl:attriute element- See Also:
ExtendedContentHandler.addAttribute(String, String, String, String, String)
-
endCDATA
Description copied from class:ToStreamReport the end of a CDATA section.- Specified by:
endCDATAin interfaceLexicalHandler- Overrides:
endCDATAin classToStream- Throws:
SAXException- The application may raise an exception.- See Also:
LexicalHandler.endCDATA()
-
endElement
Description copied from class:ToStreamReceive notification of the end of an element.- Specified by:
endElementin interfaceExtendedContentHandler- Overrides:
endElementin classToStream- Parameters:
elemName- The element type name- Throws:
SAXException- Any SAX exception, possibly wrapping another exception.- See Also:
ExtendedContentHandler.endElement(String)
-
startElement
public void startElement(String elementNamespaceURI, String elementLocalName, String elementName) throws SAXExceptionFrom XSLTC- Specified by:
startElementin interfaceExtendedContentHandler- Overrides:
startElementin classToStream- Parameters:
elementNamespaceURI- The Namespace URI, or the empty string if the element has no Namespace URI or if Namespace processing is not being performed.elementLocalName- The local name (without prefix), or the empty string if Namespace processing is not being performed.elementName- The element type name.- Throws:
SAXException- See Also:
ContentHandler.startElement(java.lang.String, java.lang.String, java.lang.String, org.xml.sax.Attributes),ContentHandler.endElement(java.lang.String, java.lang.String, java.lang.String),AttributeList
-
characters
From XSLTC- Specified by:
charactersin interfaceExtendedContentHandler- Overrides:
charactersin classToStream- Parameters:
characters- The string of characters to process.- Throws:
SAXException
-
addAttribute
From XSLTC- Specified by:
addAttributein interfaceExtendedContentHandler- Overrides:
addAttributein classSerializerBase- Parameters:
name- the attribute's qualified namevalue- the value of the attribute
-
addUniqueAttribute
Add a unique attribute- Parameters:
qName- the fully qualified attribute name.value- the attribute valueflags- a bitwise flag- Throws:
SAXException
-
startPrefixMapping
public boolean startPrefixMapping(String prefix, String uri, boolean shouldFlush) throws SAXExceptionDescription copied from class:ToStreamHandle a prefix/uri mapping, which is associated with a startElement() that is soon to follow. Need to close any open start tag to make sure than any name space attributes due to this event are associated wih the up comming element, not the current one.- Specified by:
startPrefixMappingin interfaceExtendedContentHandler- Overrides:
startPrefixMappingin classToStream- Parameters:
prefix- The Namespace prefix being declared.uri- The Namespace URI the prefix is mapped to.shouldFlush- true if any open tags need to be closed first, this will impact which element the mapping applies to (open parent, or its up comming child)- Returns:
- returns true if the call made a change to the current namespace information, false if it did not change anything, e.g. if the prefix/namespace mapping was already in scope from before.
- Throws:
SAXException- The client may throw an exception during processing.- See Also:
ExtendedContentHandler.startPrefixMapping(java.lang.String, java.lang.String, boolean)
-
startPrefixMapping
Description copied from class:ToStreamBegin the scope of a prefix-URI Namespace mapping just before another element is about to start. This call will close any open tags so that the prefix mapping will not apply to the current element, but the up comming child.- Specified by:
startPrefixMappingin interfaceContentHandler- Overrides:
startPrefixMappingin classToStream- Parameters:
prefix- The Namespace prefix being declared.uri- The Namespace URI the prefix is mapped to.- Throws:
SAXException- The client may throw an exception during processing.- See Also:
ContentHandler.startPrefixMapping(java.lang.String, java.lang.String)
-
namespaceAfterStartElement
Description copied from class:SerializerBaseThis method is used when a prefix/uri namespace mapping is indicated after the element was started with a startElement() and before and endElement(). startPrefixMapping(prefix,uri) would be used before the startElement() call.- Specified by:
namespaceAfterStartElementin interfaceExtendedContentHandler- Overrides:
namespaceAfterStartElementin classSerializerBase- Parameters:
prefix- the URI of the namespaceuri- the prefix associated with the given URI.- Throws:
SAXException- See Also:
ExtendedContentHandler.namespaceAfterStartElement(String, String)
-
flushPending
Description copied from class:ToStreamThis method flushes any pending events, which can be startDocument() closing the opening tag of an element, or closing an open CDATA section.- Specified by:
flushPendingin interfaceSerializationHandler- Overrides:
flushPendingin classToStream- Throws:
SAXException
-