diff --git a/parserInternals.c b/parserInternals.c index 8e47bfa4203382266b82597804b6396bc0d8e44b_cGFyc2VySW50ZXJuYWxzLmM=..3fbb03dbf133bd9fdb9777f13d2d90be4b920be9_cGFyc2VySW50ZXJuYWxzLmM= 100644 --- a/parserInternals.c +++ b/parserInternals.c @@ -1345,6 +1345,7 @@ xmlParserInputPtr xmlNewStringInputStream(xmlParserCtxtPtr ctxt, const xmlChar *buffer) { xmlParserInputPtr input; + xmlParserInputBufferPtr buf; if (buffer == NULL) { xmlErrInternal(ctxt, "xmlNewStringInputStream string = NULL\n", @@ -1354,6 +1355,13 @@ if (xmlParserDebugEntities) xmlGenericError(xmlGenericErrorContext, "new fixed input: %.30s\n", buffer); + buf = xmlParserInputBufferCreateMem((const char *) buffer, + strlen((const char *) buffer), + XML_CHAR_ENCODING_NONE); + if (buf == NULL) { + xmlErrMemory(ctxt, NULL); + return(NULL); + } input = xmlNewInputStream(ctxt); if (input == NULL) { xmlErrMemory(ctxt, "couldn't allocate a new input stream\n"); @@ -1357,5 +1365,6 @@ input = xmlNewInputStream(ctxt); if (input == NULL) { xmlErrMemory(ctxt, "couldn't allocate a new input stream\n"); + xmlFreeParserInputBuffer(buf); return(NULL); } @@ -1360,9 +1369,7 @@ return(NULL); } - input->base = buffer; - input->cur = buffer; - input->length = xmlStrlen(buffer); - input->end = &buffer[input->length]; + input->buf = buf; + xmlBufResetInput(input->buf->buffer, input); return(input); }