mirror of
https://gitlab.gnome.org/GNOME/libxml2
synced 2025-03-28 21:33:13 +00:00
fixing a leak detected by testapi in xmlDOMWrapAdoptNode, and fixing
* testapi.c tree.c: fixing a leak detected by testapi in xmlDOMWrapAdoptNode, and fixing another side effect in testapi seems to pass tests fine now. * include/libxml/parser.h parser.c: xmlStopParser() is no more limited to push mode * error.c: remove a warning * runtest.c xmllint.c: avoid compilation errors if only some parts of the library are compiled in. Daniel
This commit is contained in:
parent
7e33dbaa0e
commit
39e5c89016
15
ChangeLog
15
ChangeLog
@ -1,13 +1,18 @@
|
|||||||
Mon Jul 4 00:39:35 CEST 2005 Daniel Veillard <daniel@veillard.com>
|
|
||||||
|
|
||||||
* gentest.py testapi.c: fix a problem with previous patch to
|
|
||||||
testapi.c
|
|
||||||
|
|
||||||
Sun Jul 3 23:42:31 CEST 2005 Daniel Veillard <daniel@veillard.com>
|
Sun Jul 3 23:42:31 CEST 2005 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
* testapi.c tree.c: fixing a leak detected by testapi in
|
* testapi.c tree.c: fixing a leak detected by testapi in
|
||||||
xmlDOMWrapAdoptNode, and fixing another side effect in testapi
|
xmlDOMWrapAdoptNode, and fixing another side effect in testapi
|
||||||
seems to pass tests fine now.
|
seems to pass tests fine now.
|
||||||
|
* include/libxml/parser.h parser.c: xmlStopParser() is no more limited
|
||||||
|
to push mode
|
||||||
|
* error.c: remove a warning
|
||||||
|
* runtest.c xmllint.c: avoid compilation errors if only some parts
|
||||||
|
of the library are compiled in.
|
||||||
|
|
||||||
|
Mon Jul 4 00:39:35 CEST 2005 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
* gentest.py testapi.c: fix a problem with previous patch to
|
||||||
|
testapi.c
|
||||||
|
|
||||||
Sun Jul 3 22:59:28 CEST 2005 Daniel Veillard <daniel@veillard.com>
|
Sun Jul 3 22:59:28 CEST 2005 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
18
configure.in
18
configure.in
@ -127,7 +127,7 @@ AC_ARG_WITH(run_debug,
|
|||||||
AC_ARG_WITH(sax1,
|
AC_ARG_WITH(sax1,
|
||||||
[ --with-sax1 add the older SAX1 interface (on)])
|
[ --with-sax1 add the older SAX1 interface (on)])
|
||||||
AC_ARG_WITH(schemas,
|
AC_ARG_WITH(schemas,
|
||||||
[ --with-schemas add Relax-NG and experimental Schemas support (on)])
|
[ --with-schemas add Relax-NG and Schemas support (on)])
|
||||||
AC_ARG_WITH(threads,
|
AC_ARG_WITH(threads,
|
||||||
[ --with-threads add multithread support(on)])
|
[ --with-threads add multithread support(on)])
|
||||||
AC_ARG_WITH(thread-alloc,
|
AC_ARG_WITH(thread-alloc,
|
||||||
@ -155,6 +155,22 @@ AC_ARG_WITH(zlib,
|
|||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
|
dnl
|
||||||
|
dnl hard dependancies on options
|
||||||
|
dnl
|
||||||
|
if test "$with_schemas" = "yes"
|
||||||
|
then
|
||||||
|
with_pattern=yes
|
||||||
|
with_regexp=yes
|
||||||
|
fi
|
||||||
|
if test "$with_reader" = "yes"
|
||||||
|
then
|
||||||
|
with_push=yes
|
||||||
|
fi
|
||||||
|
if test "$with_xptr" = "yes"
|
||||||
|
then
|
||||||
|
with_xpath=yes
|
||||||
|
fi
|
||||||
dnl
|
dnl
|
||||||
dnl option to build a minimal libxml2 library
|
dnl option to build a minimal libxml2 library
|
||||||
dnl
|
dnl
|
||||||
|
2
error.c
2
error.c
@ -514,7 +514,7 @@ __xmlRaiseError(xmlStructuredErrorFunc schannel,
|
|||||||
|
|
||||||
if ((node->doc != NULL) && (node->doc->URL != NULL)) {
|
if ((node->doc != NULL) && (node->doc->URL != NULL)) {
|
||||||
baseptr = node;
|
baseptr = node;
|
||||||
file = node->doc->URL;
|
file = (const char *) node->doc->URL;
|
||||||
}
|
}
|
||||||
for (i = 0;
|
for (i = 0;
|
||||||
((i < 10) && (node != NULL) && (node->type != XML_ELEMENT_NODE));
|
((i < 10) && (node != NULL) && (node->type != XML_ELEMENT_NODE));
|
||||||
|
@ -836,10 +836,8 @@ XMLPUBFUN int XMLCALL
|
|||||||
xmlSubstituteEntitiesDefault(int val);
|
xmlSubstituteEntitiesDefault(int val);
|
||||||
XMLPUBFUN int XMLCALL
|
XMLPUBFUN int XMLCALL
|
||||||
xmlKeepBlanksDefault (int val);
|
xmlKeepBlanksDefault (int val);
|
||||||
#ifdef LIBXML_PUSH_ENABLED
|
|
||||||
XMLPUBFUN void XMLCALL
|
XMLPUBFUN void XMLCALL
|
||||||
xmlStopParser (xmlParserCtxtPtr ctxt);
|
xmlStopParser (xmlParserCtxtPtr ctxt);
|
||||||
#endif /* LIBXML_PUSH_ENABLED */
|
|
||||||
XMLPUBFUN int XMLCALL
|
XMLPUBFUN int XMLCALL
|
||||||
xmlPedanticParserDefault(int val);
|
xmlPedanticParserDefault(int val);
|
||||||
XMLPUBFUN int XMLCALL
|
XMLPUBFUN int XMLCALL
|
||||||
|
36
parser.c
36
parser.c
@ -10137,24 +10137,6 @@ xmlParseChunk(xmlParserCtxtPtr ctxt, const char *chunk, int size,
|
|||||||
* *
|
* *
|
||||||
************************************************************************/
|
************************************************************************/
|
||||||
|
|
||||||
/**
|
|
||||||
* xmlStopParser:
|
|
||||||
* @ctxt: an XML parser context
|
|
||||||
*
|
|
||||||
* Blocks further parser processing
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
xmlStopParser(xmlParserCtxtPtr ctxt) {
|
|
||||||
if (ctxt == NULL)
|
|
||||||
return;
|
|
||||||
ctxt->instate = XML_PARSER_EOF;
|
|
||||||
ctxt->disableSAX = 1;
|
|
||||||
if (ctxt->input != NULL) {
|
|
||||||
ctxt->input->cur = BAD_CAST"";
|
|
||||||
ctxt->input->base = ctxt->input->cur;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* xmlCreatePushParserCtxt:
|
* xmlCreatePushParserCtxt:
|
||||||
* @sax: a SAX handler
|
* @sax: a SAX handler
|
||||||
@ -10287,6 +10269,24 @@ xmlCreatePushParserCtxt(xmlSAXHandlerPtr sax, void *user_data,
|
|||||||
}
|
}
|
||||||
#endif /* LIBXML_PUSH_ENABLED */
|
#endif /* LIBXML_PUSH_ENABLED */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlStopParser:
|
||||||
|
* @ctxt: an XML parser context
|
||||||
|
*
|
||||||
|
* Blocks further parser processing
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
xmlStopParser(xmlParserCtxtPtr ctxt) {
|
||||||
|
if (ctxt == NULL)
|
||||||
|
return;
|
||||||
|
ctxt->instate = XML_PARSER_EOF;
|
||||||
|
ctxt->disableSAX = 1;
|
||||||
|
if (ctxt->input != NULL) {
|
||||||
|
ctxt->input->cur = BAD_CAST"";
|
||||||
|
ctxt->input->base = ctxt->input->cur;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* xmlCreateIOParserCtxt:
|
* xmlCreateIOParserCtxt:
|
||||||
* @sax: a SAX handler
|
* @sax: a SAX handler
|
||||||
|
15
runtest.c
15
runtest.c
@ -2122,6 +2122,7 @@ streamMemParseTest(const char *filename, const char *result, const char *err,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef LIBXML_XPATH_ENABLED
|
#ifdef LIBXML_XPATH_ENABLED
|
||||||
|
#ifdef LIBXML_DEBUG_ENABLED
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* *
|
* *
|
||||||
* XPath and XPointer based tests *
|
* XPath and XPointer based tests *
|
||||||
@ -2411,6 +2412,7 @@ xmlidDocTest(const char *filename,
|
|||||||
return(res);
|
return(res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif /* LIBXML_DEBUG_ENABLED */
|
||||||
#endif /* XPATH */
|
#endif /* XPATH */
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* *
|
* *
|
||||||
@ -2909,6 +2911,7 @@ rngTest(const char *filename,
|
|||||||
return(res);
|
return(res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef LIBXML_READER_ENABLED
|
||||||
/**
|
/**
|
||||||
* rngStreamTest:
|
* rngStreamTest:
|
||||||
* @filename: the schemas file
|
* @filename: the schemas file
|
||||||
@ -2999,11 +3002,12 @@ rngStreamTest(const char *filename,
|
|||||||
|
|
||||||
return(res);
|
return(res);
|
||||||
}
|
}
|
||||||
|
#endif /* READER */
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef LIBXML_PATTERN_ENABLED
|
#ifdef LIBXML_PATTERN_ENABLED
|
||||||
|
#ifdef LIBXML_READER_ENABLED
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* *
|
* *
|
||||||
* Patterns tests *
|
* Patterns tests *
|
||||||
@ -3212,7 +3216,8 @@ patternTest(const char *filename,
|
|||||||
free(temp);
|
free(temp);
|
||||||
return(ret);
|
return(ret);
|
||||||
}
|
}
|
||||||
#endif
|
#endif /* READER */
|
||||||
|
#endif /* PATTERN */
|
||||||
#ifdef LIBXML_C14N_ENABLED
|
#ifdef LIBXML_C14N_ENABLED
|
||||||
/************************************************************************
|
/************************************************************************
|
||||||
* *
|
* *
|
||||||
@ -3890,6 +3895,7 @@ testDesc testDescriptions[] = {
|
|||||||
NULL, XML_PARSE_XINCLUDE | XML_PARSE_NOXINCNODE },
|
NULL, XML_PARSE_XINCLUDE | XML_PARSE_NOXINCNODE },
|
||||||
#endif
|
#endif
|
||||||
#ifdef LIBXML_XPATH_ENABLED
|
#ifdef LIBXML_XPATH_ENABLED
|
||||||
|
#ifdef LIBXML_DEBUG_ENABLED
|
||||||
{ "XPath expressions regression tests" ,
|
{ "XPath expressions regression tests" ,
|
||||||
xpathExprTest, "./test/XPath/expr/*", "result/XPath/expr/", "", NULL,
|
xpathExprTest, "./test/XPath/expr/*", "result/XPath/expr/", "", NULL,
|
||||||
0 },
|
0 },
|
||||||
@ -3904,6 +3910,7 @@ testDesc testDescriptions[] = {
|
|||||||
{ "xml:id regression tests" ,
|
{ "xml:id regression tests" ,
|
||||||
xmlidDocTest, "./test/xmlid/*", "result/xmlid/", "", ".err",
|
xmlidDocTest, "./test/xmlid/*", "result/xmlid/", "", ".err",
|
||||||
0 },
|
0 },
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
{ "URI parsing tests" ,
|
{ "URI parsing tests" ,
|
||||||
uriParseTest, "./test/URI/*.uri", "result/URI/", "", NULL,
|
uriParseTest, "./test/URI/*.uri", "result/URI/", "", NULL,
|
||||||
@ -3918,15 +3925,19 @@ testDesc testDescriptions[] = {
|
|||||||
{ "Relax-NG regression tests" ,
|
{ "Relax-NG regression tests" ,
|
||||||
rngTest, "./test/relaxng/*.rng", NULL, NULL, NULL,
|
rngTest, "./test/relaxng/*.rng", NULL, NULL, NULL,
|
||||||
XML_PARSE_DTDATTR | XML_PARSE_NOENT },
|
XML_PARSE_DTDATTR | XML_PARSE_NOENT },
|
||||||
|
#ifdef LIBXML_READER_ENABLED
|
||||||
{ "Relax-NG streaming regression tests" ,
|
{ "Relax-NG streaming regression tests" ,
|
||||||
rngStreamTest, "./test/relaxng/*.rng", NULL, NULL, NULL,
|
rngStreamTest, "./test/relaxng/*.rng", NULL, NULL, NULL,
|
||||||
XML_PARSE_DTDATTR | XML_PARSE_NOENT },
|
XML_PARSE_DTDATTR | XML_PARSE_NOENT },
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
#ifdef LIBXML_PATTERN_ENABLED
|
#ifdef LIBXML_PATTERN_ENABLED
|
||||||
|
#ifdef LIBXML_READER_ENABLED
|
||||||
{ "Pattern regression tests" ,
|
{ "Pattern regression tests" ,
|
||||||
patternTest, "./test/pattern/*.pat", "result/pattern/", NULL, NULL,
|
patternTest, "./test/pattern/*.pat", "result/pattern/", NULL, NULL,
|
||||||
0 },
|
0 },
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
#ifdef LIBXML_C14N_ENABLED
|
#ifdef LIBXML_C14N_ENABLED
|
||||||
{ "C14N with comments regression tests" ,
|
{ "C14N with comments regression tests" ,
|
||||||
c14nWithCommentTest, "./test/c14n/with-comments/*.xml", NULL, NULL, NULL,
|
c14nWithCommentTest, "./test/c14n/with-comments/*.xml", NULL, NULL, NULL,
|
||||||
|
2
tree.c
2
tree.c
@ -7445,7 +7445,7 @@ xmlDOMWrapNSNormGatherInScopeNs(xmlNsMapItemPtr *map,
|
|||||||
str = xmlDictLookup(destDoc->dict, str, -1); \
|
str = xmlDictLookup(destDoc->dict, str, -1); \
|
||||||
if ((sourceDoc == NULL) || (sourceDoc->dict == NULL) || \
|
if ((sourceDoc == NULL) || (sourceDoc->dict == NULL) || \
|
||||||
(!xmlDictOwns(sourceDoc->dict, old))) \
|
(!xmlDictOwns(sourceDoc->dict, old))) \
|
||||||
xmlFree(old); \
|
xmlFree((char *)old); \
|
||||||
} else if ((sourceDoc) && (sourceDoc->dict) && \
|
} else if ((sourceDoc) && (sourceDoc->dict) && \
|
||||||
xmlDictOwns(sourceDoc->dict, str)) { \
|
xmlDictOwns(sourceDoc->dict, str)) { \
|
||||||
str = BAD_CAST xmlStrdup(str); \
|
str = BAD_CAST xmlStrdup(str); \
|
||||||
|
@ -2341,7 +2341,11 @@ main(int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
#endif /* LIBXML_SCHEMAS_ENABLED */
|
#endif /* LIBXML_SCHEMAS_ENABLED */
|
||||||
#ifdef LIBXML_PATTERN_ENABLED
|
#ifdef LIBXML_PATTERN_ENABLED
|
||||||
if ((pattern != NULL) && (walker == 0)) {
|
if ((pattern != NULL)
|
||||||
|
#ifdef LIBXML_WALKER_ENABLED
|
||||||
|
&& (walker == 0)
|
||||||
|
#endif
|
||||||
|
) {
|
||||||
patternc = xmlPatterncompile((const xmlChar *) pattern, NULL, 0, NULL);
|
patternc = xmlPatterncompile((const xmlChar *) pattern, NULL, 0, NULL);
|
||||||
if (patternc == NULL) {
|
if (patternc == NULL) {
|
||||||
xmlGenericError(xmlGenericErrorContext,
|
xmlGenericError(xmlGenericErrorContext,
|
||||||
|
@ -664,7 +664,9 @@ struct _xmlSchemaValidCtxt {
|
|||||||
|
|
||||||
xmlDictPtr dict;
|
xmlDictPtr dict;
|
||||||
|
|
||||||
|
#ifdef LIBXML_READER_ENABLED
|
||||||
xmlTextReaderPtr reader;
|
xmlTextReaderPtr reader;
|
||||||
|
#endif
|
||||||
|
|
||||||
xmlSchemaAttrInfoPtr *attrInfos;
|
xmlSchemaAttrInfoPtr *attrInfos;
|
||||||
int nbAttrInfos;
|
int nbAttrInfos;
|
||||||
@ -18330,6 +18332,7 @@ xmlSchemaLookupNamespace(xmlSchemaValidCtxtPtr vctxt,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
#ifdef LIBXML_WRITER_ENABLED
|
||||||
} else if (vctxt->reader != NULL) {
|
} else if (vctxt->reader != NULL) {
|
||||||
xmlChar *nsName;
|
xmlChar *nsName;
|
||||||
|
|
||||||
@ -18343,6 +18346,7 @@ xmlSchemaLookupNamespace(xmlSchemaValidCtxtPtr vctxt,
|
|||||||
return (ret);
|
return (ret);
|
||||||
} else
|
} else
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
#endif
|
||||||
} else {
|
} else {
|
||||||
xmlNsPtr ns;
|
xmlNsPtr ns;
|
||||||
|
|
||||||
@ -23411,7 +23415,9 @@ xmlSchemaClearValidCtxt(xmlSchemaValidCtxtPtr vctxt)
|
|||||||
vctxt->flags = 0;
|
vctxt->flags = 0;
|
||||||
vctxt->validationRoot = NULL;
|
vctxt->validationRoot = NULL;
|
||||||
vctxt->doc = NULL;
|
vctxt->doc = NULL;
|
||||||
|
#ifdef LIBXML_READER_ENABLED
|
||||||
vctxt->reader = NULL;
|
vctxt->reader = NULL;
|
||||||
|
#endif
|
||||||
if (vctxt->value != NULL) {
|
if (vctxt->value != NULL) {
|
||||||
xmlSchemaFreeValue(vctxt->value);
|
xmlSchemaFreeValue(vctxt->value);
|
||||||
vctxt->value = NULL;
|
vctxt->value = NULL;
|
||||||
@ -23846,12 +23852,14 @@ xmlSchemaVStart(xmlSchemaValidCtxtPtr vctxt)
|
|||||||
* Tree validation.
|
* Tree validation.
|
||||||
*/
|
*/
|
||||||
ret = xmlSchemaVDocWalk(vctxt);
|
ret = xmlSchemaVDocWalk(vctxt);
|
||||||
|
#ifdef LIBXML_READER_ENABLED
|
||||||
} else if (vctxt->reader != NULL) {
|
} else if (vctxt->reader != NULL) {
|
||||||
/*
|
/*
|
||||||
* XML Reader validation.
|
* XML Reader validation.
|
||||||
*/
|
*/
|
||||||
#ifdef XML_SCHEMA_READER_ENABLED
|
#ifdef XML_SCHEMA_READER_ENABLED
|
||||||
ret = xmlSchemaVReaderWalk(vctxt);
|
ret = xmlSchemaVReaderWalk(vctxt);
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
} else if ((vctxt->sax != NULL) && (vctxt->parserCtxt != NULL)) {
|
} else if ((vctxt->sax != NULL) && (vctxt->parserCtxt != NULL)) {
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user