mirror of
https://gitlab.gnome.org/GNOME/libxml2.git
synced 2025-10-24 13:33:01 +03:00
Fix line numbers in error messages for mismatched tags
Commit 62150ed2
introduced a small regression in the error messages for
mismatched tags. This typically only affected messages after the first
mismatch, but with custom SAX handlers all line numbers would be off.
This also fixes line numbers in the SAX push parser which were never
handled correctly.
This commit is contained in:
38
parser.c
38
parser.c
@@ -1838,6 +1838,8 @@ nodePop(xmlParserCtxtPtr ctxt)
|
|||||||
* @value: the element name
|
* @value: the element name
|
||||||
* @prefix: the element prefix
|
* @prefix: the element prefix
|
||||||
* @URI: the element namespace name
|
* @URI: the element namespace name
|
||||||
|
* @line: the current line number for error messages
|
||||||
|
* @nsNr: the number of namespaces pushed on the namespace table
|
||||||
*
|
*
|
||||||
* Pushes a new element name/prefix/URL on top of the name stack
|
* Pushes a new element name/prefix/URL on top of the name stack
|
||||||
*
|
*
|
||||||
@@ -1845,7 +1847,7 @@ nodePop(xmlParserCtxtPtr ctxt)
|
|||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
nameNsPush(xmlParserCtxtPtr ctxt, const xmlChar * value,
|
nameNsPush(xmlParserCtxtPtr ctxt, const xmlChar * value,
|
||||||
const xmlChar *prefix, const xmlChar *URI, int nsNr)
|
const xmlChar *prefix, const xmlChar *URI, int line, int nsNr)
|
||||||
{
|
{
|
||||||
if (ctxt->nameNr >= ctxt->nameMax) {
|
if (ctxt->nameNr >= ctxt->nameMax) {
|
||||||
const xmlChar * *tmp;
|
const xmlChar * *tmp;
|
||||||
@@ -1860,7 +1862,7 @@ nameNsPush(xmlParserCtxtPtr ctxt, const xmlChar * value,
|
|||||||
}
|
}
|
||||||
ctxt->nameTab = tmp;
|
ctxt->nameTab = tmp;
|
||||||
tmp2 = (void **) xmlRealloc((void * *)ctxt->pushTab,
|
tmp2 = (void **) xmlRealloc((void * *)ctxt->pushTab,
|
||||||
ctxt->nameMax * 3 *
|
ctxt->nameMax * 4 *
|
||||||
sizeof(ctxt->pushTab[0]));
|
sizeof(ctxt->pushTab[0]));
|
||||||
if (tmp2 == NULL) {
|
if (tmp2 == NULL) {
|
||||||
ctxt->nameMax /= 2;
|
ctxt->nameMax /= 2;
|
||||||
@@ -1868,16 +1870,17 @@ nameNsPush(xmlParserCtxtPtr ctxt, const xmlChar * value,
|
|||||||
}
|
}
|
||||||
ctxt->pushTab = tmp2;
|
ctxt->pushTab = tmp2;
|
||||||
} else if (ctxt->pushTab == NULL) {
|
} else if (ctxt->pushTab == NULL) {
|
||||||
ctxt->pushTab = (void **) xmlMalloc(ctxt->nameMax * 3 *
|
ctxt->pushTab = (void **) xmlMalloc(ctxt->nameMax * 4 *
|
||||||
sizeof(ctxt->pushTab[0]));
|
sizeof(ctxt->pushTab[0]));
|
||||||
if (ctxt->pushTab == NULL)
|
if (ctxt->pushTab == NULL)
|
||||||
goto mem_error;
|
goto mem_error;
|
||||||
}
|
}
|
||||||
ctxt->nameTab[ctxt->nameNr] = value;
|
ctxt->nameTab[ctxt->nameNr] = value;
|
||||||
ctxt->name = value;
|
ctxt->name = value;
|
||||||
ctxt->pushTab[ctxt->nameNr * 3] = (void *) prefix;
|
ctxt->pushTab[ctxt->nameNr * 4] = (void *) prefix;
|
||||||
ctxt->pushTab[ctxt->nameNr * 3 + 1] = (void *) URI;
|
ctxt->pushTab[ctxt->nameNr * 4 + 1] = (void *) URI;
|
||||||
ctxt->pushTab[ctxt->nameNr * 3 + 2] = (void *) (ptrdiff_t) nsNr;
|
ctxt->pushTab[ctxt->nameNr * 4 + 2] = (void *) (ptrdiff_t) line;
|
||||||
|
ctxt->pushTab[ctxt->nameNr * 4 + 3] = (void *) (ptrdiff_t) nsNr;
|
||||||
return (ctxt->nameNr++);
|
return (ctxt->nameNr++);
|
||||||
mem_error:
|
mem_error:
|
||||||
xmlErrMemory(ctxt, NULL);
|
xmlErrMemory(ctxt, NULL);
|
||||||
@@ -9998,7 +10001,7 @@ xmlParseElementStart(xmlParserCtxtPtr ctxt) {
|
|||||||
return(-1);
|
return(-1);
|
||||||
}
|
}
|
||||||
if (ctxt->sax2)
|
if (ctxt->sax2)
|
||||||
nameNsPush(ctxt, name, prefix, URI, ctxt->nsNr - nsNr);
|
nameNsPush(ctxt, name, prefix, URI, line, ctxt->nsNr - nsNr);
|
||||||
#ifdef LIBXML_SAX1_ENABLED
|
#ifdef LIBXML_SAX1_ENABLED
|
||||||
else
|
else
|
||||||
namePush(ctxt, name);
|
namePush(ctxt, name);
|
||||||
@@ -10095,10 +10098,11 @@ xmlParseElementEnd(xmlParserCtxtPtr ctxt) {
|
|||||||
* parse the end of tag: '</' should be here.
|
* parse the end of tag: '</' should be here.
|
||||||
*/
|
*/
|
||||||
if (ctxt->sax2) {
|
if (ctxt->sax2) {
|
||||||
const xmlChar *prefix = ctxt->pushTab[ctxt->nameNr * 3 - 3];
|
const xmlChar *prefix = ctxt->pushTab[ctxt->nameNr * 4 - 4];
|
||||||
const xmlChar *URI = ctxt->pushTab[ctxt->nameNr * 3 - 2];
|
const xmlChar *URI = ctxt->pushTab[ctxt->nameNr * 4 - 3];
|
||||||
int nsNr = (ptrdiff_t) ctxt->pushTab[ctxt->nameNr * 3 - 1];
|
int line = (ptrdiff_t) ctxt->pushTab[ctxt->nameNr * 4 - 2];
|
||||||
xmlParseEndTag2(ctxt, prefix, URI, 0, nsNr, 0);
|
int nsNr = (ptrdiff_t) ctxt->pushTab[ctxt->nameNr * 4 - 1];
|
||||||
|
xmlParseEndTag2(ctxt, prefix, URI, line, nsNr, 0);
|
||||||
namePop(ctxt);
|
namePop(ctxt);
|
||||||
}
|
}
|
||||||
#ifdef LIBXML_SAX1_ENABLED
|
#ifdef LIBXML_SAX1_ENABLED
|
||||||
@@ -11373,6 +11377,7 @@ xmlParseTryOrFinish(xmlParserCtxtPtr ctxt, int terminate) {
|
|||||||
const xmlChar *name;
|
const xmlChar *name;
|
||||||
const xmlChar *prefix = NULL;
|
const xmlChar *prefix = NULL;
|
||||||
const xmlChar *URI = NULL;
|
const xmlChar *URI = NULL;
|
||||||
|
int line = ctxt->input->line;
|
||||||
int nsNr = ctxt->nsNr;
|
int nsNr = ctxt->nsNr;
|
||||||
|
|
||||||
if ((avail < 2) && (ctxt->inputNr == 1))
|
if ((avail < 2) && (ctxt->inputNr == 1))
|
||||||
@@ -11471,7 +11476,8 @@ xmlParseTryOrFinish(xmlParserCtxtPtr ctxt, int terminate) {
|
|||||||
spacePop(ctxt);
|
spacePop(ctxt);
|
||||||
}
|
}
|
||||||
if (ctxt->sax2)
|
if (ctxt->sax2)
|
||||||
nameNsPush(ctxt, name, prefix, URI, ctxt->nsNr - nsNr);
|
nameNsPush(ctxt, name, prefix, URI, line,
|
||||||
|
ctxt->nsNr - nsNr);
|
||||||
#ifdef LIBXML_SAX1_ENABLED
|
#ifdef LIBXML_SAX1_ENABLED
|
||||||
else
|
else
|
||||||
namePush(ctxt, name);
|
namePush(ctxt, name);
|
||||||
@@ -11593,10 +11599,12 @@ xmlParseTryOrFinish(xmlParserCtxtPtr ctxt, int terminate) {
|
|||||||
}
|
}
|
||||||
if (ctxt->sax2) {
|
if (ctxt->sax2) {
|
||||||
xmlParseEndTag2(ctxt,
|
xmlParseEndTag2(ctxt,
|
||||||
(void *) ctxt->pushTab[ctxt->nameNr * 3 - 3],
|
(void *) ctxt->pushTab[ctxt->nameNr * 4 - 4],
|
||||||
(void *) ctxt->pushTab[ctxt->nameNr * 3 - 2], 0,
|
(void *) ctxt->pushTab[ctxt->nameNr * 4 - 3],
|
||||||
|
(int) (ptrdiff_t)
|
||||||
|
ctxt->pushTab[ctxt->nameNr * 4 - 2],
|
||||||
(int) (ptrdiff_t)
|
(int) (ptrdiff_t)
|
||||||
ctxt->pushTab[ctxt->nameNr * 3 - 1], 0);
|
ctxt->pushTab[ctxt->nameNr * 4 - 1], 0);
|
||||||
nameNsPop(ctxt);
|
nameNsPop(ctxt);
|
||||||
}
|
}
|
||||||
#ifdef LIBXML_SAX1_ENABLED
|
#ifdef LIBXML_SAX1_ENABLED
|
||||||
|
@@ -10,7 +10,7 @@ import libxml2
|
|||||||
libxml2.debugMemory(1)
|
libxml2.debugMemory(1)
|
||||||
|
|
||||||
expect="""--> (3) xmlns: URI foo is not absolute
|
expect="""--> (3) xmlns: URI foo is not absolute
|
||||||
--> (4) Opening and ending tag mismatch: x line 0 and y
|
--> (4) Opening and ending tag mismatch: x line 1 and y
|
||||||
"""
|
"""
|
||||||
|
|
||||||
err=""
|
err=""
|
||||||
|
@@ -1,10 +1,10 @@
|
|||||||
./test/errors/759398.xml:210: parser error : StartTag: invalid element name
|
./test/errors/759398.xml:210: parser error : StartTag: invalid element name
|
||||||
need to worry about parsers whi<! don't expand PErefs finding
|
need to worry about parsers whi<! don't expand PErefs finding
|
||||||
^
|
^
|
||||||
./test/errors/759398.xml:309: parser error : Opening and ending tag mismatch: №№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№m line 205 and termdef
|
./test/errors/759398.xml:309: parser error : Opening and ending tag mismatch: №№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№m line 308 and termdef
|
||||||
and provide access to their content and structure.</termdef> <termdef
|
and provide access to their content and structure.</termdef> <termdef
|
||||||
^
|
^
|
||||||
./test/errors/759398.xml:314: parser error : Opening and ending tag mismatch: spec line 205 and p
|
./test/errors/759398.xml:314: parser error : Opening and ending tag mismatch: spec line 50 and p
|
||||||
data and the information it must provide to the application.</p>
|
data and the information it must provide to the application.</p>
|
||||||
^
|
^
|
||||||
./test/errors/759398.xml:316: parser error : Extra content at the end of the document
|
./test/errors/759398.xml:316: parser error : Extra content at the end of the document
|
||||||
|
@@ -1,10 +1,10 @@
|
|||||||
./test/errors/759398.xml:210: parser error : StartTag: invalid element name
|
./test/errors/759398.xml:210: parser error : StartTag: invalid element name
|
||||||
need to worry about parsers whi<! don't expand PErefs finding
|
need to worry about parsers whi<! don't expand PErefs finding
|
||||||
^
|
^
|
||||||
./test/errors/759398.xml:309: parser error : Opening and ending tag mismatch: №№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№m line 205 and termdef
|
./test/errors/759398.xml:309: parser error : Opening and ending tag mismatch: №№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№№m line 308 and termdef
|
||||||
and provide access to their content and structure.</termdef> <termdef
|
and provide access to their content and structure.</termdef> <termdef
|
||||||
^
|
^
|
||||||
./test/errors/759398.xml:314: parser error : Opening and ending tag mismatch: spec line 205 and p
|
./test/errors/759398.xml:314: parser error : Opening and ending tag mismatch: spec line 50 and p
|
||||||
data and the information it must provide to the application.</p>
|
data and the information it must provide to the application.</p>
|
||||||
^
|
^
|
||||||
./test/errors/759398.xml:316: parser error : Extra content at the end of the document
|
./test/errors/759398.xml:316: parser error : Extra content at the end of the document
|
||||||
|
Reference in New Issue
Block a user