Reordered files in all libs - now all includes are in "libname/include" dir - logical, isn't it? This should break compilation however.
This commit is contained in:
547
project/jni/xerces/include/xercesc/dom/DOMLSSerializer.hpp
Normal file
547
project/jni/xerces/include/xercesc/dom/DOMLSSerializer.hpp
Normal file
@@ -0,0 +1,547 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||
* (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
/*
|
||||
* $Id: DOMLSSerializer.hpp 883665 2009-11-24 11:41:38Z borisk $
|
||||
*/
|
||||
|
||||
#if !defined(XERCESC_INCLUDE_GUARD_DOMLSSERIALIZER_HPP)
|
||||
#define XERCESC_INCLUDE_GUARD_DOMLSSERIALIZER_HPP
|
||||
|
||||
/**
|
||||
*
|
||||
* DOMLSSerializer provides an API for serializing (writing) a DOM document out in
|
||||
* an XML document. The XML data is written to an output stream, the type of
|
||||
* which depends on the specific language bindings in use. During
|
||||
* serialization of XML data, namespace fixup is done when possible.
|
||||
* <p> <code>DOMLSSerializer</code> accepts any node type for serialization. For
|
||||
* nodes of type <code>Document</code> or <code>Entity</code>, well formed
|
||||
* XML will be created if possible. The serialized output for these node
|
||||
* types is either as a Document or an External Entity, respectively, and is
|
||||
* acceptable input for an XML parser. For all other types of nodes the
|
||||
* serialized form is not specified, but should be something useful to a
|
||||
* human for debugging or diagnostic purposes. Note: rigorously designing an
|
||||
* external (source) form for stand-alone node types that don't already have
|
||||
* one defined in seems a bit much to take on here.
|
||||
* <p>Within a Document or Entity being serialized, Nodes are processed as
|
||||
* follows Documents are written including an XML declaration and a DTD
|
||||
* subset, if one exists in the DOM. Writing a document node serializes the
|
||||
* entire document. Entity nodes, when written directly by
|
||||
* <code>write</code> defined in the <code>DOMLSSerializer</code> interface,
|
||||
* output the entity expansion but no namespace fixup is done. The resulting
|
||||
* output will be valid as an external entity. Entity References nodes are
|
||||
* serializes as an entity reference of the form
|
||||
* <code>"&entityName;"</code>) in the output. Child nodes (the
|
||||
* expansion) of the entity reference are ignored. CDATA sections
|
||||
* containing content characters that can not be represented in the
|
||||
* specified output encoding are handled according to the
|
||||
* "split-cdata-sections" feature.If the feature is <code>true</code>, CDATA
|
||||
* sections are split, and the unrepresentable characters are serialized as
|
||||
* numeric character references in ordinary content. The exact position and
|
||||
* number of splits is not specified. If the feature is <code>false</code>,
|
||||
* unrepresentable characters in a CDATA section are reported as errors. The
|
||||
* error is not recoverable - there is no mechanism for supplying
|
||||
* alternative characters and continuing with the serialization. All other
|
||||
* node types (DOMElement, DOMText, etc.) are serialized to their corresponding
|
||||
* XML source form.
|
||||
* <p> Within the character data of a document (outside of markup), any
|
||||
* characters that cannot be represented directly are replaced with
|
||||
* character references. Occurrences of '<' and '&' are replaced by
|
||||
* the predefined entities &lt; and &amp. The other predefined
|
||||
* entities (&gt, &apos, etc.) are not used; these characters can be
|
||||
* included directly. Any character that can not be represented directly in
|
||||
* the output character encoding is serialized as a numeric character
|
||||
* reference.
|
||||
* <p> Attributes not containing quotes are serialized in quotes. Attributes
|
||||
* containing quotes but no apostrophes are serialized in apostrophes
|
||||
* (single quotes). Attributes containing both forms of quotes are
|
||||
* serialized in quotes, with quotes within the value represented by the
|
||||
* predefined entity &quot;. Any character that can not be represented
|
||||
* directly in the output character encoding is serialized as a numeric
|
||||
* character reference.
|
||||
* <p> Within markup, but outside of attributes, any occurrence of a character
|
||||
* that cannot be represented in the output character encoding is reported
|
||||
* as an error. An example would be serializing the element
|
||||
* <LaCañada/> with the encoding="us-ascii".
|
||||
* <p> When requested by setting the <code>normalize-characters</code> feature
|
||||
* on <code>DOMLSSerializer</code>, all data to be serialized, both markup and
|
||||
* character data, is W3C Text normalized according to the rules defined in
|
||||
* . The W3C Text normalization process affects only the data as it is being
|
||||
* written; it does not alter the DOM's view of the document after
|
||||
* serialization has completed.
|
||||
* <p>Namespaces are fixed up during serialization, the serialization process
|
||||
* will verify that namespace declarations, namespace prefixes and the
|
||||
* namespace URIs associated with Elements and Attributes are consistent. If
|
||||
* inconsistencies are found, the serialized form of the document will be
|
||||
* altered to remove them. The algorithm used for doing the namespace fixup
|
||||
* while seralizing a document is a combination of the algorithms used for
|
||||
* lookupNamespaceURI and lookupPrefix. previous paragraph to be
|
||||
* defined closer here.
|
||||
* <p>Any changes made affect only the namespace prefixes and declarations
|
||||
* appearing in the serialized data. The DOM's view of the document is not
|
||||
* altered by the serialization operation, and does not reflect any changes
|
||||
* made to namespace declarations or prefixes in the serialized output.
|
||||
* <p> While serializing a document the serializer will write out
|
||||
* non-specified values (such as attributes whose <code>specified</code> is
|
||||
* <code>false</code>) if the <code>output-default-values</code> feature is
|
||||
* set to <code>true</code>. If the <code>output-default-values</code> flag
|
||||
* is set to <code>false</code> and the <code>use-abstract-schema</code>
|
||||
* feature is set to <code>true</code> the abstract schema will be used to
|
||||
* determine if a value is specified or not, if
|
||||
* <code>use-abstract-schema</code> is not set the <code>specified</code>
|
||||
* flag on attribute nodes is used to determine if attribute values should
|
||||
* be written out.
|
||||
* <p> Ref to Core spec (1.1.9, XML namespaces, 5th paragraph) entity ref
|
||||
* description about warning about unbound entity refs. Entity refs are
|
||||
* always serialized as &foo;, also mention this in the load part of
|
||||
* this spec.
|
||||
* <p> When serializing a document the DOMLSSerializer checks to see if the document
|
||||
* element in the document is a DOM Level 1 element or a DOM Level 2 (or
|
||||
* higher) element (this check is done by looking at the localName of the
|
||||
* root element). If the root element is a DOM Level 1 element then the
|
||||
* DOMLSSerializer will issue an error if a DOM Level 2 (or higher) element is
|
||||
* found while serializing. Likewise if the document element is a DOM Level
|
||||
* 2 (or higher) element and the DOMLSSerializer sees a DOM Level 1 element an
|
||||
* error is issued. Mixing DOM Level 1 elements with DOM Level 2 (or higher)
|
||||
* is not supported.
|
||||
* <p> <code>DOMLSSerializer</code>s have a number of named features that can be
|
||||
* queried or set. The name of <code>DOMLSSerializer</code> features must be valid
|
||||
* XML names. Implementation specific features (extensions) should choose an
|
||||
* implementation dependent prefix to avoid name collisions.
|
||||
* <p>Here is a list of properties that must be recognized by all
|
||||
* implementations.
|
||||
* <dl>
|
||||
* <dt><code>"normalize-characters"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[
|
||||
* optional] (default) Perform the W3C Text Normalization of the characters
|
||||
* in document as they are written out. Only the characters being written
|
||||
* are (potentially) altered. The DOM document itself is unchanged. </dd>
|
||||
* <dt>
|
||||
* <code>false</code></dt>
|
||||
* <dd>[required] do not perform character normalization. </dd>
|
||||
* </dl></dd>
|
||||
* <dt>
|
||||
* <code>"split-cdata-sections"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[required] (default)
|
||||
* Split CDATA sections containing the CDATA section termination marker
|
||||
* ']]>' or characters that can not be represented in the output
|
||||
* encoding, and output the characters using numeric character references.
|
||||
* If a CDATA section is split a warning is issued. </dd>
|
||||
* <dt><code>false</code></dt>
|
||||
* <dd>[
|
||||
* required] Signal an error if a <code>CDATASection</code> contains an
|
||||
* unrepresentable character. </dd>
|
||||
* </dl></dd>
|
||||
* <dt><code>"validation"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[
|
||||
* optional] Use the abstract schema to validate the document as it is being
|
||||
* serialized. If validation errors are found the error handler is notified
|
||||
* about the error. Setting this state will also set the feature
|
||||
* <code>use-abstract-schema</code> to <code>true</code>. </dd>
|
||||
* <dt><code>false</code></dt>
|
||||
* <dd>[
|
||||
* required] (default) Don't validate the document as it is being
|
||||
* serialized. </dd>
|
||||
* </dl></dd>
|
||||
* <dt><code>"expand-entity-references"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[
|
||||
* optional] Expand <code>EntityReference</code> nodes when serializing. </dd>
|
||||
* <dt>
|
||||
* <code>false</code></dt>
|
||||
* <dd>[required] (default) Serialize all
|
||||
* <code>EntityReference</code> nodes as XML entity references. </dd>
|
||||
* </dl></dd>
|
||||
* <dt>
|
||||
* <code>"whitespace-in-element-content"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[required] (
|
||||
* default) Output all white spaces in the document. </dd>
|
||||
* <dt><code>false</code></dt>
|
||||
* <dd>[
|
||||
* optional] Only output white space that is not within element content. The
|
||||
* implementation is expected to use the
|
||||
* <code>isWhitespaceInElementContent</code> flag on <code>Text</code> nodes
|
||||
* to determine if a text node should be written out or not. </dd>
|
||||
* </dl></dd>
|
||||
* <dt>
|
||||
* <code>"discard-default-content"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[required] (default
|
||||
* ) Use whatever information available to the implementation (i.e. XML
|
||||
* schema, DTD, the <code>specified</code> flag on <code>Attr</code> nodes,
|
||||
* and so on) to decide what attributes and content should be serialized or
|
||||
* not. Note that the <code>specified</code> flag on <code>Attr</code> nodes
|
||||
* in itself is not always reliable, it is only reliable when it is set to
|
||||
* <code>false</code> since the only case where it can be set to
|
||||
* <code>false</code> is if the attribute was created by a Level 1
|
||||
* implementation. </dd>
|
||||
* <dt><code>false</code></dt>
|
||||
* <dd>[required] Output all attributes and
|
||||
* all content. </dd>
|
||||
* </dl></dd>
|
||||
* <dt><code>"format-canonical"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[optional]
|
||||
* This formatting writes the document according to the rules specified in .
|
||||
* Setting this feature to true will set the feature "format-pretty-print"
|
||||
* to false. </dd>
|
||||
* <dt><code>false</code></dt>
|
||||
* <dd>[required] (default) Don't canonicalize the
|
||||
* output. </dd>
|
||||
* </dl></dd>
|
||||
* <dt><code>"format-pretty-print"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[optional]
|
||||
* Formatting the output by adding whitespace to produce a pretty-printed,
|
||||
* indented, human-readable form. The exact form of the transformations is
|
||||
* not specified by this specification. Setting this feature to true will
|
||||
* set the feature "format-canonical" to false. </dd>
|
||||
* <dt><code>false</code></dt>
|
||||
* <dd>[required]
|
||||
* (default) Don't pretty-print the result. </dd>
|
||||
* </dl></dd>
|
||||
* <dt><code>"http://apache.org/xml/features/dom/byte-order-mark"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>false</code></dt>
|
||||
* <dd>[optional]
|
||||
* (default) Setting this feature to true will output the correct BOM for the specified
|
||||
* encoding. </dd>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[required]
|
||||
* Don't generate a BOM. </dd>
|
||||
* </dl></dd>
|
||||
* <dt><code>"http://apache.org/xml/features/pretty-print/space-first-level-elements"</code></dt>
|
||||
* <dd>
|
||||
* <dl>
|
||||
* <dt><code>true</code></dt>
|
||||
* <dd>[optional]
|
||||
* (default) Setting this feature to true will add an extra line feed between the elements
|
||||
* that are children of the document root. </dd>
|
||||
* <dt><code>false</code></dt>
|
||||
* <dd>[required]
|
||||
* Don't add the extra line feed. </dd>
|
||||
* </dl></dd>
|
||||
* </dl>
|
||||
* <p>See also the <a href='http://www.w3.org/TR/2004/REC-DOM-Level-3-LS-20040407'>Document Object Model (DOM) Level 3 Load and Save Specification</a>.
|
||||
*
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
|
||||
|
||||
#include <xercesc/dom/DOMNode.hpp>
|
||||
#include <xercesc/dom/DOMLSSerializerFilter.hpp>
|
||||
#include <xercesc/dom/DOMErrorHandler.hpp>
|
||||
#include <xercesc/dom/DOMConfiguration.hpp>
|
||||
|
||||
XERCES_CPP_NAMESPACE_BEGIN
|
||||
|
||||
class DOMLSOutput;
|
||||
|
||||
class CDOM_EXPORT DOMLSSerializer
|
||||
{
|
||||
protected :
|
||||
// -----------------------------------------------------------------------
|
||||
// Hidden constructors
|
||||
// -----------------------------------------------------------------------
|
||||
/** @name Hidden constructors */
|
||||
//@{
|
||||
DOMLSSerializer() {};
|
||||
//@}
|
||||
private:
|
||||
// -----------------------------------------------------------------------
|
||||
// Unimplemented constructors and operators
|
||||
// -----------------------------------------------------------------------
|
||||
/** @name Unimplemented constructors and operators */
|
||||
//@{
|
||||
DOMLSSerializer(const DOMLSSerializer &);
|
||||
DOMLSSerializer & operator = (const DOMLSSerializer &);
|
||||
//@}
|
||||
|
||||
|
||||
public:
|
||||
// -----------------------------------------------------------------------
|
||||
// All constructors are hidden, just the destructor is available
|
||||
// -----------------------------------------------------------------------
|
||||
/** @name Destructor */
|
||||
//@{
|
||||
/**
|
||||
* Destructor
|
||||
*
|
||||
*/
|
||||
virtual ~DOMLSSerializer() {};
|
||||
//@}
|
||||
|
||||
// -----------------------------------------------------------------------
|
||||
// Virtual DOMLSSerializer interface
|
||||
// -----------------------------------------------------------------------
|
||||
/** @name Functions introduced in DOM Level 3 */
|
||||
//@{
|
||||
// -----------------------------------------------------------------------
|
||||
// Feature methods
|
||||
// -----------------------------------------------------------------------
|
||||
/**
|
||||
* The DOMConfiguration object used by the LSSerializer when serializing a DOM node.
|
||||
*
|
||||
* In addition to the parameters recognized in on the <code>DOMConfiguration</code>
|
||||
* interface defined in [DOM Level 3 Core], the <code>DOMConfiguration</code> objects
|
||||
* for <code>DOMLSSerializer</code> add or modify the following parameters:
|
||||
*
|
||||
* "canonical-form"
|
||||
* true [optional]
|
||||
* Writes the document according to the rules specified in [Canonical XML]. In addition to
|
||||
* the behavior described in "canonical-form" [DOM Level 3 Core], setting this parameter to
|
||||
* true will set the parameters "format-pretty-print", "discard-default-content", and
|
||||
* "xml-declaration", to false. Setting one of those parameters to true will set this
|
||||
* parameter to false. Serializing an XML 1.1 document when "canonical-form" is true will
|
||||
* generate a fatal error.
|
||||
* false [required] (default)
|
||||
* Do not canonicalize the output.
|
||||
*
|
||||
* "discard-default-content"
|
||||
* true [required] (default)
|
||||
* Use the DOMAttr::getSpecified attribute to decide what attributes should be discarded.
|
||||
* Note that some implementations might use whatever information available to the implementation
|
||||
* (i.e. XML schema, DTD, the DOMAttr::getSpecified attribute, and so on) to determine what
|
||||
* attributes and content to discard if this parameter is set to true.
|
||||
* false [required]
|
||||
* Keep all attributes and all content.
|
||||
*
|
||||
* "format-pretty-print"
|
||||
* true [optional]
|
||||
* Formatting the output by adding whitespace to produce a pretty-printed, indented,
|
||||
* human-readable form. The exact form of the transformations is not specified by this specification.
|
||||
* Pretty-printing changes the content of the document and may affect the validity of the document,
|
||||
* validating implementations should preserve validity.
|
||||
* false [required] (default)
|
||||
* Don't pretty-print the result.
|
||||
*
|
||||
* "ignore-unknown-character-denormalizations"
|
||||
* true [required] (default)
|
||||
* If, while verifying full normalization when [XML 1.1] is supported, a character is encountered
|
||||
* for which the normalization properties cannot be determined, then raise a "unknown-character-denormalization"
|
||||
* warning (instead of raising an error, if this parameter is not set) and ignore any possible
|
||||
* denormalizations caused by these characters.
|
||||
* false [optional]
|
||||
* Report a fatal error if a character is encountered for which the processor cannot determine the
|
||||
* normalization properties.
|
||||
*
|
||||
* "normalize-characters"
|
||||
* This parameter is equivalent to the one defined by <code>DOMConfiguration</code> in [DOM Level 3 Core].
|
||||
* Unlike in the Core, the default value for this parameter is true. While DOM implementations are not
|
||||
* required to support fully normalizing the characters in the document according to appendix E of [XML 1.1],
|
||||
* this parameter must be activated by default if supported.
|
||||
*
|
||||
* "xml-declaration"
|
||||
* true [required] (default)
|
||||
* If a DOMDocument, DOMElement, or DOMEntity node is serialized, the XML declaration, or text declaration,
|
||||
* should be included. The version (DOMDocument::xmlVersion if the document is a Level 3 document and the
|
||||
* version is non-null, otherwise use the value "1.0"), and the output encoding (see DOMLSSerializer::write
|
||||
* for details on how to find the output encoding) are specified in the serialized XML declaration.
|
||||
* false [required]
|
||||
* Do not serialize the XML and text declarations. Report a "xml-declaration-needed" warning if this will
|
||||
* cause problems (i.e. the serialized data is of an XML version other than [XML 1.0], or an encoding would
|
||||
* be needed to be able to re-parse the serialized data).
|
||||
*
|
||||
* "error-handler"
|
||||
* Contains a DOMErrorHandler object. If an error is encountered in the document, the implementation will call back
|
||||
* the DOMErrorHandler registered using this parameter. The implementation may provide a default DOMErrorHandler
|
||||
* object. When called, DOMError::relatedData will contain the closest node to where the error occurred.
|
||||
* If the implementation is unable to determine the node where the error occurs, DOMError::relatedData will contain
|
||||
* the DOMDocument node. Mutations to the document from within an error handler will result in implementation
|
||||
* dependent behavior.
|
||||
*
|
||||
* @return The pointer to the configuration object.
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
virtual DOMConfiguration* getDomConfig() = 0;
|
||||
|
||||
// -----------------------------------------------------------------------
|
||||
// Setter methods
|
||||
// -----------------------------------------------------------------------
|
||||
/**
|
||||
* The end-of-line sequence of characters to be used in the XML being
|
||||
* written out. The only permitted values are these:
|
||||
* <dl>
|
||||
* <dt><code>null</code></dt>
|
||||
* <dd>
|
||||
* Use a default end-of-line sequence. DOM implementations should choose
|
||||
* the default to match the usual convention for text files in the
|
||||
* environment being used. Implementations must choose a default
|
||||
* sequence that matches one of those allowed by 2.11 "End-of-Line
|
||||
* Handling". However, Xerces-C++ always uses LF when this
|
||||
* property is set to <code>null</code> since otherwise automatic
|
||||
* translation of LF to CR-LF on Windows for text files would
|
||||
* result in such files containing CR-CR-LF. If you need Windows-style
|
||||
* end of line sequences in your output, consider writing to a file
|
||||
* opened in text mode or explicitly set this property to CR-LF.</dd>
|
||||
* <dt>CR</dt>
|
||||
* <dd>The carriage-return character (\#xD).</dd>
|
||||
* <dt>CR-LF</dt>
|
||||
* <dd> The
|
||||
* carriage-return and line-feed characters (\#xD \#xA). </dd>
|
||||
* <dt>LF</dt>
|
||||
* <dd> The line-feed
|
||||
* character (\#xA). </dd>
|
||||
* </dl>
|
||||
* <br>The default value for this attribute is <code>null</code>.
|
||||
*
|
||||
* @param newLine The end-of-line sequence of characters to be used.
|
||||
* @see getNewLine
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
virtual void setNewLine(const XMLCh* const newLine) = 0;
|
||||
|
||||
/**
|
||||
* When the application provides a filter, the serializer will call out
|
||||
* to the filter before serializing each Node. Attribute nodes are never
|
||||
* passed to the filter. The filter implementation can choose to remove
|
||||
* the node from the stream or to terminate the serialization early.
|
||||
*
|
||||
* @param filter The writer filter to be used.
|
||||
* @see getFilter
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
virtual void setFilter(DOMLSSerializerFilter *filter) = 0;
|
||||
|
||||
// -----------------------------------------------------------------------
|
||||
// Getter methods
|
||||
// -----------------------------------------------------------------------
|
||||
/**
|
||||
* Return the end-of-line sequence of characters to be used in the XML being
|
||||
* written out.
|
||||
*
|
||||
* @return The end-of-line sequence of characters to be used.
|
||||
* @see setNewLine
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
virtual const XMLCh* getNewLine() const = 0;
|
||||
|
||||
/**
|
||||
* Return the WriterFilter used.
|
||||
*
|
||||
* @return The writer filter used.
|
||||
* @see setFilter
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
virtual DOMLSSerializerFilter* getFilter() const = 0;
|
||||
|
||||
// -----------------------------------------------------------------------
|
||||
// Write methods
|
||||
// -----------------------------------------------------------------------
|
||||
/**
|
||||
* Write out the specified node as described above in the description of
|
||||
* <code>DOMLSSerializer</code>. Writing a Document or Entity node produces a
|
||||
* serialized form that is well formed XML. Writing other node types
|
||||
* produces a fragment of text in a form that is not fully defined by
|
||||
* this document, but that should be useful to a human for debugging or
|
||||
* diagnostic purposes.
|
||||
*
|
||||
* @param nodeToWrite The <code>Document</code> or <code>Entity</code> node to
|
||||
* be written. For other node types, something sensible should be
|
||||
* written, but the exact serialized form is not specified.
|
||||
* @param destination The destination for the data to be written.
|
||||
* @return Returns <code>true</code> if <code>node</code> was
|
||||
* successfully serialized and <code>false</code> in case a failure
|
||||
* occured and the failure wasn't canceled by the error handler.
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
virtual bool write(const DOMNode* nodeToWrite,
|
||||
DOMLSOutput* const destination) = 0;
|
||||
|
||||
/**
|
||||
* Write out the specified node as described above in the description of
|
||||
* <code>DOMLSSerializer</code>. Writing a Document or Entity node produces a
|
||||
* serialized form that is well formed XML. Writing other node types
|
||||
* produces a fragment of text in a form that is not fully defined by
|
||||
* this document, but that should be useful to a human for debugging or
|
||||
* diagnostic purposes.
|
||||
*
|
||||
* @param nodeToWrite The <code>Document</code> or <code>Entity</code> node to
|
||||
* be written. For other node types, something sensible should be
|
||||
* written, but the exact serialized form is not specified.
|
||||
* @param uri The destination for the data to be written.
|
||||
* @return Returns <code>true</code> if <code>node</code> was
|
||||
* successfully serialized and <code>false</code> in case a failure
|
||||
* occured and the failure wasn't canceled by the error handler.
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
virtual bool writeToURI(const DOMNode* nodeToWrite,
|
||||
const XMLCh* uri) = 0;
|
||||
/**
|
||||
* Serialize the specified node as described above in the description of
|
||||
* <code>DOMLSSerializer</code>. The result of serializing the node is
|
||||
* returned as a string. Writing a Document or Entity node produces a
|
||||
* serialized form that is well formed XML. Writing other node types
|
||||
* produces a fragment of text in a form that is not fully defined by
|
||||
* this document, but that should be useful to a human for debugging or
|
||||
* diagnostic purposes.
|
||||
*
|
||||
* @param nodeToWrite The node to be written.
|
||||
* @param manager The memory manager to be used to allocate the result string.
|
||||
* If NULL is used, the memory manager used to construct the serializer will
|
||||
* be used.
|
||||
* @return Returns the serialized data, or <code>null</code> in case a
|
||||
* failure occured and the failure wasn't canceled by the error
|
||||
* handler. The returned string is always in UTF-16.
|
||||
* The encoding information available in DOMLSSerializer is ignored in writeToString().
|
||||
* @since DOM Level 3
|
||||
*/
|
||||
virtual XMLCh* writeToString(const DOMNode* nodeToWrite, MemoryManager* manager = NULL) = 0;
|
||||
|
||||
//@}
|
||||
|
||||
// -----------------------------------------------------------------------
|
||||
// Non-standard Extension
|
||||
// -----------------------------------------------------------------------
|
||||
/** @name Non-standard Extension */
|
||||
//@{
|
||||
/**
|
||||
* Called to indicate that this Writer is no longer in use
|
||||
* and that the implementation may relinquish any resources associated with it.
|
||||
*
|
||||
* Access to a released object will lead to unexpected result.
|
||||
*/
|
||||
virtual void release() = 0;
|
||||
//@}
|
||||
|
||||
|
||||
};
|
||||
|
||||
XERCES_CPP_NAMESPACE_END
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user