38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlsave.c: Implemetation of the document serializer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * See Copyright for the status of this software.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * daniel@veillard.com
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * XHTML detection *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "-//W3C//DTD XHTML 1.0 Strict//EN"
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "-//W3C//DTD XHTML 1.0 Frameset//EN"
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd"
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "-//W3C//DTD XHTML 1.0 Transitional//EN"
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#define XHTML_NS_NAME BAD_CAST "http://www.w3.org/1999/xhtml"
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlIsXHTML:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @systemID: the system identifier
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @publicID: the public identifier
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Try to find if the document correspond to an XHTML DTD
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns 1 if true, 0 if not and -1 in case of error
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlIsXHTML(const xmlChar *systemID, const xmlChar *publicID) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (xmlStrEqual(publicID, XHTML_STRICT_PUBLIC_ID)) return(1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (xmlStrEqual(publicID, XHTML_FRAME_PUBLIC_ID)) return(1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (xmlStrEqual(publicID, XHTML_TRANS_PUBLIC_ID)) return(1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (xmlStrEqual(systemID, XHTML_STRICT_SYSTEM_ID)) return(1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (xmlStrEqual(systemID, XHTML_FRAME_SYSTEM_ID)) return(1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (xmlStrEqual(systemID, XHTML_TRANS_SYSTEM_ID)) return(1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "Unimplemented block at %s:%d\n", \
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync char indent[MAX_INDENT + 1]; /* array for indenting output */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlCharEncodingOutputFunc escape; /* used for element content */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlCharEncodingOutputFunc escapeAttr;/* used for attribute content */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Output error handlers *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveErrMemory:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @extra: extra informations
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Handle an out of memory condition
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync __xmlSimpleError(XML_FROM_OUTPUT, XML_ERR_NO_MEMORY, NULL, NULL, extra);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveErr:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @code: the error number
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @node: the location of the error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @extra: extra informations
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Handle an out of memory condition
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveErr(int code, xmlNodePtr node, const char *extra)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync __xmlSimpleError(XML_FROM_OUTPUT, code, node, msg, extra);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Special escaping routines *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncstatic unsigned char *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSerializeHexCharRef(unsigned char *out, int val) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync while (val > 0) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlEscapeEntities:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @out: a pointer to an array of bytes to store the result
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @outlen: the length of @out
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @in: a pointer to an array of unescaped UTF-8 bytes
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @inlen: the length of @in
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Take a block of UTF-8 chars in and escape them. Used when there is no
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * encoding specified.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns 0 if success, or -1 otherwise
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * The value of @inlen after return is the number of octets consumed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * if the return value is positive, else unpredictable.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * The value of @outlen after return is the number of octets consumed.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * default case, just copy !
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * We assume we have UTF-8 input.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * We could do multiple things here. Just save as a char ref
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "xmlEscapeEntities : char out of range\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Allocation and deallocation *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveCtxtInit:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: the saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Initialize a saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((ctxt->encoding == NULL) && (ctxt->escape == NULL))
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync memcpy(&ctxt->indent[i * ctxt->indent_size], xmlTreeIndentString,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ctxt->indent[ctxt->indent_nr * ctxt->indent_size] = 0;
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlFreeSaveCtxt:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Free a saving context, destroying the ouptut in any remaining buffer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlNewSaveCtxt:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Create a new saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the new structure or NULL in case of error
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ret = (xmlSaveCtxtPtr) xmlMalloc(sizeof(xmlSaveCtxt));
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return ( NULL );
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ret->handler = xmlFindCharEncodingHandler(encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ret->encoding = xmlStrdup((const xmlChar *)encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Use the options
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* Re-check this option as it may already have been set */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((ret->options & XML_SAVE_NO_EMPTY) && ! (options & XML_SAVE_NO_EMPTY)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dumping XML tree content to a simple buffer *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlAttrSerializeContent:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @attr: the attribute pointer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Serialize the attribute in the buffer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlAttrSerializeContent(xmlOutputBufferPtr buf, xmlAttrPtr attr)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* should not happen unless we have a badly built tree */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dumping XML tree content to an I/O output buffer *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxhtmlNodeDumpOutput(xmlSaveCtxtPtr ctxt, xmlNodePtr cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncstatic void xmlNodeListDumpOutput(xmlSaveCtxtPtr ctxt, xmlNodePtr cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncstatic void xmlNodeDumpOutputInternal(xmlSaveCtxtPtr ctxt, xmlNodePtr cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncvoid xmlNsListDumpOutput(xmlOutputBufferPtr buf, xmlNsPtr cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncstatic int xmlDocContentDumpOutput(xmlSaveCtxtPtr ctxt, xmlDocPtr cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlNsDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: a namespace
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump a local Namespace definition.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Should be called in the context of attributes dumps.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlNsDumpOutput(xmlOutputBufferPtr buf, xmlNsPtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->type == XML_LOCAL_NAMESPACE) && (cur->href != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* Within the context of an element attributes */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->prefix);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlBufferWriteQuotedString(buf->buffer, cur->href);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlNsListDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the first namespace
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump a list of local Namespace definitions.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Should be called in the context of attributes dumps.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlNsListDumpOutput(xmlOutputBufferPtr buf, xmlNsPtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlDtdDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @dtd: the pointer to the DTD
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump the XML document DTD, if any.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlDtdDumpOutput(xmlSaveCtxtPtr ctxt, xmlDtdPtr dtd) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)dtd->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlBufferWriteQuotedString(buf->buffer, dtd->ExternalID);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlBufferWriteQuotedString(buf->buffer, dtd->SystemID);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlBufferWriteQuotedString(buf->buffer, dtd->SystemID);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((dtd->entities == NULL) && (dtd->elements == NULL) &&
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync (dtd->attributes == NULL) && (dtd->notations == NULL) &&
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump the notations first they are not in the DTD children list
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Do this only on a standalone DTD or on the internal subset though.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((dtd->notations != NULL) && ((dtd->doc == NULL) ||
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDumpNotationTable(buf->buffer, (xmlNotationTablePtr) dtd->notations);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlAttrDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the attribute pointer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML attribute
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlAttrDumpOutput(xmlSaveCtxtPtr ctxt, xmlAttrPtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns != NULL) && (cur->ns->prefix != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->ns->prefix);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlAttrListDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the first attribute pointer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: an optional encoding string
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump a list of XML attributes
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlAttrListDumpOutput(xmlSaveCtxtPtr ctxt, xmlAttrPtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlNodeListDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the first node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML node list, recursive behaviour, children are printed too.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlNodeListDumpOutput(xmlSaveCtxtPtr ctxt, xmlNodePtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlNodeDumpOutputInternal:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the current node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML node, recursive behaviour, children are printed too.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlNodeDumpOutputInternal(xmlSaveCtxtPtr ctxt, xmlNodePtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDumpElementDecl(buf->buffer, (xmlElementPtr) cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDumpAttributeDecl(buf->buffer, (xmlAttributePtr) cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDumpEntityDecl(buf->buffer, (xmlEntityPtr) cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteEscape(buf, cur->content, ctxt->escape);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Disable escaping, needed for XSLT
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *) cur->content);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->content);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->content);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWrite(buf, end - start, (const char *)start);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)start);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns != NULL) && (cur->ns->prefix != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->ns->prefix);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (((cur->type == XML_ELEMENT_NODE) || (cur->content == NULL)) &&
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync (cur->children == NULL) && ((ctxt->options & XML_SAVE_NO_EMPTY) == 0)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->type != XML_ELEMENT_NODE) && (cur->content != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteEscape(buf, cur->content, ctxt->escape);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (ctxt->format) xmlOutputBufferWrite(buf, 1, "\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns != NULL) && (cur->ns->prefix != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->ns->prefix);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlDocContentDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlDocContentDumpOutput(xmlSaveCtxtPtr ctxt, xmlDocPtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlCharEncodingOutputFunc oldescape = ctxt->escape;
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlCharEncodingOutputFunc oldescapeAttr = ctxt->escapeAttr;
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync } else if (cur->charset != XML_CHAR_ENCODING_UTF8) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlGetCharEncodingName((xmlCharEncoding) cur->charset);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync enc = xmlParseCharEncoding((const char*) encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * we need to switch to this encoding but just for this document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * since we output the XMLDecl the conversion must be done to not
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * generate not well formed documents.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync buf->encoder = xmlFindCharEncodingHandler((const char *)encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync (const char *)encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * initialize the state, e.g. if outputting a BOM
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Save the XML declaration
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlBufferWriteQuotedString(buf->buffer, cur->version);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlBufferWriteQuotedString(buf->buffer, (xmlChar *) encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWrite(buf, 16, " standalone=\"no\"");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWrite(buf, 17, " standalone=\"yes\"");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync is_xhtml = xmlIsXHTML(dtd->SystemID, dtd->ExternalID);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Restore the state of the saving context at the end of the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Functions specific to XHTML serialization *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xhtmlIsEmpty:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @node: the node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Check if a node is an empty xhtml node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns 1 if the node is an empty node, 0 if not and -1 in case of error
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((node->ns != NULL) && (!xmlStrEqual(node->ns->href, XHTML_NS_NAME)))
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xhtmlAttrListDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the first attribute pointer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump a list of XML attributes
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxhtmlAttrListDumpOutput(xmlSaveCtxtPtr ctxt, xmlAttrPtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns == NULL) && (xmlStrEqual(cur->name, BAD_CAST "id")))
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns == NULL) && (xmlStrEqual(cur->name, BAD_CAST "name")))
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns == NULL) && (xmlStrEqual(cur->name, BAD_CAST "lang")))
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns != NULL) && (xmlStrEqual(cur->name, BAD_CAST "lang")) &&
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xhtmlNodeListDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: the XHTML document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the first node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @level: the imbrication level for indenting
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: is formatting allowed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: an optional encoding string
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML node list, recursive behaviour, children are printed too.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Note that @format = 1 provide node indenting only if xmlIndentTreeOutput = 1
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * or xmlKeepBlanksDefault(0) was called
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxhtmlNodeListDumpOutput(xmlSaveCtxtPtr ctxt, xmlNodePtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xhtmlNodeDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: the XHTML document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the current node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @level: the imbrication level for indenting
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: is formatting allowed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: an optional encoding string
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XHTML node, recursive behaviour, children are printed too.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxhtmlNodeDumpOutput(xmlSaveCtxtPtr ctxt, xmlNodePtr cur) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDumpElementDecl(buf->buffer, (xmlElementPtr) cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDumpAttributeDecl(buf->buffer, (xmlAttributePtr) cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDumpEntityDecl(buf->buffer, (xmlEntityPtr) cur);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteEscape(buf, cur->content, ctxt->escape);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Disable escaping, needed for XSLT
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *) cur->content);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->content);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->content);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (*end == ']' && *(end + 1) == ']' && *(end + 2) == '>') {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWrite(buf, end - start, (const char *)start);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)start);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns != NULL) && (cur->ns->prefix != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->ns->prefix);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * 3.1.1. Strictly Conforming Documents A.3.1.1 3/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (xmlStrcasecmp(httpequiv, BAD_CAST"Content-Type") == 0) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->type == XML_ELEMENT_NODE) && (cur->children == NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (((cur->ns == NULL) || (cur->ns->prefix == NULL)) &&
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * C.2. Empty Elements
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "<meta http-equiv=\"Content-Type\" content=\"text/html; charset=");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)ctxt->encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * C.3. Element Minimization and Empty Element Content
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns != NULL) && (cur->ns->prefix != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->ns->prefix);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "<meta http-equiv=\"Content-Type\" content=\"text/html; charset=");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)ctxt->encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->type != XML_ELEMENT_NODE) && (cur->content != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteEscape(buf, cur->content, ctxt->escape);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * This was removed due to problems with HTML processors.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * See bug #345147.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * 4.8. Script and Style elements
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync (xmlStrstr(child->content, BAD_CAST "]]>") == NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* Nothing to escape, so just output as is... */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* FIXME: Should we do something about "--" also? */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *) child->content);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* (We cannot use xhtmlNodeDumpOutput() here because
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * we wish to leave '>' unescaped!) */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* We must use a CDATA section. Unfortunately,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * this will break CSS and JavaScript when read by
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * a browser in HTML4-compliant mode. :-( */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync (const char *)start);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync (const char *)start);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((cur->ns != NULL) && (cur->ns->prefix != NULL)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->ns->prefix);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlOutputBufferWriteString(buf, (const char *)cur->name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Public entry points *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveToFd:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @fd: a file descriptor number
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: the encoding name to use or NULL
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @options: a set of xmlSaveOptions
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Create a document saving context serializing to a file descriptor
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * with the encoding and the options given.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns a new serialization context or NULL in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveToFd(int fd, const char *encoding, int options)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ret->buf = xmlOutputBufferCreateFd(fd, ret->handler);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveToFilename:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @filename: a file name or an URL
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: the encoding name to use or NULL
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @options: a set of xmlSaveOptions
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Create a document saving context serializing to a filename or possibly
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * to an URL (but this is less reliable) with the encoding and the options
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns a new serialization context or NULL in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveToFilename(const char *filename, const char *encoding, int options)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync int compression = 0; /* TODO handle compression option */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ret->buf = xmlOutputBufferCreateFilename(filename, ret->handler,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveToBuffer:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buffer: a buffer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: the encoding name to use or NULL
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @options: a set of xmlSaveOptions
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Create a document saving context serializing to a buffer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * with the encoding and the options given
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns a new serialization context or NULL in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveToBuffer(xmlBufferPtr buffer, const char *encoding, int options)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync out_buff = xmlOutputBufferCreateBuffer(buffer, handler);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveToIO:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @iowrite: an I/O write function
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ioclose: an I/O close function
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ioctx: an I/O handler
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: the encoding name to use or NULL
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @options: a set of xmlSaveOptions
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Create a document saving context serializing to a file descriptor
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * with the encoding and the options given
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns a new serialization context or NULL in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ret->buf = xmlOutputBufferCreateIO(iowrite, ioclose, ioctx, ret->handler);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveDoc:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: a document saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: a document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Save a full document to a saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * TODO: The function is not fully implemented yet as it does not return the
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * byte count but 0 instead
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the number of byte written or -1 in case of error
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveTree:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: a document saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @node: the top node of the subtree to save
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Save a subtree starting at the node parameter to a saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * TODO: The function is not fully implemented yet as it does not return the
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * byte count but 0 instead
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the number of byte written or -1 in case of error
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveFlush:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: a document saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Flush a document saving context, i.e. make sure that all bytes have
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * been output.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the number of byte written or -1 in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveClose:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: a document saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Close a document saving context, i.e. make sure that all bytes have
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * been output and free the associated data.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the number of byte written or -1 in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveSetEscape:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: a document saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @escape: the escaping function
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Set a custom escaping function to be used for text in element content
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns 0 if successful or -1 in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveSetEscape(xmlSaveCtxtPtr ctxt, xmlCharEncodingOutputFunc escape)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveSetAttrEscape:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: a document saving context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @escape: the escaping function
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Set a custom escaping function to be used for text in attribute content
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns 0 if successful or -1 in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveSetAttrEscape(xmlSaveCtxtPtr ctxt, xmlCharEncodingOutputFunc escape)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Public entry points based on buffers *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlAttrSerializeTxtContent:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @attr: the attribute node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @string: the text content
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Serialize text attribute values to an xml simple buffer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlAttrSerializeTxtContent(xmlBufferPtr buf, xmlDocPtr doc,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync while (*cur != 0) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * We assume we have UTF-8 content.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlSaveErr(XML_SAVE_NOT_UTF8, (xmlNodePtr) attr, NULL);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlSaveErr(XML_SAVE_CHAR_INVALID, (xmlNodePtr) attr, NULL);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * We could do multiple things here. Just save
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * as a char ref
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlNodeDump:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the current node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @level: the imbrication level for indenting
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: is formatting allowed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML node, recursive behaviour,children are printed too.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Note that @format = 1 provide node indenting only if xmlIndentTreeOutput = 1
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * or xmlKeepBlanksDefault(0) was called
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the number of bytes written to the buffer or -1 in case of error
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlNodeDump(xmlBufferPtr buf, xmlDocPtr doc, xmlNodePtr cur, int level,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "xmlNodeDump : node == NULL\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return (-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "xmlNodeDump : buf == NULL\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return (-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync outbuf = (xmlOutputBufferPtr) xmlMalloc(sizeof(xmlOutputBuffer));
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return (-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync memset(outbuf, 0, (size_t) sizeof(xmlOutputBuffer));
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlNodeDumpOutput(outbuf, doc, cur, level, format, NULL);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlElemDump:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @f: the FILE * for the output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the current node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML/HTML node, recursive behaviour, children are printed too.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlElemDump(FILE * f, xmlDocPtr doc, xmlNodePtr cur)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "xmlElemDump : cur == NULL\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "xmlElemDump : doc == NULL\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((doc != NULL) && (doc->type == XML_HTML_DOCUMENT_NODE)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlSaveErr(XML_ERR_INTERNAL_ERROR, cur, "HTML support not compiled in\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* LIBXML_HTML_ENABLED */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Saving functions front-ends *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlNodeDumpOutput:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: the XML buffer output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the current node
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @level: the imbrication level for indenting
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: is formatting allowed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: an optional encoding string
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML node, recursive behaviour, children are printed too.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Note that @format = 1 provide node indenting only if xmlIndentTreeOutput = 1
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * or xmlKeepBlanksDefault(0) was called
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlNodeDumpOutput(xmlOutputBufferPtr buf, xmlDocPtr doc, xmlNodePtr cur,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync is_xhtml = xmlIsXHTML(dtd->SystemID, dtd->ExternalID);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlDocDumpFormatMemoryEnc:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @out_doc: Document to generate XML text from
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc_txt_ptr: Memory pointer for allocated XML text
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc_txt_len: Length of the generated XML text
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @txt_encoding: Character encoding to use when generating XML text
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: should formatting spaces been added
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump the current DOM tree into memory using the character encoding specified
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * by the caller. Note it is up to the caller of this function to free the
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * allocated memory with xmlFree().
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Note that @format = 1 provide node indenting only if xmlIndentTreeOutput = 1
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * or xmlKeepBlanksDefault(0) was called
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlDocDumpFormatMemoryEnc(xmlDocPtr out_doc, xmlChar **doc_txt_ptr,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync doc_txt_len = &dummy; /* Continue, caller just won't get length */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* No document, no output */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Validate the encoding value, if provided.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * This logic is copied from xmlSaveFileEnc.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync conv_hdlr = xmlFindCharEncodingHandler(txt_encoding);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, (xmlNodePtr) out_doc,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((out_buff = xmlAllocOutputBuffer(conv_hdlr)) == NULL ) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync *doc_txt_ptr = xmlStrndup(out_buff->conv->content, *doc_txt_len);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync *doc_txt_ptr = xmlStrndup(out_buff->buffer->content, *doc_txt_len);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((*doc_txt_ptr == NULL) && (*doc_txt_len > 0)) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlDocDumpMemory:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @mem: OUT: the memory pointer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @size: OUT: the memory length
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document in memory and return the #xmlChar * and it's size
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * in bytes. It's up to the caller to free the memory with xmlFree().
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * The resulting byte array is zero terminated, though the last 0 is not
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * included in the returned size.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlDocDumpMemory(xmlDocPtr cur, xmlChar**mem, int *size) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDocDumpFormatMemoryEnc(cur, mem, size, NULL, 0);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlDocDumpFormatMemory:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @mem: OUT: the memory pointer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @size: OUT: the memory length
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: should formatting spaces been added
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document in memory and return the #xmlChar * and it's size.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * It's up to the caller to free the memory with xmlFree().
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Note that @format = 1 provide node indenting only if xmlIndentTreeOutput = 1
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * or xmlKeepBlanksDefault(0) was called
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlDocDumpFormatMemory(xmlDocPtr cur, xmlChar**mem, int *size, int format) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDocDumpFormatMemoryEnc(cur, mem, size, NULL, format);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlDocDumpMemoryEnc:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @out_doc: Document to generate XML text from
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc_txt_ptr: Memory pointer for allocated XML text
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @doc_txt_len: Length of the generated XML text
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @txt_encoding: Character encoding to use when generating XML text
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump the current DOM tree into memory using the character encoding specified
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * by the caller. Note it is up to the caller of this function to free the
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * allocated memory with xmlFree().
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlDocDumpMemoryEnc(xmlDocPtr out_doc, xmlChar **doc_txt_ptr,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync xmlDocDumpFormatMemoryEnc(out_doc, doc_txt_ptr, doc_txt_len,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlDocFormatDump:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @f: the FILE*
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: should formatting spaces been added
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document to an open FILE.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * returns: the number of bytes written or -1 in case of failure.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Note that @format = 1 provide node indenting only if xmlIndentTreeOutput = 1
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * or xmlKeepBlanksDefault(0) was called
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlDocFormatDump(FILE *f, xmlDocPtr cur, int format) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync "xmlDocDump : document == NULL\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlDocDump:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @f: the FILE*
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document to an open FILE.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * returns: the number of bytes written or -1 in case of failure.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveFileTo:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: an output I/O buffer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: the encoding if any assuming the I/O layer handles the trancoding
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document to an I/O buffer.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Warning ! This call xmlOutputBufferClose() on buf which is not available
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * after this call.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * returns: the number of bytes written or -1 in case of failure.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveFileTo(xmlOutputBufferPtr buf, xmlDocPtr cur, const char *encoding) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveFormatFileTo:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @buf: an output I/O buffer
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: the encoding if any assuming the I/O layer handles the trancoding
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: should formatting spaces been added
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document to an I/O buffer.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Warning ! This call xmlOutputBufferClose() on buf which is not available
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * after this call.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * returns: the number of bytes written or -1 in case of failure.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveFormatFileTo(xmlOutputBufferPtr buf, xmlDocPtr cur,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveFormatFileEnc:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @filename: the filename or URL to output
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document being saved
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: the name of the encoding to use or NULL.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: should formatting spaces be added.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document to a file or an URL.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the number of bytes written or -1 in case of error.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Note that @format = 1 provide node indenting only if xmlIndentTreeOutput = 1
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * or xmlKeepBlanksDefault(0) was called
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveFormatFileEnc( const char * filename, xmlDocPtr cur,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(-1);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (cur->compression < 0) cur->compression = xmlGetCompressMode();
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * save the content to a temp buffer.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync buf = xmlOutputBufferCreateFilename(filename, handler, cur->compression);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveFileEnc:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @filename: the filename (or URL)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @encoding: the name of an encoding (or NULL)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document, converting it to the given encoding
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * returns: the number of bytes written or -1 in case of failure.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveFileEnc(const char *filename, xmlDocPtr cur, const char *encoding) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return ( xmlSaveFormatFileEnc( filename, cur, encoding, 0 ) );
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveFormatFile:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @filename: the filename (or URL)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @format: should formatting spaces been added
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document to a file. Will use compression if
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * compiled in and enabled. If @filename is "-" the stdout file is
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * used. If @format is set then the document will be indented on output.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Note that @format = 1 provide node indenting only if xmlIndentTreeOutput = 1
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * or xmlKeepBlanksDefault(0) was called
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * returns: the number of bytes written or -1 in case of failure.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSaveFormatFile(const char *filename, xmlDocPtr cur, int format) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return ( xmlSaveFormatFileEnc( filename, cur, NULL, format ) );
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * xmlSaveFile:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @filename: the filename (or URL)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @cur: the document
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Dump an XML document to a file. Will use compression if
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * compiled in and enabled. If @filename is "-" the stdout file is
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * returns: the number of bytes written or -1 in case of failure.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(xmlSaveFormatFileEnc(filename, cur, NULL, 0));
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* LIBXML_OUTPUT_ENABLED */