|
BEA Systems, Inc. | |||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectweblogic.apache.xml.serialize.BaseMarkupSerializer
Base class for a serializer supporting both DOM and SAX pretty serializing of XML/HTML/XHTML documents. Derives classes perform the method-specific serializing, this class provides the common serializing mechanisms.
The serializer must be initialized with the proper writer and
output format before it can be used by calling setOutputCharStream(java.io.Writer)
or setOutputByteStream(java.io.OutputStream)
for the writer and setOutputFormat(weblogic.apache.xml.serialize.OutputFormat)
for the output format.
The serializer can be reused any number of times, but cannot be used concurrently by two threads.
If an output stream is used, the encoding is taken from the output format (defaults to UTF-8). If a writer is used, make sure the writer uses the same encoding (if applies) as specified in the output format.
The serializer supports both DOM and SAX. DOM serializing is done
by calling serialize(Document)
and SAX serializing is done by firing
SAX events and using the serializer as a document handler.
This also applies to derived class.
If an I/O exception occurs while serializing, the serializer
will not throw an exception directly, but only throw it
at the end of serializing (either DOM or SAX's DocumentHandler.endDocument()
.
For elements that are not specified as whitespace preserving, the serializer will potentially break long text lines at space boundaries, indent lines, and serialize elements on separate lines. Line terminators will be regarded as spaces, and spaces at beginning of line will be stripped.
When indenting, the serializer is capable of detecting seemingly element content, and serializing these elements indented on separate lines. An element is serialized indented when it is the first or last child of an element, or immediate following or preceding another element.
Serializer
,
DOMSerializer
Field Summary | |
protected String |
_docTypePublicId
The system identifier of the document type, if known. |
protected String |
_docTypeSystemId
The system identifier of the document type, if known. |
protected EncodingInfo |
_encodingInfo
|
protected OutputFormat |
_format
The output format associated with this serializer. |
protected boolean |
_indenting
True if indenting printer. |
protected Hashtable |
_prefixes
Association between namespace URIs (keys) and prefixes (values). |
protected Printer |
_printer
The printer used for printing text parts. |
protected boolean |
_started
If the document has been started (header serialized), this flag is set to true so it's not started twice. |
protected DOMErrorImpl |
fDOMError
|
protected org.apache.xerces.dom3.DOMErrorHandler |
fDOMErrorHandler
|
protected DOMWriterFilter |
fDOMFilter
|
protected Hashtable |
fFeatures
|
protected StringBuffer |
fStrBuffer
Temporary buffer to store character data |
Constructor Summary | |
protected |
BaseMarkupSerializer(OutputFormat format)
Protected constructor can only be used by derived class. |
Method Summary | |
ContentHandler |
asContentHandler()
Return a ContentHandler interface into this serializer. |
DocumentHandler |
asDocumentHandler()
Return a DocumentHandler interface into this serializer. |
DOMSerializer |
asDOMSerializer()
|
void |
attributeDecl(String eName,
String aName,
String type,
String valueDefault,
String value)
|
void |
characters(char[] chars,
int start,
int length)
|
protected void |
characters(String text)
Called to print the text contents in the prevailing element format. |
void |
comment(char[] chars,
int start,
int length)
|
void |
comment(String text)
|
protected ElementState |
content()
Must be called by a method about to print any type of content. |
void |
elementDecl(String name,
String model)
|
void |
endCDATA()
|
void |
endDocument()
Called at the end of the document to wrap it up. |
void |
endDTD()
|
void |
endEntity(String name)
|
void |
endNonEscaping()
|
void |
endPrefixMapping(String prefix)
|
void |
endPreserving()
|
protected ElementState |
enterElementState(String namespaceURI,
String localName,
String rawName,
boolean preserveSpace)
Enter a new element state for the specified element. |
void |
externalEntityDecl(String name,
String publicId,
String systemId)
|
protected void |
fatalError(String message)
|
protected ElementState |
getElementState()
Return the state of the current element. |
protected abstract String |
getEntityRef(int ch)
Returns the suitable entity reference for this character value, or null if no such entity exists. |
protected String |
getPrefix(String namespaceURI)
Returns the namespace prefix for the specified URI. |
void |
ignorableWhitespace(char[] chars,
int start,
int length)
|
void |
internalEntityDecl(String name,
String value)
|
protected boolean |
isDocumentState()
Returns true if in the state of the document. |
protected ElementState |
leaveElementState()
Leave the current element state and return to the state of the parent element. |
protected org.apache.xerces.dom3.DOMError |
modifyDOMError(String message,
short severity,
Node node)
The method modifies global DOM error object |
void |
notationDecl(String name,
String publicId,
String systemId)
|
protected void |
prepare()
|
protected void |
printCDATAText(String text)
|
protected void |
printDoctypeURL(String url)
Print a document type public or system identifier URL. |
protected void |
printEscaped(int ch)
|
protected void |
printEscaped(String source)
Escapes a string so it may be printed as text content or attribute value. |
protected void |
printText(char[] chars,
int start,
int length,
boolean preserveSpace,
boolean unescaped)
Called to print additional text with whitespace handling. |
protected void |
printText(String text,
boolean preserveSpace,
boolean unescaped)
|
void |
processingInstruction(String target,
String code)
|
void |
processingInstructionIO(String target,
String code)
|
boolean |
reset()
|
void |
serialize(Document doc)
Serializes the DOM document using the previously specified writer and output format. |
void |
serialize(DocumentFragment frag)
Serializes the DOM document fragmnt using the previously specified writer and output format. |
void |
serialize(Element elem)
Serializes the DOM element using the previously specified writer and output format. |
protected abstract void |
serializeElement(Element elem)
Called to serializee the DOM element. |
protected void |
serializeNode(Node node)
Serialize the DOM node. |
protected void |
serializePreRoot()
Comments and PIs cannot be serialized before the root element, because the root element serializes the document type, which generally comes first. |
void |
setDocumentLocator(Locator locator)
|
void |
setOutputByteStream(OutputStream output)
Specifies an output stream to which the document should be serialized. |
void |
setOutputCharStream(Writer writer)
Specifies a writer to which the document should be serialized. |
void |
setOutputFormat(OutputFormat format)
|
void |
skippedEntity(String name)
|
void |
startCDATA()
|
void |
startDocument()
|
void |
startDTD(String name,
String publicId,
String systemId)
|
void |
startEntity(String name)
|
void |
startNonEscaping()
|
void |
startPrefixMapping(String prefix,
String uri)
|
void |
startPreserving()
|
protected void |
surrogates(int high,
int low)
|
void |
unparsedEntityDecl(String name,
String publicId,
String systemId,
String notationName)
|
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Methods inherited from interface org.xml.sax.ContentHandler |
endElement, startElement |
Methods inherited from interface org.xml.sax.DocumentHandler |
endElement, startElement |
Field Detail |
protected String _docTypePublicId
protected String _docTypeSystemId
protected EncodingInfo _encodingInfo
protected OutputFormat _format
protected boolean _indenting
protected Hashtable _prefixes
protected Printer _printer
protected boolean _started
protected final DOMErrorImpl fDOMError
protected org.apache.xerces.dom3.DOMErrorHandler fDOMErrorHandler
protected DOMWriterFilter fDOMFilter
protected Hashtable fFeatures
protected final StringBuffer fStrBuffer
Constructor Detail |
protected BaseMarkupSerializer(OutputFormat format)
setOutputCharStream(java.io.Writer)
or setOutputByteStream(java.io.OutputStream)
first
Method Detail |
public ContentHandler asContentHandler() throws IOException
Serializer
ContentHandler
interface into this serializer.
If the serializer does not support the ContentHandler
interface, it should return null.
asContentHandler
in interface Serializer
IOException
public DocumentHandler asDocumentHandler() throws IOException
Serializer
DocumentHandler
interface into this serializer.
If the serializer does not support the DocumentHandler
interface, it should return null.
asDocumentHandler
in interface Serializer
IOException
public DOMSerializer asDOMSerializer() throws IOException
Serializer
DOMSerializer
interface into this serializer.
If the serializer does not support the DOMSerializer
interface, it should return null.
asDOMSerializer
in interface Serializer
IOException
public void attributeDecl(String eName, String aName, String type, String valueDefault, String value) throws SAXException
attributeDecl
in interface DeclHandler
SAXException
public void characters(char[] chars, int start, int length) throws SAXException
characters
in interface ContentHandler
SAXException
protected void characters(String text) throws IOException
text
- The text to print
IOException
- An I/O exception occured while
serializingpublic void comment(char[] chars, int start, int length) throws SAXException
comment
in interface LexicalHandler
SAXException
public void comment(String text) throws IOException
IOException
protected ElementState content() throws IOException
IOException
- An I/O exception occured while
serializingpublic void elementDecl(String name, String model) throws SAXException
elementDecl
in interface DeclHandler
SAXException
public void endCDATA()
endCDATA
in interface LexicalHandler
public void endDocument() throws SAXException
endDocument
in interface ContentHandler
SAXException
- An I/O exception occured during
serializingpublic void endDTD()
endDTD
in interface LexicalHandler
public void endEntity(String name)
endEntity
in interface LexicalHandler
public void endNonEscaping()
public void endPrefixMapping(String prefix) throws SAXException
endPrefixMapping
in interface ContentHandler
SAXException
public void endPreserving()
protected ElementState enterElementState(String namespaceURI, String localName, String rawName, boolean preserveSpace)
public void externalEntityDecl(String name, String publicId, String systemId) throws SAXException
externalEntityDecl
in interface DeclHandler
SAXException
protected void fatalError(String message) throws IOException
IOException
protected ElementState getElementState()
protected abstract String getEntityRef(int ch)
ch
- Character value
protected String getPrefix(String namespaceURI)
namespaceURI
- The namespace URI
public void ignorableWhitespace(char[] chars, int start, int length) throws SAXException
ignorableWhitespace
in interface ContentHandler
SAXException
public void internalEntityDecl(String name, String value) throws SAXException
internalEntityDecl
in interface DeclHandler
SAXException
protected boolean isDocumentState()
protected ElementState leaveElementState()
protected org.apache.xerces.dom3.DOMError modifyDOMError(String message, short severity, Node node)
message
- severity
-
public void notationDecl(String name, String publicId, String systemId) throws SAXException
notationDecl
in interface DTDHandler
SAXException
protected void prepare() throws IOException
IOException
protected final void printCDATAText(String text) throws IOException
IOException
protected void printDoctypeURL(String url) throws IOException
printText(char[], int, int, boolean, boolean)
.
url
- The document type url to print
IOException
protected void printEscaped(int ch) throws IOException
IOException
protected void printEscaped(String source) throws IOException
source
- The string to escape
IOException
protected void printText(char[] chars, int start, int length, boolean preserveSpace, boolean unescaped) throws IOException
printText(String,boolean,boolean)
with a call to Printer.breakLine()
for each new line. If spaces are not preserved, the text is
broken at space boundaries if longer than the line width;
Multiple spaces are printed as such, but spaces at beginning
of line are removed.
preserveSpace
- Space preserving flagunescaped
- Print unescaped
IOException
protected void printText(String text, boolean preserveSpace, boolean unescaped) throws IOException
IOException
public final void processingInstruction(String target, String code) throws SAXException
processingInstruction
in interface ContentHandler
SAXException
public void processingInstructionIO(String target, String code) throws IOException
IOException
public boolean reset()
public void serialize(Document doc) throws IOException
serialize
in interface DOMSerializer
doc
- The document to serialize
IOException
- An I/O exception occured while
serializingpublic void serialize(DocumentFragment frag) throws IOException
serialize
in interface DOMSerializer
frag
- The document fragment to serialize
IOException
- An I/O exception occured while
serializingpublic void serialize(Element elem) throws IOException
serialize
in interface DOMSerializer
elem
- The element to serialize
IOException
- An I/O exception occured while
serializingprotected abstract void serializeElement(Element elem) throws IOException
elem
- The element to serialize
IOException
- An I/O exception occured while
serializingprotected void serializeNode(Node node) throws IOException
serializeElement(org.w3c.dom.Element)
.
node
- The node to serialize
IOException
- An I/O exception occured while
serializingserializeElement(org.w3c.dom.Element)
protected void serializePreRoot() throws IOException
IOException
- An I/O exception occured while
serializingpublic void setDocumentLocator(Locator locator)
setDocumentLocator
in interface ContentHandler
public void setOutputByteStream(OutputStream output)
Serializer
setOutputByteStream
in interface Serializer
public void setOutputCharStream(Writer writer)
Serializer
setOutputCharStream
in interface Serializer
public void setOutputFormat(OutputFormat format)
Serializer
setOutputFormat
in interface Serializer
format
- The output format to usepublic void skippedEntity(String name) throws SAXException
skippedEntity
in interface ContentHandler
SAXException
public void startCDATA()
startCDATA
in interface LexicalHandler
public void startDocument() throws SAXException
startDocument
in interface ContentHandler
SAXException
public final void startDTD(String name, String publicId, String systemId) throws SAXException
startDTD
in interface LexicalHandler
SAXException
public void startEntity(String name)
startEntity
in interface LexicalHandler
public void startNonEscaping()
public void startPrefixMapping(String prefix, String uri) throws SAXException
startPrefixMapping
in interface ContentHandler
SAXException
public void startPreserving()
protected final void surrogates(int high, int low) throws IOException
IOException
public void unparsedEntityDecl(String name, String publicId, String systemId, String notationName) throws SAXException
unparsedEntityDecl
in interface DTDHandler
SAXException
|
Documentation is available at http://download.oracle.com/docs/cd/E13222_01/wls/docs90 Copyright 2005 BEA Systems Inc. |
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |