|
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
SerializerContentHandler interface into this serializer.
If the serializer does not support the ContentHandler
interface, it should return null.
asContentHandler in interface SerializerIOException
public DocumentHandler asDocumentHandler()
throws IOException
SerializerDocumentHandler interface into this serializer.
If the serializer does not support the DocumentHandler
interface, it should return null.
asDocumentHandler in interface SerializerIOException
public DOMSerializer asDOMSerializer()
throws IOException
SerializerDOMSerializer interface into this serializer.
If the serializer does not support the DOMSerializer
interface, it should return null.
asDOMSerializer in interface SerializerIOException
public void attributeDecl(String eName,
String aName,
String type,
String valueDefault,
String value)
throws SAXException
attributeDecl in interface DeclHandlerSAXException
public void characters(char[] chars,
int start,
int length)
throws SAXException
characters in interface ContentHandlerSAXException
protected void characters(String text)
throws IOException
text - The text to print
IOException - An I/O exception occured while
serializing
public void comment(char[] chars,
int start,
int length)
throws SAXException
comment in interface LexicalHandlerSAXException
public void comment(String text)
throws IOException
IOException
protected ElementState content()
throws IOException
IOException - An I/O exception occured while
serializing
public void elementDecl(String name,
String model)
throws SAXException
elementDecl in interface DeclHandlerSAXExceptionpublic void endCDATA()
endCDATA in interface LexicalHandler
public void endDocument()
throws SAXException
endDocument in interface ContentHandlerSAXException - An I/O exception occured during
serializingpublic void endDTD()
endDTD in interface LexicalHandlerpublic void endEntity(String name)
endEntity in interface LexicalHandlerpublic void endNonEscaping()
public void endPrefixMapping(String prefix)
throws SAXException
endPrefixMapping in interface ContentHandlerSAXExceptionpublic 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 DeclHandlerSAXException
protected void fatalError(String message)
throws IOException
IOExceptionprotected 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 ContentHandlerSAXException
public void internalEntityDecl(String name,
String value)
throws SAXException
internalEntityDecl in interface DeclHandlerSAXExceptionprotected 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 DTDHandlerSAXException
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 ContentHandlerSAXException
public void processingInstructionIO(String target,
String code)
throws IOException
IOExceptionpublic boolean reset()
public void serialize(Document doc)
throws IOException
serialize in interface DOMSerializerdoc - The document to serialize
IOException - An I/O exception occured while
serializing
public void serialize(DocumentFragment frag)
throws IOException
serialize in interface DOMSerializerfrag - The document fragment to serialize
IOException - An I/O exception occured while
serializing
public void serialize(Element elem)
throws IOException
serialize in interface DOMSerializerelem - The element to serialize
IOException - An I/O exception occured while
serializing
protected abstract void serializeElement(Element elem)
throws IOException
elem - The element to serialize
IOException - An I/O exception occured while
serializing
protected 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 ContentHandlerpublic void setOutputByteStream(OutputStream output)
Serializer
setOutputByteStream in interface Serializerpublic void setOutputCharStream(Writer writer)
Serializer
setOutputCharStream in interface Serializerpublic void setOutputFormat(OutputFormat format)
Serializer
setOutputFormat in interface Serializerformat - The output format to use
public void skippedEntity(String name)
throws SAXException
skippedEntity in interface ContentHandlerSAXExceptionpublic void startCDATA()
startCDATA in interface LexicalHandler
public void startDocument()
throws SAXException
startDocument in interface ContentHandlerSAXException
public final void startDTD(String name,
String publicId,
String systemId)
throws SAXException
startDTD in interface LexicalHandlerSAXExceptionpublic void startEntity(String name)
startEntity in interface LexicalHandlerpublic void startNonEscaping()
public void startPrefixMapping(String prefix,
String uri)
throws SAXException
startPrefixMapping in interface ContentHandlerSAXExceptionpublic 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 DTDHandlerSAXException
|
Documentation is available at http://download.oracle.com/docs/cd/E13222_01/wls/docs91 Copyright 2005 BEA Systems Inc. |
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||