mirror of
https://gitlab.gnome.org/GNOME/libxml2
synced 2025-03-28 21:33:13 +00:00
* parser.c: reverted first patches for #319279 which led to #326295 and fixed the problem in xmlParseChunk() instead * test/ent11 result//ent11*: added test for #326295 to the regression suite Daniel
This commit is contained in:
parent
6795260135
commit
a617e24f32
@ -1,3 +1,10 @@
|
|||||||
|
Mon Jan 9 15:33:16 CET 2006 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
|
* parser.c: reverted first patches for #319279 which led to #326295
|
||||||
|
and fixed the problem in xmlParseChunk() instead
|
||||||
|
* test/ent11 result//ent11*: added test for #326295 to the regression
|
||||||
|
suite
|
||||||
|
|
||||||
Thu Jan 5 16:25:06 CET 2006 Daniel Veillard <daniel@veillard.com>
|
Thu Jan 5 16:25:06 CET 2006 Daniel Veillard <daniel@veillard.com>
|
||||||
|
|
||||||
* NEWS configure.in libxml.spec.in testapi.c doc/*: upated the news
|
* NEWS configure.in libxml.spec.in testapi.c doc/*: upated the news
|
||||||
|
17
parser.c
17
parser.c
@ -3539,16 +3539,12 @@ get_more:
|
|||||||
ctxt->input->cur = in;
|
ctxt->input->cur = in;
|
||||||
if (*in == 0xD) {
|
if (*in == 0xD) {
|
||||||
in++;
|
in++;
|
||||||
if (!*in) /* if end of current chunk return */
|
|
||||||
return;
|
|
||||||
if (*in == 0xA) {
|
if (*in == 0xA) {
|
||||||
ctxt->input->cur = in;
|
ctxt->input->cur = in;
|
||||||
in++;
|
in++;
|
||||||
ctxt->input->line++; ctxt->input->col = 1;
|
ctxt->input->line++; ctxt->input->col = 1;
|
||||||
continue; /* while */
|
continue; /* while */
|
||||||
}
|
}
|
||||||
if (!*in) /* if end of current chunk return */
|
|
||||||
return;
|
|
||||||
in--;
|
in--;
|
||||||
}
|
}
|
||||||
if (*in == '<') {
|
if (*in == '<') {
|
||||||
@ -3931,8 +3927,6 @@ get_more:
|
|||||||
ctxt->input->line++; ctxt->input->col = 1;
|
ctxt->input->line++; ctxt->input->col = 1;
|
||||||
continue; /* while */
|
continue; /* while */
|
||||||
}
|
}
|
||||||
if (!*in) /* if end of current chunk return */
|
|
||||||
return;
|
|
||||||
in--;
|
in--;
|
||||||
}
|
}
|
||||||
SHRINK;
|
SHRINK;
|
||||||
@ -10407,12 +10401,19 @@ encoding_error:
|
|||||||
int
|
int
|
||||||
xmlParseChunk(xmlParserCtxtPtr ctxt, const char *chunk, int size,
|
xmlParseChunk(xmlParserCtxtPtr ctxt, const char *chunk, int size,
|
||||||
int terminate) {
|
int terminate) {
|
||||||
|
int end_in_lf = 0;
|
||||||
|
|
||||||
if (ctxt == NULL)
|
if (ctxt == NULL)
|
||||||
return(XML_ERR_INTERNAL_ERROR);
|
return(XML_ERR_INTERNAL_ERROR);
|
||||||
if ((ctxt->errNo != XML_ERR_OK) && (ctxt->disableSAX == 1))
|
if ((ctxt->errNo != XML_ERR_OK) && (ctxt->disableSAX == 1))
|
||||||
return(ctxt->errNo);
|
return(ctxt->errNo);
|
||||||
if (ctxt->instate == XML_PARSER_START)
|
if (ctxt->instate == XML_PARSER_START)
|
||||||
xmlDetectSAX2(ctxt);
|
xmlDetectSAX2(ctxt);
|
||||||
|
if ((size > 0) && (chunk != NULL) && (!terminate) &&
|
||||||
|
(chunk[size - 1] == '\r')) {
|
||||||
|
end_in_lf = 1;
|
||||||
|
size--;
|
||||||
|
}
|
||||||
if ((size > 0) && (chunk != NULL) && (ctxt->input != NULL) &&
|
if ((size > 0) && (chunk != NULL) && (ctxt->input != NULL) &&
|
||||||
(ctxt->input->buf != NULL) && (ctxt->instate != XML_PARSER_EOF)) {
|
(ctxt->input->buf != NULL) && (ctxt->instate != XML_PARSER_EOF)) {
|
||||||
int base = ctxt->input->base - ctxt->input->buf->buffer->content;
|
int base = ctxt->input->base - ctxt->input->buf->buffer->content;
|
||||||
@ -10451,6 +10452,10 @@ xmlParseChunk(xmlParserCtxtPtr ctxt, const char *chunk, int size,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
xmlParseTryOrFinish(ctxt, terminate);
|
xmlParseTryOrFinish(ctxt, terminate);
|
||||||
|
if ((end_in_lf == 1) && (ctxt->input != NULL) &&
|
||||||
|
(ctxt->input->buf != NULL)) {
|
||||||
|
xmlParserInputBufferPush(ctxt->input->buf, 1, "\r");
|
||||||
|
}
|
||||||
if ((ctxt->errNo != XML_ERR_OK) && (ctxt->disableSAX == 1))
|
if ((ctxt->errNo != XML_ERR_OK) && (ctxt->disableSAX == 1))
|
||||||
return(ctxt->errNo);
|
return(ctxt->errNo);
|
||||||
if (terminate) {
|
if (terminate) {
|
||||||
|
5
result/ent11
Normal file
5
result/ent11
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!DOCTYPE doc [
|
||||||
|
<!ENTITY newl " ">
|
||||||
|
]>
|
||||||
|
<doc>&newl;</doc>
|
5
result/ent11.rde
Normal file
5
result/ent11.rde
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
0 10 doc 0 0
|
||||||
|
0 1 doc 0 0
|
||||||
|
1 14 #text 0 1
|
||||||
|
|
||||||
|
0 15 doc 0 0
|
4
result/ent11.rdr
Normal file
4
result/ent11.rdr
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
0 10 doc 0 0
|
||||||
|
0 1 doc 0 0
|
||||||
|
1 5 newl 0 0
|
||||||
|
0 15 doc 0 0
|
13
result/ent11.sax
Normal file
13
result/ent11.sax
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
SAX.setDocumentLocator()
|
||||||
|
SAX.startDocument()
|
||||||
|
SAX.internalSubset(doc, , )
|
||||||
|
SAX.entityDecl(newl, 1, (null), (null),
)
|
||||||
|
SAX.getEntity(newl)
|
||||||
|
SAX.externalSubset(doc, , )
|
||||||
|
SAX.startElement(doc)
|
||||||
|
SAX.getEntity(newl)
|
||||||
|
SAX.characters(
|
||||||
|
, 1)
|
||||||
|
SAX.reference(newl)
|
||||||
|
SAX.endElement(doc)
|
||||||
|
SAX.endDocument()
|
13
result/ent11.sax2
Normal file
13
result/ent11.sax2
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
SAX.setDocumentLocator()
|
||||||
|
SAX.startDocument()
|
||||||
|
SAX.internalSubset(doc, , )
|
||||||
|
SAX.entityDecl(newl, 1, (null), (null),
)
|
||||||
|
SAX.getEntity(newl)
|
||||||
|
SAX.externalSubset(doc, , )
|
||||||
|
SAX.startElementNs(doc, NULL, NULL, 0, 0, 0)
|
||||||
|
SAX.getEntity(newl)
|
||||||
|
SAX.characters(
|
||||||
|
, 1)
|
||||||
|
SAX.reference(newl)
|
||||||
|
SAX.endElementNs(doc, NULL, NULL)
|
||||||
|
SAX.endDocument()
|
6
result/noent/ent11
Normal file
6
result/noent/ent11
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!DOCTYPE doc [
|
||||||
|
<!ENTITY newl " ">
|
||||||
|
]>
|
||||||
|
<doc>
|
||||||
|
</doc>
|
6
test/ent11
Normal file
6
test/ent11
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8" ?>
|
||||||
|
<!DOCTYPE doc [
|
||||||
|
<!ENTITY newl " ">
|
||||||
|
]>
|
||||||
|
|
||||||
|
<doc>&newl;</doc>
|
Loading…
x
Reference in New Issue
Block a user