1
0
mirror of https://gitlab.gnome.org/GNOME/libxml2.git synced 2025-10-23 01:52:48 +03:00

Revert "tree: Allocate XML namespace statically"

This reverts commit 2840e33c5e.
This commit is contained in:
Nick Wellnhofer
2024-03-17 16:23:31 +01:00
parent fb1e63025b
commit 047ea3ecb3
6 changed files with 199 additions and 85 deletions

4
SAX2.c
View File

@@ -812,6 +812,10 @@ xmlSAX2StartDocument(void *ctx)
doc->dict = ctxt->dict; doc->dict = ctxt->dict;
xmlDictReference(doc->dict); xmlDictReference(doc->dict);
} }
if (xmlTreeEnsureXMLDecl(doc) == NULL) {
xmlSAX2ErrMemory(ctxt);
return;
}
} }
if ((ctxt->myDoc != NULL) && (ctxt->myDoc->URL == NULL) && if ((ctxt->myDoc != NULL) && (ctxt->myDoc->URL == NULL) &&
(ctxt->input != NULL) && (ctxt->input->filename != NULL)) { (ctxt->input != NULL) && (ctxt->input->filename != NULL)) {

View File

@@ -101,10 +101,6 @@ xmlNsCheckScope(xmlNodePtr node, xmlNsPtr ns)
(node->type != XML_XINCLUDE_START)) (node->type != XML_XINCLUDE_START))
return(-2); return(-2);
/* xml namespace */
if (xmlStrEqual(ns->prefix, BAD_CAST "xml"))
return(1);
while ((node != NULL) && while ((node != NULL) &&
((node->type == XML_ELEMENT_NODE) || ((node->type == XML_ELEMENT_NODE) ||
(node->type == XML_ATTRIBUTE_NODE) || (node->type == XML_ATTRIBUTE_NODE) ||
@@ -123,7 +119,14 @@ xmlNsCheckScope(xmlNodePtr node, xmlNsPtr ns)
} }
node = node->parent; node = node->parent;
} }
/* the xml namespace may be declared on the document node */
if ((node != NULL) &&
((node->type == XML_DOCUMENT_NODE) ||
(node->type == XML_HTML_DOCUMENT_NODE))) {
xmlNsPtr oldNs = ((xmlDocPtr) node)->oldNs;
if (oldNs == ns)
return(1);
}
return(-3); return(-3);
} }

View File

@@ -9,8 +9,8 @@
XML_HIDDEN extern int XML_HIDDEN extern int
__xmlRegisterCallbacks; __xmlRegisterCallbacks;
XML_HIDDEN extern xmlNsPtr XML_HIDDEN xmlNsPtr
xmlXmlNamespace; xmlTreeEnsureXMLDecl(xmlDocPtr doc);
XML_HIDDEN int XML_HIDDEN int
xmlNodeParseContent(xmlNodePtr node, const xmlChar *content, int len); xmlNodeParseContent(xmlNodePtr node, const xmlChar *content, int len);

View File

