1
0
mirror of https://gitlab.gnome.org/GNOME/libxml2.git synced 2025-01-26 10:03:34 +03:00

testrecurse: Support multiple huge docs

This commit is contained in:
Nick Wellnhofer 2022-12-21 17:05:54 +01:00
parent 079da5b26d
commit 106c4cdd4b

View File

@ -153,27 +153,41 @@ static void globfree(glob_t *pglob) {
#include <libxml/xmlIO.h>
typedef struct {
const char *URL;
const char *start;
const char *segment;
const char *finish;
} xmlHugeDocParts;
static const char *start = "<!DOCTYPE foo [\
<!ELEMENT foo (bar*)> \
<!ELEMENT bar (#PCDATA)> \
<!ATTLIST bar attr CDATA #IMPLIED> \
<!ENTITY a SYSTEM 'test/recurse/ga.ent'> \
<!ENTITY b SYSTEM 'test/recurse/gb.ent'> \
<!ENTITY c SYSTEM 'test/recurse/gc.ent'> \
<!ENTITY f 'some internal data'> \
<!ENTITY e '&f;&f;'> \
<!ENTITY d '&e;&e;'> \
]> \
<foo>";
static const xmlHugeDocParts hugeDocTable[] = {
{
"test/recurse/huge.xml",
"<!DOCTYPE foo ["
"<!ELEMENT foo (bar*)> "
"<!ELEMENT bar (#PCDATA)> "
"<!ATTLIST bar attr CDATA #IMPLIED> "
"<!ENTITY a SYSTEM 'ga.ent'> "
"<!ENTITY b SYSTEM 'gb.ent'> "
"<!ENTITY c SYSTEM 'gc.ent'> "
"<!ENTITY f 'some internal data'> "
"<!ENTITY e '&f;&f;'> "
"<!ENTITY d '&e;&e;'> "
"]> "
"<foo>",
static const char *segment =
" <bar attr='&e; &f; &d;'>&a; &b; &c; &e; &f; &d;</bar>\n"
" <bar>_123456789_123456789_123456789_123456789</bar>\n"
" <bar>_123456789_123456789_123456789_123456789</bar>\n"
" <bar>_123456789_123456789_123456789_123456789</bar>\n";
static const char *finish = "</foo>";
" <bar>_123456789_123456789_123456789_123456789</bar>\n",
"</foo>"
},
{ NULL, NULL, NULL, NULL }
};
static const xmlHugeDocParts *hugeDocParts;
static int curseg = 0;
static const char *current;
static int rlen;
@ -182,14 +196,22 @@ static int rlen;
* hugeMatch:
* @URI: an URI to test
*
* Check for an huge.xml query
* Check for a huge query
*
* Returns 1 if yes and 0 if another Input module should be used
*/
static int
hugeMatch(const char * URI) {
if ((URI != NULL) && (!strcmp(URI, "huge.xml")))
int i;
if (URI == NULL)
return(0);
for (i = 0; hugeDocTable[i].URL; i++) {
if (strcmp(URI, hugeDocTable[i].URL) == 0)
return(1);
}
return(0);
}
@ -197,26 +219,36 @@ hugeMatch(const char * URI) {
* hugeOpen:
* @URI: an URI to test
*
* Return a pointer to the huge.xml query handler, in this example simply
* Return a pointer to the huge query handler, in this example simply
* the current pointer...
*
* Returns an Input context or NULL in case or error
*/
static void *
hugeOpen(const char * URI) {
if ((URI == NULL) || (strcmp(URI, "huge.xml")))
int i;
if (URI == NULL)
return(NULL);
for (i = 0; hugeDocTable[i].URL; i++) {
if (strcmp(URI, hugeDocTable[i].URL) == 0) {
hugeDocParts = hugeDocTable + i;
curseg = 0;
rlen = strlen(start);
current = start;
current = hugeDocParts->start;
rlen = strlen(current);
return((void *) current);
}
}
return(NULL);
}
/**
* hugeClose:
* @context: the read context
*
* Close the huge.xml query handler
* Close the huge query handler
*
* Returns 0 or -1 in case of error
*/
@ -234,7 +266,7 @@ hugeClose(void * context) {
* @buffer: where to store data
* @len: number of bytes to read
*
* Implement an huge.xml query read.
* Implement an huge query read.
*
* Returns the number of bytes read or -1 in case of error
*/
@ -254,12 +286,11 @@ hugeRead(void *context, char *buffer, int len)
memcpy(buffer, current, len);
curseg ++;
if (curseg == MAX_NODES) {
rlen = strlen(finish);
current = finish;
current = hugeDocParts->finish;
} else {
rlen = strlen(segment);
current = segment;
current = hugeDocParts->segment;
}
rlen = strlen(current);
} else {
memcpy(buffer, current, len);
rlen -= len;
@ -794,9 +825,9 @@ notRecursiveHugeTest(const char *filename ATTRIBUTE_UNUSED,
initSAX(ctxt);
if ((options & OPT_NO_SUBST) == 0)
parserOptions |= XML_PARSE_NOENT;
doc = xmlCtxtReadFile(ctxt, "huge.xml", NULL, parserOptions);
doc = xmlCtxtReadFile(ctxt, "test/recurse/huge.xml", NULL, parserOptions);
if (doc == NULL) {
fprintf(stderr, "Failed to parse huge.xml with entities\n");
fprintf(stderr, "Failed to parse huge.xml\n");
res = 1;
} else {
xmlEntityPtr ent;