mirror of
https://gitlab.gnome.org/GNOME/libxml2.git
synced 2025-01-25 06:03:34 +03:00
Fixed bug 109942
This commit is contained in:
parent
d72c7e339c
commit
3dd57f7981
@ -1,3 +1,8 @@
|
|||||||
|
Mon May 12 21:58:00 EDT 2003 William Brack <wbrack@mmm.com.hk>
|
||||||
|
|
||||||
|
* minor cleanup of configure '--help' display
|
||||||
|
* error.c: enhanced xmlParserPrintFileContext to fix bug #109942
|
||||||
|
|
||||||
Mon May 12 17:53:30 EDT 2003 Daniel Veillard <daniel@veillard.com>
|
Mon May 12 17:53:30 EDT 2003 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
* tree.c: PI nodes in external subset were not freed :-\
|
* tree.c: PI nodes in external subset were not freed :-\
|
||||||
|
37
error.c
37
error.c
@ -149,8 +149,8 @@ xmlParserPrintFileInfo(xmlParserInputPtr input) {
|
|||||||
void
|
void
|
||||||
xmlParserPrintFileContext(xmlParserInputPtr input) {
|
xmlParserPrintFileContext(xmlParserInputPtr input) {
|
||||||
const xmlChar *cur, *base;
|
const xmlChar *cur, *base;
|
||||||
int n;
|
int n, col;
|
||||||
xmlChar content[81];
|
xmlChar content[81]; /* space for 80 chars + line terminator */
|
||||||
xmlChar *ctnt;
|
xmlChar *ctnt;
|
||||||
|
|
||||||
if (input == NULL) return;
|
if (input == NULL) return;
|
||||||
@ -161,37 +161,34 @@ xmlParserPrintFileContext(xmlParserInputPtr input) {
|
|||||||
cur--;
|
cur--;
|
||||||
}
|
}
|
||||||
n = 0;
|
n = 0;
|
||||||
/* search backwards for beginning-of-line maximum 80 characters */
|
/* search backwards for beginning-of-line (to max buff size) */
|
||||||
while ((n++ < 80) && (cur > base) && (*cur != '\n') && (*cur != '\r'))
|
while ((n++ < sizeof(content)-1) && (cur > base) && (*cur != '\n') && (*cur != '\r'))
|
||||||
cur--;
|
cur--;
|
||||||
if ((*cur == '\n') || (*cur == '\r')) cur++;
|
if ((*cur == '\n') || (*cur == '\r')) cur++;
|
||||||
/* search forward for end-of-line maximum 80 characters */
|
/* calculate the error position in terms of the current position */
|
||||||
|
col = input->cur - cur;
|
||||||
|
/* search forward for end-of-line (to max buff size) */
|
||||||
n = 0;
|
n = 0;
|
||||||
ctnt = content;
|
ctnt = content;
|
||||||
while ((*cur != 0) && (*cur != '\n') && (*cur != '\r') && (n < 79)) {
|
/* copy selected text to our buffer */
|
||||||
|
while ((*cur != 0) && (*cur != '\n') && (*cur != '\r') && (n < sizeof(content)-1)) {
|
||||||
*ctnt++ = *cur++;
|
*ctnt++ = *cur++;
|
||||||
n++;
|
n++;
|
||||||
}
|
}
|
||||||
*ctnt = 0;
|
*ctnt = 0;
|
||||||
|
/* print out the selected text */
|
||||||
xmlGenericError(xmlGenericErrorContext,"%s\n", content);
|
xmlGenericError(xmlGenericErrorContext,"%s\n", content);
|
||||||
/* create blank line with problem pointer */
|
/* create blank line with problem pointer */
|
||||||
cur = input->cur;
|
|
||||||
while ((cur > base) && ((*cur == '\n') || (*cur == '\r'))) {
|
|
||||||
cur--;
|
|
||||||
}
|
|
||||||
n = 0;
|
n = 0;
|
||||||
ctnt = content;
|
ctnt = content;
|
||||||
while ((n++ < 79) && (cur > base) && (*cur != '\n') && (*cur != '\r')) {
|
/* (leave buffer space for pointer + line terminator) */
|
||||||
*ctnt++ = ' ';
|
while ((n<col) && (n++ < sizeof(content)-2) && (*ctnt != 0)) {
|
||||||
cur--;
|
if (*ctnt!='\t')
|
||||||
}
|
*ctnt = ' ';
|
||||||
if (ctnt > content) {
|
*ctnt++;
|
||||||
*(--ctnt) = '^';
|
|
||||||
*(++ctnt) = 0;
|
|
||||||
} else {
|
|
||||||
*ctnt = '^';
|
|
||||||
*(++ctnt) = 0;
|
|
||||||
}
|
}
|
||||||
|
*ctnt++ = '^';
|
||||||
|
*ctnt = 0;
|
||||||
xmlGenericError(xmlGenericErrorContext,"%s\n", content);
|
xmlGenericError(xmlGenericErrorContext,"%s\n", content);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user