mirror of
https://gitlab.gnome.org/GNOME/libxml2
synced 2025-03-28 21:33:13 +00:00
Avoid calling xmlSetTreeDoc
Create text nodes with xmlNewDocText or set the document directly to avoid xmlSetTreeDoc being called when the node is inserted.
This commit is contained in:
parent
823bf16156
commit
3e7b4f37aa
5
SAX2.c
5
SAX2.c
@ -2633,9 +2633,10 @@ xmlSAX2Text(xmlParserCtxtPtr ctxt, const xmlChar *ch, int len,
|
||||
}
|
||||
} else {
|
||||
/* Mixed content, first time */
|
||||
if (type == XML_TEXT_NODE)
|
||||
if (type == XML_TEXT_NODE) {
|
||||
lastChild = xmlSAX2TextNode(ctxt, ch, len);
|
||||
else
|
||||
lastChild->doc = ctxt->myDoc;
|
||||
} else
|
||||
lastChild = xmlNewCDataBlock(ctxt->myDoc, ch, len);
|
||||
if (lastChild != NULL) {
|
||||
xmlAddChild(ctxt->node, lastChild);
|
||||
|
@ -25,7 +25,7 @@ main(void)
|
||||
* Create the document.
|
||||
*/
|
||||
doc = xmlNewDoc(BAD_CAST "1.0");
|
||||
n = xmlNewNode(NULL, BAD_CAST "root");
|
||||
n = xmlNewDocNode(doc, NULL, BAD_CAST "root", NULL);
|
||||
xmlNodeSetContent(n, BAD_CAST "content");
|
||||
xmlDocSetRootElement(doc, n);
|
||||
|
||||
|
@ -36,7 +36,7 @@ main(int argc, char **argv)
|
||||
* Creates a new document, a node and set it as a root node
|
||||
*/
|
||||
doc = xmlNewDoc(BAD_CAST "1.0");
|
||||
root_node = xmlNewNode(NULL, BAD_CAST "root");
|
||||
root_node = xmlNewDocNode(doc, NULL, BAD_CAST "root", NULL);
|
||||
xmlDocSetRootElement(doc, root_node);
|
||||
|
||||
/*
|
||||
@ -70,8 +70,8 @@ main(int argc, char **argv)
|
||||
* creates a node and a text node separately. They are "attached"
|
||||
* by xmlAddChild()
|
||||
*/
|
||||
node = xmlNewNode(NULL, BAD_CAST "node4");
|
||||
node1 = xmlNewText(BAD_CAST
|
||||
node = xmlNewDocNode(doc, NULL, BAD_CAST "node4", NULL);
|
||||
node1 = xmlNewDocText(doc, BAD_CAST
|
||||
"other way to create content (which is also a node)");
|
||||
xmlAddChild(node, node1);
|
||||
xmlAddChild(root_node, node);
|
||||
|
3
parser.c
3
parser.c
@ -7234,6 +7234,7 @@ xmlParseReference(xmlParserCtxtPtr ctxt) {
|
||||
ent->owner = 1;
|
||||
while (list != NULL) {
|
||||
list->parent = (xmlNodePtr) ent;
|
||||
if (list->doc != ent->doc)
|
||||
xmlSetTreeDoc(list, ent->doc);
|
||||
if (list->next == NULL)
|
||||
ent->last = list;
|
||||
@ -13583,7 +13584,7 @@ xmlParseInNodeContext(xmlNodePtr node, const char *data, int datalen,
|
||||
ctxt->input_id = 2;
|
||||
ctxt->instate = XML_PARSER_CONTENT;
|
||||
|
||||
fake = xmlNewComment(NULL);
|
||||
fake = xmlNewDocComment(node->doc, NULL);
|
||||
if (fake == NULL) {
|
||||
xmlFreeParserCtxt(ctxt);
|
||||
return(XML_ERR_NO_MEMORY);
|
||||
|
@ -7233,7 +7233,7 @@ xmlRelaxNGCleanupTree(xmlRelaxNGParserCtxtPtr ctxt, xmlNodePtr root)
|
||||
BAD_CAST "name", NULL);
|
||||
if (node != NULL) {
|
||||
xmlAddPrevSibling(cur->children, node);
|
||||
text = xmlNewText(name);
|
||||
text = xmlNewDocText(node->doc, name);
|
||||
xmlAddChild(node, text);
|
||||
text = node;
|
||||
}
|
||||
|
2
tree.c
2
tree.c
@ -5878,7 +5878,7 @@ xmlNodeAddContentLen(xmlNodePtr cur, const xmlChar *content, int len) {
|
||||
xmlNodePtr last, newNode, tmp;
|
||||
|
||||
last = cur->last;
|
||||
newNode = xmlNewTextLen(content, len);
|
||||
newNode = xmlNewDocTextLen(cur->doc, content, len);
|
||||
if (newNode != NULL) {
|
||||
tmp = xmlAddChild(cur, newNode);
|
||||
if (tmp != newNode)
|
||||
|
@ -1849,7 +1849,7 @@ xmlXIncludeLoadTxt(xmlXIncludeCtxtPtr ctxt, const xmlChar *url, int nr) {
|
||||
*/
|
||||
for (i = 0; i < ctxt->txtNr; i++) {
|
||||
if (xmlStrEqual(URL, ctxt->txturlTab[i])) {
|
||||
node = xmlNewText(ctxt->txtTab[i]);
|
||||
node = xmlNewDocText(ctxt->doc, ctxt->txtTab[i]);
|
||||
goto loaded;
|
||||
}
|
||||
}
|
||||
@ -1898,7 +1898,7 @@ xmlXIncludeLoadTxt(xmlXIncludeCtxtPtr ctxt, const xmlChar *url, int nr) {
|
||||
if (buf->encoder)
|
||||
xmlCharEncCloseFunc(buf->encoder);
|
||||
buf->encoder = xmlGetCharEncodingHandler(enc);
|
||||
node = xmlNewText(NULL);
|
||||
node = xmlNewDocText(ctxt->doc, NULL);
|
||||
|
||||
/*
|
||||
* Scan all chars from the resource and add the to the node
|
||||
|
@ -1379,7 +1379,7 @@ xhtmlAttrListDumpOutput(xmlSaveCtxtPtr ctxt, xmlAttrPtr cur) {
|
||||
(htmlIsBooleanAttr(cur->name))) {
|
||||
if (cur->children != NULL)
|
||||
xmlFreeNode(cur->children);
|
||||
cur->children = xmlNewText(cur->name);
|
||||
cur->children = xmlNewDocText(cur->doc, cur->name);
|
||||
if (cur->children != NULL)
|
||||
cur->children->parent = (xmlNodePtr) cur;
|
||||
}
|
||||
|
@ -26467,13 +26467,15 @@ default_psvi:
|
||||
normValue = xmlSchemaNormalizeValue(inode->typeDef,
|
||||
inode->decl->value);
|
||||
if (normValue != NULL) {
|
||||
textChild = xmlNewText(BAD_CAST normValue);
|
||||
textChild = xmlNewDocText(inode->node->doc,
|
||||
BAD_CAST normValue);
|
||||
xmlFree(normValue);
|
||||
} else
|
||||
textChild = xmlNewText(inode->decl->value);
|
||||
textChild = xmlNewDocText(inode->node->doc,
|
||||
inode->decl->value);
|
||||
if (textChild == NULL) {
|
||||
VERROR_INT("xmlSchemaValidatorPopElem",
|
||||
"calling xmlNewText()");
|
||||
"calling xmlNewDocText()");
|
||||
goto internal_error;
|
||||
} else
|
||||
xmlAddChild(inode->node, textChild);
|
||||
|
Loading…
x
Reference in New Issue
Block a user