mirror of
https://gitlab.gnome.org/GNOME/libxml2.git
synced 2024-12-24 21:33:51 +03:00
more cleanup through the I/O error path Daniel
* error.c tree.c xmlIO.c xmllint.c: more cleanup through the I/O error path Daniel
This commit is contained in:
parent
97bf4d02e5
commit
828ce83d4c
@ -1,3 +1,8 @@
|
||||
Wed Oct 8 21:18:12 CEST 2003 Daniel Veillard <daniel@veillard.com>
|
||||
|
||||
* error.c tree.c xmlIO.c xmllint.c: more cleanup through the
|
||||
I/O error path
|
||||
|
||||
Wed Oct 8 20:57:27 CEST 2003 Daniel Veillard <daniel@veillard.com>
|
||||
|
||||
* xmlIO.c: better handling of error cases
|
||||
|
9
error.c
9
error.c
@ -350,9 +350,14 @@ xmlReportError(xmlErrorPtr err, xmlParserCtxtPtr ctxt, const char *str,
|
||||
if (code == XML_ERR_OK)
|
||||
return;
|
||||
if (str != NULL) {
|
||||
channel(data, "%s", str);
|
||||
int len;
|
||||
len = xmlStrlen((const xmlChar *)str);
|
||||
if ((len > 0) && (str[len - 1] != '\n'))
|
||||
channel(data, "%s", str);
|
||||
else
|
||||
channel(data, "%s\n", str);
|
||||
} else {
|
||||
channel(data, "%s", "out of memory error");
|
||||
channel(data, "%s\n", "out of memory error");
|
||||
}
|
||||
if (code == XML_ERR_OK)
|
||||
return;
|
||||
|
2
tree.c
2
tree.c
@ -8346,7 +8346,7 @@ xmlDocFormatDump(FILE *f, xmlDocPtr cur, int format) {
|
||||
*/
|
||||
int
|
||||
xmlDocDump(FILE *f, xmlDocPtr cur) {
|
||||
return(xmlDocFormatDump (f, cur, 0));
|
||||
return(xmlDocFormatDump (f, cur, 0));
|
||||
}
|
||||
|
||||
/**
|
||||
|
17
xmlIO.c
17
xmlIO.c
@ -1974,32 +1974,35 @@ xmlFreeParserInputBuffer(xmlParserInputBufferPtr in) {
|
||||
* Returns the number of byte written or -1 in case of error.
|
||||
*/
|
||||
int
|
||||
xmlOutputBufferClose(xmlOutputBufferPtr out) {
|
||||
xmlOutputBufferClose(xmlOutputBufferPtr out)
|
||||
{
|
||||
int written;
|
||||
int err_rc = 0;
|
||||
|
||||
if (out == NULL)
|
||||
return(-1);
|
||||
return (-1);
|
||||
if (out->writecallback != NULL)
|
||||
xmlOutputBufferFlush(out);
|
||||
xmlOutputBufferFlush(out);
|
||||
if (out->closecallback != NULL) {
|
||||
err_rc = out->closecallback(out->context);
|
||||
err_rc = out->closecallback(out->context);
|
||||
}
|
||||
written = out->written;
|
||||
if (out->conv) {
|
||||
xmlBufferFree(out->conv);
|
||||
out->conv = NULL;
|
||||
out->conv = NULL;
|
||||
}
|
||||
if (out->encoder != NULL) {
|
||||
xmlCharEncCloseFunc(out->encoder);
|
||||
}
|
||||
if (out->buffer != NULL) {
|
||||
xmlBufferFree(out->buffer);
|
||||
out->buffer = NULL;
|
||||
out->buffer = NULL;
|
||||
}
|
||||
|
||||
if (out->error)
|
||||
err_rc = -1;
|
||||
xmlFree(out);
|
||||
return( ( err_rc == 0 ) ? written : err_rc );
|
||||
return ((err_rc == 0) ? written : err_rc);
|
||||
}
|
||||
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user