@@ -68,14 +68,14 @@ testBalancedChunk(void) {
int err = 0; int err = 0;
ret = xmlParseBalancedChunkMemory(NULL, NULL, NULL, 0, ret = xmlParseBalancedChunkMemory(NULL, NULL, NULL, 0,
BAD_CAST "start <xml:node>abc</xml:node> end", &list); BAD_CAST "start <node xml:lang='en'>abc</node> end", &list);
if ((ret != XML_ERR_OK) || if ((ret != XML_ERR_OK) ||
(list == NULL) || (list == NULL) ||
((elem = list->next) == NULL) || ((elem = list->next) == NULL) ||
(elem->type != XML_ELEMENT_NODE) || (elem->type != XML_ELEMENT_NODE) ||
(elem->ns == NULL) || (elem->nsDef == NULL) ||
(!xmlStrEqual(elem->ns->href, XML_XML_NAMESPACE))) { (!xmlStrEqual(elem->nsDef->href, XML_XML_NAMESPACE))) {
fprintf(stderr, "xmlParseBalancedChunkMemory failed\n"); fprintf(stderr, "xmlParseBalancedChunkMemory failed\n");
err = 1; err = 1;
} }

229
tree.c
View File

@@ -82,16 +82,6 @@ const xmlChar xmlStringComment[] = { 'c', 'o', 'm', 'm', 'e', 'n', 't', 0 };
static int xmlCompressMode = 0; static int xmlCompressMode = 0;
static const xmlNs xmlXmlNamespaceStruct = {
NULL,
XML_NAMESPACE_DECL,
XML_XML_NAMESPACE,
BAD_CAST "xml",
NULL,
NULL
};
xmlNsPtr xmlXmlNamespace = (xmlNsPtr) &xmlXmlNamespaceStruct;
#define IS_STR_XML(str) ((str != NULL) && (str[0] == 'x') && \ #define IS_STR_XML(str) ((str != NULL) && (str[0] == 'x') && \
(str[1] == 'm') && (str[2] == 'l') && (str[3] == 0)) (str[1] == 'm') && (str[2] == 'l') && (str[3] == 0))
@@ -3944,14 +3934,14 @@ xmlCopyPropInternal(xmlDocPtr doc, xmlNodePtr target, xmlAttrPtr cur) {
if ((cur->ns != NULL) && (target != NULL)) { if ((cur->ns != NULL) && (target != NULL)) {
xmlNsPtr ns; xmlNsPtr ns;
ns = xmlSearchNs(NULL, target, cur->ns->prefix); ns = xmlSearchNs(target->doc, target, cur->ns->prefix);
if (ns == NULL) { if (ns == NULL) {
/* /*
* Humm, we are copying an element whose namespace is defined * Humm, we are copying an element whose namespace is defined
* out of the new tree scope. Search it in the original tree * out of the new tree scope. Search it in the original tree
* and add it at the top of the new tree * and add it at the top of the new tree
*/ */
ns = xmlSearchNs(NULL, cur->parent, cur->ns->prefix); ns = xmlSearchNs(cur->doc, cur->parent, cur->ns->prefix);
if (ns != NULL) { if (ns != NULL) {
xmlNodePtr root = target; xmlNodePtr root = target;
xmlNodePtr pred = NULL; xmlNodePtr pred = NULL;
@@ -3982,7 +3972,7 @@ xmlCopyPropInternal(xmlDocPtr doc, xmlNodePtr target, xmlAttrPtr cur) {
* we are in trouble: we need a new reconciled namespace. * we are in trouble: we need a new reconciled namespace.
* This is expensive * This is expensive
*/ */
ret->ns = xmlNewReconciledNs(NULL, target, cur->ns); ret->ns = xmlNewReconciledNs(target->doc, target, cur->ns);
if (ret->ns == NULL) if (ret->ns == NULL)
goto error; goto error;
} }
@@ -4217,7 +4207,7 @@ xmlStaticCopyNode(xmlNodePtr node, xmlDocPtr doc, xmlNodePtr parent,
if ((node->type == XML_ELEMENT_NODE) && (node->ns != NULL)) { if ((node->type == XML_ELEMENT_NODE) && (node->ns != NULL)) {
xmlNsPtr ns; xmlNsPtr ns;
ns = xmlSearchNs(NULL, ret, node->ns->prefix); ns = xmlSearchNs(doc, ret, node->ns->prefix);
if (ns == NULL) { if (ns == NULL) {
/* /*
* Humm, we are copying an element whose namespace is defined * Humm, we are copying an element whose namespace is defined
@@ -4227,14 +4217,14 @@ xmlStaticCopyNode(xmlNodePtr node, xmlDocPtr doc, xmlNodePtr parent,
* TODO: Searching the original tree seems unnecessary. We * TODO: Searching the original tree seems unnecessary. We
* already have a namespace URI. * already have a namespace URI.
*/ */
ns = xmlSearchNs(NULL, node, node->ns->prefix); ns = xmlSearchNs(node->doc, node, node->ns->prefix);
if (ns != NULL) { if (ns != NULL) {
xmlNodePtr root = ret; xmlNodePtr root = ret;
while (root->parent != NULL) root = root->parent; while (root->parent != NULL) root = root->parent;
ret->ns = xmlNewNs(root, ns->href, ns->prefix); ret->ns = xmlNewNs(root, ns->href, ns->prefix);
} else { } else {
ret->ns = xmlNewReconciledNs(NULL, ret, node->ns); ret->ns = xmlNewReconciledNs(doc, ret, node->ns);
} }
if (ret->ns == NULL) if (ret->ns == NULL)
goto error; goto error;
@@ -5065,7 +5055,9 @@ xmlNodeSetLang(xmlNodePtr cur, const xmlChar *lang) {
default: default:
return; return;
} }
ns = xmlXmlNamespace; ns = xmlSearchNsByHref(cur->doc, cur, XML_XML_NAMESPACE);
if (ns == NULL)
return;
xmlSetNsProp(cur, ns, BAD_CAST "lang", lang); xmlSetNsProp(cur, ns, BAD_CAST "lang", lang);
} }
#endif /* LIBXML_TREE_ENABLED */ #endif /* LIBXML_TREE_ENABLED */
@@ -5117,7 +5109,9 @@ xmlNodeSetSpacePreserve(xmlNodePtr cur, int val) {
default: default:
return; return;
} }
ns = xmlXmlNamespace; ns = xmlSearchNsByHref(cur->doc, cur, XML_XML_NAMESPACE);
if (ns == NULL)
return;
switch (val) { switch (val) {
case 0: case 0:
xmlSetNsProp(cur, ns, BAD_CAST "space", BAD_CAST "default"); xmlSetNsProp(cur, ns, BAD_CAST "space", BAD_CAST "default");
@@ -5252,7 +5246,9 @@ xmlNodeSetBase(xmlNodePtr cur, const xmlChar* uri) {
return(-1); return(-1);
} }
ns = xmlXmlNamespace; ns = xmlSearchNsByHref(cur->doc, cur, XML_XML_NAMESPACE);
if (ns == NULL)
return(-1);
fixed = xmlPathToURI(uri); fixed = xmlPathToURI(uri);
if (fixed == NULL) if (fixed == NULL)
return(-1); return(-1);
@@ -5872,6 +5868,43 @@ xmlGetNsList(const xmlDoc *doc, const xmlNode *node)
} }
#endif /* LIBXML_TREE_ENABLED */ #endif /* LIBXML_TREE_ENABLED */
/*
* xmlTreeEnsureXMLDecl:
* @doc: the doc
*
* Ensures that there is an XML namespace declaration on the doc.
*
* Returns the XML ns-struct or NULL if a memory allocation failed.
*/
xmlNsPtr
xmlTreeEnsureXMLDecl(xmlDocPtr doc)
{
if (doc == NULL)
return (NULL);
if (doc->oldNs != NULL)
return (doc->oldNs);
{
xmlNsPtr ns;
ns = (xmlNsPtr) xmlMalloc(sizeof(xmlNs));
if (ns == NULL)
return(NULL);
memset(ns, 0, sizeof(xmlNs));
ns->type = XML_LOCAL_NAMESPACE;
ns->href = xmlStrdup(XML_XML_NAMESPACE);
if (ns->href == NULL) {
xmlFreeNs(ns);
return(NULL);
}
ns->prefix = xmlStrdup((const xmlChar *)"xml");
if (ns->prefix == NULL) {
xmlFreeNs(ns);
return(NULL);
}
doc->oldNs = ns;
return (ns);
}
}
/** /**
* xmlSearchNs: * xmlSearchNs:
* @doc: the document * @doc: the document
@@ -5886,20 +5919,50 @@ xmlGetNsList(const xmlDoc *doc, const xmlNode *node)
* the namespace within those you will be in troubles !!! A warning * the namespace within those you will be in troubles !!! A warning
* is generated to cover this case. * is generated to cover this case.
* *
* Returns the namespace pointer or NULL if no namespace was found. * Returns the namespace pointer or NULL if no namespace was found or
* a memory allocation failed. Allocations can only fail if the "xml"
* namespace is queried and xmlTreeEnsureXMLDecl wasn't called
* successfully or doc is NULL.
*/ */
xmlNsPtr xmlNsPtr
xmlSearchNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr node, xmlSearchNs(xmlDocPtr doc, xmlNodePtr node, const xmlChar *nameSpace) {
const xmlChar *nameSpace) {
xmlNsPtr cur; xmlNsPtr cur;
const xmlNode *orig = node; const xmlNode *orig = node;
if ((node == NULL) || (node->type == XML_NAMESPACE_DECL)) if ((node == NULL) || (node->type == XML_NAMESPACE_DECL)) return(NULL);
if ((nameSpace != NULL) &&
(xmlStrEqual(nameSpace, (const xmlChar *)"xml"))) {
if ((doc == NULL) && (node->type == XML_ELEMENT_NODE)) {
/*
* The XML-1.0 namespace is normally held on the root
* element. In this case exceptionally create it on the
* node element.
*/
cur = (xmlNsPtr) xmlMalloc(sizeof(xmlNs));
if (cur == NULL)
return(NULL); return(NULL);
memset(cur, 0, sizeof(xmlNs));
if (xmlStrEqual(nameSpace, BAD_CAST "xml")) cur->type = XML_LOCAL_NAMESPACE;
return(xmlXmlNamespace); cur->href = xmlStrdup(XML_XML_NAMESPACE);
cur->prefix = xmlStrdup((const xmlChar *)"xml");
cur->next = node->nsDef;
node->nsDef = cur;
return(cur);
}
if (doc == NULL) {
doc = node->doc;
if (doc == NULL)
return(NULL);
}
/*
* Return the XML namespace declaration held by the doc.
*/
if (doc->oldNs == NULL)
return(xmlTreeEnsureXMLDecl(doc));
else
return(doc->oldNs);
}
while (node != NULL) { while (node != NULL) {
if ((node->type == XML_ENTITY_REF_NODE) || if ((node->type == XML_ENTITY_REF_NODE) ||
(node->type == XML_ENTITY_DECL)) (node->type == XML_ENTITY_DECL))
@@ -5974,21 +6037,54 @@ xmlNsInScope(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr node,
* Search a Ns aliasing a given URI. Recurse on the parents until it finds * Search a Ns aliasing a given URI. Recurse on the parents until it finds
* the defined namespace or return NULL otherwise. * the defined namespace or return NULL otherwise.
* *
* Returns the namespace pointer or NULL if no namespace was found. * Returns the namespace pointer or NULL if no namespace was found or
* a memory allocation failed. Allocations can only fail if the "xml"
* namespace is queried and xmlTreeEnsureXMLDecl wasn't called
* successfully or doc is NULL.
*/ */
xmlNsPtr xmlNsPtr
xmlSearchNsByHref(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr node, xmlSearchNsByHref(xmlDocPtr doc, xmlNodePtr node, const xmlChar * href)
const xmlChar * href) { {
xmlNsPtr cur; xmlNsPtr cur;
xmlNodePtr orig = node; xmlNodePtr orig = node;
int is_attr; int is_attr;
if ((node == NULL) || (node->type == XML_NAMESPACE_DECL)) if ((node == NULL) || (node->type == XML_NAMESPACE_DECL))
return (NULL); return (NULL);
if (xmlStrEqual(href, XML_XML_NAMESPACE)) {
if (xmlStrEqual(href, XML_XML_NAMESPACE)) /*
return(xmlXmlNamespace); * Only the document can hold the XML spec namespace.
*/
if ((doc == NULL) && (node->type == XML_ELEMENT_NODE)) {
/*
* The XML-1.0 namespace is normally held on the root
* element. In this case exceptionally create it on the
* node element.
*/
cur = (xmlNsPtr) xmlMalloc(sizeof(xmlNs));
if (cur == NULL)
return (NULL);
memset(cur, 0, sizeof(xmlNs));
cur->type = XML_LOCAL_NAMESPACE;
cur->href = xmlStrdup(XML_XML_NAMESPACE);
cur->prefix = xmlStrdup((const xmlChar *) "xml");
cur->next = node->nsDef;
node->nsDef = cur;
return (cur);
}
if (doc == NULL) {
doc = node->doc;
if (doc == NULL)
return(NULL);
}
/*
* Return the XML namespace declaration held by the doc.
*/
if (doc->oldNs == NULL)
return(xmlTreeEnsureXMLDecl(doc));
else
return(doc->oldNs);
}
is_attr = (node->type == XML_ATTRIBUTE_NODE); is_attr = (node->type == XML_ATTRIBUTE_NODE);
while (node != NULL) { while (node != NULL) {
if ((node->type == XML_ENTITY_REF_NODE) || if ((node->type == XML_ENTITY_REF_NODE) ||
@@ -5999,7 +6095,7 @@ xmlSearchNsByHref(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr node,
while (cur != NULL) { while (cur != NULL) {
if (xmlStrEqual(cur->href, href)) { if (xmlStrEqual(cur->href, href)) {
if (((!is_attr) || (cur->prefix != NULL)) && if (((!is_attr) || (cur->prefix != NULL)) &&
(xmlNsInScope(NULL, orig, node, cur->prefix) == 1)) (xmlNsInScope(doc, orig, node, cur->prefix) == 1))
return (cur); return (cur);
} }
cur = cur->next; cur = cur->next;
@@ -6009,7 +6105,7 @@ xmlSearchNsByHref(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr node,
if (cur != NULL) { if (cur != NULL) {
if (xmlStrEqual(cur->href, href)) { if (xmlStrEqual(cur->href, href)) {
if (((!is_attr) || (cur->prefix != NULL)) && if (((!is_attr) || (cur->prefix != NULL)) &&
(xmlNsInScope(NULL, orig, node, cur->prefix) == 1)) (xmlNsInScope(doc, orig, node, cur->prefix) == 1))
return (cur); return (cur);
} }
} }
@@ -6034,8 +6130,7 @@ xmlSearchNsByHref(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr node,
* Returns the (new) namespace definition or NULL in case of error * Returns the (new) namespace definition or NULL in case of error
*/ */
static xmlNsPtr static xmlNsPtr
xmlNewReconciledNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr tree, xmlNewReconciledNs(xmlDocPtr doc, xmlNodePtr tree, xmlNsPtr ns) {
xmlNsPtr ns) {
xmlNsPtr def; xmlNsPtr def;
xmlChar prefix[50]; xmlChar prefix[50];
int counter = 1; int counter = 1;
@@ -6049,7 +6144,7 @@ xmlNewReconciledNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr tree,
/* /*
* Search an existing namespace definition inherited. * Search an existing namespace definition inherited.
*/ */
def = xmlSearchNsByHref(NULL, tree, ns->href); def = xmlSearchNsByHref(doc, tree, ns->href);
if (def != NULL) if (def != NULL)
return(def); return(def);
@@ -6062,7 +6157,7 @@ xmlNewReconciledNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr tree,
else else
snprintf((char *) prefix, sizeof(prefix), "%.20s", (char *)ns->prefix); snprintf((char *) prefix, sizeof(prefix), "%.20s", (char *)ns->prefix);
def = xmlSearchNs(NULL, tree, prefix); def = xmlSearchNs(doc, tree, prefix);
while (def != NULL) { while (def != NULL) {
if (counter > 1000) return(NULL); if (counter > 1000) return(NULL);
if (ns->prefix == NULL) if (ns->prefix == NULL)
@@ -6070,7 +6165,7 @@ xmlNewReconciledNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr tree,
else else
snprintf((char *) prefix, sizeof(prefix), "%.20s%d", snprintf((char *) prefix, sizeof(prefix), "%.20s%d",
(char *)ns->prefix, counter++); (char *)ns->prefix, counter++);
def = xmlSearchNs(NULL, tree, prefix); def = xmlSearchNs(doc, tree, prefix);
} }
/* /*
@@ -6103,7 +6198,7 @@ typedef struct {
* Returns 0 on success or -1 in case of error. * Returns 0 on success or -1 in case of error.
*/ */
int int
xmlReconciliateNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr tree) { xmlReconciliateNs(xmlDocPtr doc, xmlNodePtr tree) {
xmlNsCache *cache = NULL; xmlNsCache *cache = NULL;
int sizeCache = 0; int sizeCache = 0;
int nbCache = 0; int nbCache = 0;
@@ -6113,9 +6208,8 @@ xmlReconciliateNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr tree) {
xmlAttrPtr attr; xmlAttrPtr attr;
int ret = 0, i; int ret = 0, i;
if ((node == NULL) || (node->type != XML_ELEMENT_NODE)) if ((node == NULL) || (node->type != XML_ELEMENT_NODE)) return(-1);
return(-1); if (node->doc != doc) return(-1);
while (node != NULL) { while (node != NULL) {
/* /*
* Reconciliate the node namespace * Reconciliate the node namespace
@@ -6131,7 +6225,7 @@ xmlReconciliateNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr tree) {
/* /*
* OK we need to recreate a new namespace definition * OK we need to recreate a new namespace definition
*/ */
n = xmlNewReconciledNs(NULL, tree, node->ns); n = xmlNewReconciledNs(doc, tree, node->ns);
if (n == NULL) { if (n == NULL) {
ret = -1; ret = -1;
} else { } else {
@@ -6175,7 +6269,7 @@ xmlReconciliateNs(xmlDocPtr doc ATTRIBUTE_UNUSED, xmlNodePtr tree) {
/* /*
* OK we need to recreate a new namespace definition * OK we need to recreate a new namespace definition
*/ */
n = xmlNewReconciledNs(NULL, tree, attr->ns); n = xmlNewReconciledNs(doc, tree, attr->ns);
if (n == NULL) { if (n == NULL) {
ret = -1; ret = -1;
} else { } else {
@@ -6654,7 +6748,7 @@ xmlSetProp(xmlNodePtr node, const xmlChar *name, const xmlChar *value) {
if (nqname != NULL) { if (nqname != NULL) {
xmlNsPtr ns; xmlNsPtr ns;
xmlChar *prefix = xmlStrndup(name, len); xmlChar *prefix = xmlStrndup(name, len);
ns = xmlSearchNs(NULL, node, prefix); ns = xmlSearchNs(node->doc, node, prefix);
if (prefix != NULL) if (prefix != NULL)
xmlFree(prefix); xmlFree(prefix);
if (ns != NULL) if (ns != NULL)
@@ -7673,29 +7767,28 @@ xmlDOMWrapStoreNs(xmlDocPtr doc,
if (doc == NULL) if (doc == NULL)
return (NULL); return (NULL);
ns = xmlTreeEnsureXMLDecl(doc);
if (ns == NULL)
return (NULL);
if (ns->next != NULL) {
/* Reuse. */ /* Reuse. */
ns = doc->oldNs; ns = ns->next;
while (ns != NULL) { while (ns != NULL) {
if (((ns->prefix == prefix) || if (((ns->prefix == prefix) ||
xmlStrEqual(ns->prefix, prefix)) && xmlStrEqual(ns->prefix, prefix)) &&
xmlStrEqual(ns->href, nsName)) { xmlStrEqual(ns->href, nsName)) {
return(ns); return (ns);
} }
if (ns->next == NULL) if (ns->next == NULL)
break; break;
ns = ns->next; ns = ns->next;
} }
/* Create. */
if (ns == NULL) {
doc->oldNs = xmlNewNs(NULL, nsName, prefix);
return(doc->oldNs);
} else {
ns->next = xmlNewNs(NULL, nsName, prefix);
return(ns->next);
} }
/* Create. */
if (ns != NULL) {
ns->next = xmlNewNs(NULL, nsName, prefix);
return (ns->next);
}
return(NULL); return(NULL);
} }
@@ -8026,7 +8119,9 @@ xmlSearchNsByNamespaceStrict(xmlDocPtr doc, xmlNodePtr node,
*retNs = NULL; *retNs = NULL;
if (xmlStrEqual(nsName, XML_XML_NAMESPACE)) { if (xmlStrEqual(nsName, XML_XML_NAMESPACE)) {
*retNs = xmlXmlNamespace; *retNs = xmlTreeEnsureXMLDecl(doc);
if (*retNs == NULL)
return (-1);
return (1); return (1);
} }
cur = node; cur = node;
@@ -8070,7 +8165,7 @@ xmlSearchNsByNamespaceStrict(xmlDocPtr doc, xmlNodePtr node,
if (out) { if (out) {
int ret; int ret;
ret = xmlNsInScope(NULL, node, prev, ns->prefix); ret = xmlNsInScope(doc, node, prev, ns->prefix);
if (ret < 0) if (ret < 0)
return (-1); return (-1);
/* /*
@@ -8125,7 +8220,9 @@ xmlSearchNsByPrefixStrict(xmlDocPtr doc, xmlNodePtr node,
*retNs = NULL; *retNs = NULL;
if (IS_STR_XML(prefix)) { if (IS_STR_XML(prefix)) {
if (retNs) { if (retNs) {
*retNs = xmlXmlNamespace; *retNs = xmlTreeEnsureXMLDecl(doc);
if (*retNs == NULL)
return (-1);
} }
return (1); return (1);
} }
@@ -8276,7 +8373,9 @@ xmlDOMWrapNSNormAcquireNormalizedNs(xmlDocPtr doc,
/* /*
* Insert XML namespace mapping. * Insert XML namespace mapping.
*/ */
*retNs = xmlXmlNamespace; *retNs = xmlTreeEnsureXMLDecl(doc);
if (*retNs == NULL)
return (-1);
return (0); return (0);
} }
/* /*
@@ -9496,7 +9595,7 @@ xmlDOMWrapAdoptAttr(xmlDOMWrapCtxtPtr ctxt,
} }
/* XML Namespace. */ /* XML Namespace. */
if (IS_STR_XML(attr->ns->prefix)) { if (IS_STR_XML(attr->ns->prefix)) {
ns = xmlXmlNamespace; ns = xmlTreeEnsureXMLDecl(destDoc);
} else if (destParent == NULL) { } else if (destParent == NULL) {
/* /*
* Store in @destDoc->oldNs. * Store in @destDoc->oldNs.

12
xpath.c
View File

@@ -49,7 +49,6 @@
#include "private/buf.h" #include "private/buf.h"
#include "private/error.h" #include "private/error.h"
#include "private/tree.h"
#include "private/xpath.h" #include "private/xpath.h"
/* Disabled for now */ /* Disabled for now */
@@ -225,6 +224,15 @@ xmlXPathIsInf(double val) {
* the test should just be name[0] = ' ' * the test should just be name[0] = ' '
*/ */
static xmlNs xmlXPathXMLNamespaceStruct = {
NULL,
XML_NAMESPACE_DECL,
XML_XML_NAMESPACE,
BAD_CAST "xml",
NULL,
NULL
};
static xmlNsPtr xmlXPathXMLNamespace = &xmlXPathXMLNamespaceStruct;
#ifndef LIBXML_THREAD_ENABLED #ifndef LIBXML_THREAD_ENABLED
/* /*
* Optimizer is disabled only when threaded apps are detected while * Optimizer is disabled only when threaded apps are detected while
@@ -7334,7 +7342,7 @@ xmlXPathNextNamespace(xmlXPathParserContextPtr ctxt, xmlNodePtr cur) {
ctxt->context->tmpNsNr++; ctxt->context->tmpNsNr++;
} }
} }
return((xmlNodePtr) xmlXmlNamespace); return((xmlNodePtr) xmlXPathXMLNamespace);
} }
if (ctxt->context->tmpNsNr > 0) { if (ctxt->context->tmpNsNr > 0) {
return (xmlNodePtr)ctxt->context->tmpNsList[--ctxt->context->tmpNsNr]; return (xmlNodePtr)ctxt->context->tmpNsList[--ctxt->context->tmpNsNr];