mirror of
https://gitlab.gnome.org/GNOME/libxml2
synced 2025-03-28 21:33:13 +00:00
parser: Fix parsing of doctype declarations
Fix some long-standing issues. Fixes #504.
This commit is contained in:
parent
c13fcc1910
commit
b4d3d87ed2
24
parser.c
24
parser.c
@ -8238,7 +8238,10 @@ xmlParseDocTypeDecl(xmlParserCtxtPtr ctxt) {
|
||||
*/
|
||||
SKIP(9);
|
||||
|
||||
SKIP_BLANKS;
|
||||
if (SKIP_BLANKS == 0) {
|
||||
xmlFatalErrMsg(ctxt, XML_ERR_SPACE_REQUIRED,
|
||||
"Space required after 'DOCTYPE'\n");
|
||||
}
|
||||
|
||||
/*
|
||||
* Parse the DOCTYPE name.
|
||||
@ -8272,20 +8275,9 @@ xmlParseDocTypeDecl(xmlParserCtxtPtr ctxt) {
|
||||
(!ctxt->disableSAX))
|
||||
ctxt->sax->internalSubset(ctxt->userData, name, ExternalID, URI);
|
||||
|
||||
/*
|
||||
* Is there any internal subset declarations ?
|
||||
* they are handled separately in xmlParseInternalSubset()
|
||||
*/
|
||||
if (RAW == '[')
|
||||
return;
|
||||
|
||||
/*
|
||||
* We should be at the end of the DOCTYPE declaration.
|
||||
*/
|
||||
if (RAW != '>') {
|
||||
if ((RAW != '[') && (RAW != '>')) {
|
||||
xmlFatalErr(ctxt, XML_ERR_DOCTYPE_NOT_FINISHED, NULL);
|
||||
}
|
||||
NEXT;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -10782,7 +10774,9 @@ xmlParseDocument(xmlParserCtxtPtr ctxt) {
|
||||
xmlParseDocTypeDecl(ctxt);
|
||||
if (RAW == '[') {
|
||||
xmlParseInternalSubset(ctxt);
|
||||
}
|
||||
} else if (RAW == '>') {
|
||||
NEXT;
|
||||
}
|
||||
|
||||
/*
|
||||
* Create and update the external subset.
|
||||
@ -11508,6 +11502,8 @@ xmlParseTryOrFinish(xmlParserCtxtPtr ctxt, int terminate) {
|
||||
if (RAW == '[') {
|
||||
ctxt->instate = XML_PARSER_DTD;
|
||||
} else {
|
||||
if (RAW == '>')
|
||||
NEXT;
|
||||
/*
|
||||
* Create and update the external subset.
|
||||
*/
|
||||
|
@ -1,3 +1,6 @@
|
||||
./test/errors/759573.xml:1: parser error : Space required after 'DOCTYPE'
|
||||
<?h?><!DOCTYPEt[<!ELEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ00
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : Space required after '<!ENTITY'
|
||||
ELEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITY
|
||||
^
|
||||
@ -7,15 +10,9 @@ LEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz
|
||||
./test/errors/759573.xml:1: parser error : Entity value required
|
||||
LEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : PEReference: no name
|
||||
./test/errors/759573.xml:1: parser error : Entity 'xx' not defined
|
||||
T t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz>%xx;
|
||||
^
|
||||
Entity: line 1:
|
||||
%<![INCLUDE[000%ஸ000%z;
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : Content error in the internal subset
|
||||
T t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz>%xx;
|
||||
^
|
||||
Entity: line 1:
|
||||
%<![INCLUDE[000%ஸ000%z;
|
||||
^
|
||||
|
@ -1,3 +1,6 @@
|
||||
./test/errors/759573.xml:1: parser error : Space required after 'DOCTYPE'
|
||||
<?h?><!DOCTYPEt[<!ELEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ00
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : Space required after '<!ENTITY'
|
||||
ELEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITY
|
||||
^
|
||||
@ -7,15 +10,9 @@ LEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz
|
||||
./test/errors/759573.xml:1: parser error : Entity value required
|
||||
LEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : PEReference: no name
|
||||
./test/errors/759573.xml:1: parser warning : Entity 'xx' not defined
|
||||
T t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz>%xx;
|
||||
^
|
||||
Entity: line 1:
|
||||
%<![INCLUDE[000%ஸ000%z;
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : Content error in the internal subset
|
||||
T t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz>%xx;
|
||||
^
|
||||
Entity: line 1:
|
||||
%<![INCLUDE[000%ஸ000%z;
|
||||
^
|
||||
|
@ -1,22 +1,4 @@
|
||||
./test/errors/759573.xml:1: parser error : Space required after '<!ENTITY'
|
||||
ELEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITY
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : Space required after the entity name
|
||||
LEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : Entity value required
|
||||
LEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : PEReference: no name
|
||||
T t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz>%xx;
|
||||
^
|
||||
Entity: line 1:
|
||||
%<![INCLUDE[000%ஸ000%z;
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : Content error in the internal subset
|
||||
T t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ000%z;'><!ENTITYz>%xx;
|
||||
^
|
||||
Entity: line 1:
|
||||
%<![INCLUDE[000%ஸ000%z;
|
||||
^
|
||||
./test/errors/759573.xml:1: parser error : Space required after 'DOCTYPE'
|
||||
<?h?><!DOCTYPEt[<!ELEMENT t (A)><!ENTITY % xx '%<![INCLUDE[000%ஸ00
|
||||
^
|
||||
./test/errors/759573.xml : failed to parse
|
||||
|
3
result/errors/doctype1.xml.ent
Normal file
3
result/errors/doctype1.xml.ent
Normal file
@ -0,0 +1,3 @@
|
||||
./test/errors/doctype1.xml:1: parser error : Start tag expected, '<' not found
|
||||
<!DOCTYPE doc>[]>
|
||||
^
|
3
result/errors/doctype1.xml.err
Normal file
3
result/errors/doctype1.xml.err
Normal file
@ -0,0 +1,3 @@
|
||||
./test/errors/doctype1.xml:1: parser error : Start tag expected, '<' not found
|
||||
<!DOCTYPE doc>[]>
|
||||
^
|
4
result/errors/doctype1.xml.str
Normal file
4
result/errors/doctype1.xml.str
Normal file
@ -0,0 +1,4 @@
|
||||
./test/errors/doctype1.xml:1: parser error : Start tag expected, '<' not found
|
||||
<!DOCTYPE doc>[]>
|
||||
^
|
||||
./test/errors/doctype1.xml : failed to parse
|
3
result/errors/doctype2.xml.ent
Normal file
3
result/errors/doctype2.xml.ent
Normal file
@ -0,0 +1,3 @@
|
||||
./test/errors/doctype2.xml:1: parser error : Space required after 'DOCTYPE'
|
||||
<!DOCTYPEdoc>
|
||||
^
|
3
result/errors/doctype2.xml.err
Normal file
3
result/errors/doctype2.xml.err
Normal file
@ -0,0 +1,3 @@
|
||||
./test/errors/doctype2.xml:1: parser error : Space required after 'DOCTYPE'
|
||||
<!DOCTYPEdoc>
|
||||
^
|
4
result/errors/doctype2.xml.str
Normal file
4
result/errors/doctype2.xml.str
Normal file
@ -0,0 +1,4 @@
|
||||
./test/errors/doctype2.xml:1: parser error : Space required after 'DOCTYPE'
|
||||
<!DOCTYPEdoc>
|
||||
^
|
||||
./test/errors/doctype2.xml : failed to parse
|
2
test/errors/doctype1.xml
Normal file
2
test/errors/doctype1.xml
Normal file
@ -0,0 +1,2 @@
|
||||
<!DOCTYPE doc>[]>
|
||||
<doc/>
|
2
test/errors/doctype2.xml
Normal file
2
test/errors/doctype2.xml
Normal file
@ -0,0 +1,2 @@
|
||||
<!DOCTYPEdoc>
|
||||
<doc/>
|
Loading…
x
Reference in New Issue
Block a user