1
0
mirror of https://gitlab.gnome.org/GNOME/libxml2.git synced 2025-07-29 11:41:22 +03:00

fixed xmlHasNsProp() bugs for defaulted from DTD attribs, added a specific

* tree.c python/tests/Makefile.am python/tests/attribs.py:
  fixed xmlHasNsProp() bugs for defaulted from DTD attribs,
  added a specific regression test
* python/generator.py: xmlHasNsProp() and xmlHasProp() shall
  not raise exceptions when failing to find the attribute.
Daniel
This commit is contained in:
Daniel Veillard
2002-03-07 22:21:56 +00:00
parent 90bc371716
commit ef6c46f805
5 changed files with 91 additions and 16 deletions

View File

@ -1,3 +1,11 @@
Thu Mar 7 23:19:28 CET 2002 Daniel Veillard <daniel@veillard.com>
* tree.c python/tests/Makefile.am python/tests/attribs.py:
fixed xmlHasNsProp() bugs for defaulted from DTD attribs,
added a specific regression test
* python/generator.py: xmlHasNsProp() and xmlHasProp() shall
not raise exceptions when failing to find the attribute.
Thu Mar 7 16:11:35 CET 2002 Daniel Veillard <daniel@veillard.com> Thu Mar 7 16:11:35 CET 2002 Daniel Veillard <daniel@veillard.com>
* configure.in xmllint.c: owen pointed out a problem with the * configure.in xmllint.c: owen pointed out a problem with the

View File

@ -551,6 +551,11 @@ classes_destructors = {
"URI": "xmlFreeURI", "URI": "xmlFreeURI",
} }
functions_noexcept = {
"xmlHasProp": 1,
"xmlHasNsProp": 1,
}
function_classes = {} function_classes = {}
function_classes["None"] = [] function_classes["None"] = []
@ -675,6 +680,7 @@ def buildWrappers():
global primary_classes global primary_classes
global classes_ancestor global classes_ancestor
global classes_destructors global classes_destructors
global functions_noexcept
for type in classes_type.keys(): for type in classes_type.keys():
function_classes[classes_type[type][2]] = [] function_classes[classes_type[type][2]] = []
@ -799,7 +805,9 @@ def buildWrappers():
# #
# Raise an exception # Raise an exception
# #
if string.find(name, "URI") >= 0: if functions_noexcept.has_key(name):
classes.write(" if ret == None:return None\n");
elif string.find(name, "URI") >= 0:
classes.write( classes.write(
" if ret == None:raise uriError('%s() failed')\n" " if ret == None:raise uriError('%s() failed')\n"
% (name)) % (name))
@ -912,7 +920,10 @@ def buildWrappers():
# #
# Raise an exception # Raise an exception
# #
if string.find(name, "URI") >= 0: if functions_noexcept.has_key(name):
classes.write(
" if ret == None:return None\n");
elif string.find(name, "URI") >= 0:
classes.write( classes.write(
" if ret == None:raise uriError('%s() failed')\n" " if ret == None:raise uriError('%s() failed')\n"
% (name)) % (name))
@ -935,7 +946,10 @@ def buildWrappers():
# #
# Raise an exception # Raise an exception
# #
if string.find(name, "URI") >= 0: if functions_noexcept.has_key(name):
classes.write(
" if ret == None:return None");
elif string.find(name, "URI") >= 0:
classes.write( classes.write(
" if ret == None:raise uriError('%s() failed')\n" " if ret == None:raise uriError('%s() failed')\n"
% (name)) % (name))

View File

@ -2,6 +2,7 @@ EXAMPLE_DIR = $(prefix)/share/doc/libxml2-python-$(LIBXML_VERSION)/examples
PYTESTS= \ PYTESTS= \
build.py \ build.py \
attribs.py \
tst.py \ tst.py \
tstxpath.py \ tstxpath.py \
xpathext.py \ xpathext.py \

34
python/tests/attribs.py Executable file
View File

@ -0,0 +1,34 @@
#!/usr/bin/python -u
import sys
import libxml2
# Memory debug specific
libxml2.debugMemory(1)
#
# Testing XML document serialization
#
doc = libxml2.parseDoc(
"""<?xml version="1.0" encoding="iso-8859-1"?>
<!DOCTYPE test [
<!ELEMENT test (#PCDATA) >
<!ATTLIST test xmlns:abc CDATA #FIXED "http://abc.org" >
<!ATTLIST test abc:attr CDATA #FIXED "def" >
]>
<test />
""")
elem = doc.getRootElement()
attr = elem.hasNsProp('attr', 'http://abc.org')
if attr == None or attr.serialize()[:-1] != """<!ATTLIST test abc:attr CDATA #FIXED "def">""":
print "Failed to find defaulted attribute abc:attr"
sys.exit(1)
doc.freeDoc()
# Memory debug specific
libxml2.cleanupParser()
if libxml2.debugMemory(1) == 0:
print "OK"
else:
print "Memory leak %d bytes" % (libxml2.debugMemory(1))
libxml2.dumpMemory()

44
tree.c
View File

@ -4802,7 +4802,6 @@ xmlAttrPtr
xmlHasNsProp(xmlNodePtr node, const xmlChar *name, const xmlChar *nameSpace) { xmlHasNsProp(xmlNodePtr node, const xmlChar *name, const xmlChar *nameSpace) {
xmlAttrPtr prop; xmlAttrPtr prop;
xmlDocPtr doc; xmlDocPtr doc;
xmlNsPtr ns;
if (node == NULL) if (node == NULL)
return(NULL); return(NULL);
@ -4833,20 +4832,39 @@ xmlHasNsProp(xmlNodePtr node, const xmlChar *name, const xmlChar *nameSpace) {
doc = node->doc; doc = node->doc;
if (doc != NULL) { if (doc != NULL) {
if (doc->intSubset != NULL) { if (doc->intSubset != NULL) {
xmlAttributePtr attrDecl; xmlAttributePtr attrDecl = NULL;
xmlNsPtr *nsList, *cur;
xmlChar *ename;
attrDecl = xmlGetDtdAttrDesc(doc->intSubset, node->name, name); nsList = xmlGetNsList(node->doc, node);
if ((attrDecl == NULL) && (doc->extSubset != NULL)) if (nsList == NULL)
attrDecl = xmlGetDtdAttrDesc(doc->extSubset, node->name, name); return(NULL);
if ((node->ns != NULL) && (node->ns->prefix != NULL)) {
if ((attrDecl != NULL) && (attrDecl->prefix != NULL)) { ename = xmlStrdup(node->ns->prefix);
/* ename = xmlStrcat(ename, BAD_CAST ":");
* The DTD declaration only allows a prefix search ename = xmlStrcat(ename, node->name);
*/ } else {
ns = xmlSearchNs(doc, node, attrDecl->prefix); ename = xmlStrdup(node->name);
if ((ns != NULL) && (xmlStrEqual(ns->href, nameSpace)))
return((xmlAttrPtr) attrDecl);
} }
if (ename == NULL) {
xmlFree(nsList);
return(NULL);
}
cur = nsList;
while (*cur != NULL) {
if (xmlStrEqual((*cur)->href, nameSpace)) {
attrDecl = xmlGetDtdQAttrDesc(doc->intSubset, ename,
name, (*cur)->prefix);
if ((attrDecl == NULL) && (doc->extSubset != NULL))
attrDecl = xmlGetDtdQAttrDesc(doc->extSubset, ename,
name, (*cur)->prefix);
}
cur++;
}
xmlFree(nsList);
xmlFree(ename);
return((xmlAttrPtr) attrDecl);
} }
} }
return(NULL); return(NULL);