mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-26 00:37:43 +03:00 
			
		
		
		
	parser: Introduce new input API
- xmlInputCreateUrl - xmlInputCreateMemory - xmlInputCreateString - xmlInputCreateFd - xmlInputCreateIO - xmlInputSetEncoding These functions don't take a parser context and work on xmlParserInputs, replacing functions working on xmlParserInputBuffers. xmlInputCreateUrl and xmlInputSetEncoding offer fine-grained error handling. Several XML_INPUT_* flags offer additional control.
This commit is contained in:
		| @@ -356,6 +356,29 @@ XMLPUBFUN xmlParserInputPtr | |||||||
| XMLPUBFUN xmlParserInputPtr | XMLPUBFUN xmlParserInputPtr | ||||||
| 			xmlNewInputStream	(xmlParserCtxtPtr ctxt); | 			xmlNewInputStream	(xmlParserCtxtPtr ctxt); | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * New input API | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #define XML_INPUT_BUF_STATIC		(1u << 1) | ||||||
|  | #define XML_INPUT_BUF_ZERO_TERMINATED	(1u << 2) | ||||||
|  | #define XML_INPUT_UNZIP                 (1u << 3) | ||||||
|  |  | ||||||
|  | XMLPUBFUN int | ||||||
|  | xmlInputCreateUrl(const char *url, int flags, xmlParserInputPtr *out); | ||||||
|  | XMLPUBFUN xmlParserInputPtr | ||||||
|  | xmlInputCreateMemory(const char *url, const void *mem, size_t size, | ||||||
|  |                      int flags); | ||||||
|  | XMLPUBFUN xmlParserInputPtr | ||||||
|  | xmlInputCreateString(const char *url, const char *str, int flags); | ||||||
|  | XMLPUBFUN xmlParserInputPtr | ||||||
|  | xmlInputCreateFd(const char *url, int fd, int flags); | ||||||
|  | XMLPUBFUN xmlParserInputPtr | ||||||
|  | xmlInputCreateIO(const char *url, xmlInputReadCallback ioRead, | ||||||
|  |                  xmlInputCloseCallback ioClose, void *ioCtxt, int flags); | ||||||
|  | XMLPUBFUN int | ||||||
|  | xmlInputSetEncoding(xmlParserInputPtr input, const char *encoding); | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Namespaces. |  * Namespaces. | ||||||
|  */ |  */ | ||||||
|   | |||||||
| @@ -88,10 +88,6 @@ xmlParserNsUpdateSax(xmlParserCtxtPtr ctxt, const xmlChar *prefix, | |||||||
| XML_HIDDEN void * | XML_HIDDEN void * | ||||||
| xmlParserNsLookupSax(xmlParserCtxtPtr ctxt, const xmlChar *prefix); | xmlParserNsLookupSax(xmlParserCtxtPtr ctxt, const xmlChar *prefix); | ||||||
|  |  | ||||||
| #define XML_INPUT_BUF_STATIC		(1u << 1) |  | ||||||
| #define XML_INPUT_BUF_ZERO_TERMINATED	(1u << 2) |  | ||||||
| #define XML_INPUT_UNZIP                 (1u << 3) |  | ||||||
|  |  | ||||||
| XML_HIDDEN xmlParserInputPtr | XML_HIDDEN xmlParserInputPtr | ||||||
| xmlNewInputURL(xmlParserCtxtPtr ctxt, const char *url, const char *publicId, | xmlNewInputURL(xmlParserCtxtPtr ctxt, const char *url, const char *publicId, | ||||||
|                const char *encoding, int flags); |                const char *encoding, int flags); | ||||||
|   | |||||||
| @@ -1105,8 +1105,6 @@ xmlSwitchEncoding(xmlParserCtxtPtr ctxt, xmlCharEncoding enc) | |||||||
|  * @input:  the input strea, |  * @input:  the input strea, | ||||||
|  * @encoding:  the encoding name |  * @encoding:  the encoding name | ||||||
|  * |  * | ||||||
|  * Available since 2.13.0. |  | ||||||
|  * |  | ||||||
|  * Returns 0 in case of success, -1 otherwise |  * Returns 0 in case of success, -1 otherwise | ||||||
|  */ |  */ | ||||||
| static int | static int | ||||||
| @@ -1151,27 +1149,25 @@ xmlSwitchEncodingName(xmlParserCtxtPtr ctxt, const char *encoding) { | |||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * xmlSwitchInputEncoding: |  * xmlInputSetEncodingHandler: | ||||||
|  * @ctxt:  the parser context, only for error reporting |  | ||||||
|  * @input:  the input stream |  * @input:  the input stream | ||||||
|  * @handler:  the encoding handler |  * @handler:  the encoding handler | ||||||
|  * |  * | ||||||
|  * DEPRECATED: Internal function, don't use. |  | ||||||
|  * |  | ||||||
|  * Use encoding handler to decode input data. |  * Use encoding handler to decode input data. | ||||||
|  * |  * | ||||||
|  * Returns 0 in case of success, -1 otherwise |  * Closes the handler on error. | ||||||
|  |  * | ||||||
|  |  * Returns an xmlParserErrors code. | ||||||
|  */ |  */ | ||||||
| int | static int | ||||||
| xmlSwitchInputEncoding(xmlParserCtxtPtr ctxt, xmlParserInputPtr input, | xmlInputSetEncodingHandler(xmlParserInputPtr input, | ||||||
|                        xmlCharEncodingHandlerPtr handler) |                            xmlCharEncodingHandlerPtr handler) { | ||||||
| { |  | ||||||
|     int nbchars; |     int nbchars; | ||||||
|     xmlParserInputBufferPtr in; |     xmlParserInputBufferPtr in; | ||||||
|  |  | ||||||
|     if ((input == NULL) || (input->buf == NULL)) { |     if ((input == NULL) || (input->buf == NULL)) { | ||||||
|         xmlCharEncCloseFunc(handler); |         xmlCharEncCloseFunc(handler); | ||||||
| 	return (-1); | 	return(XML_ERR_ARGUMENT); | ||||||
|     } |     } | ||||||
|     in = input->buf; |     in = input->buf; | ||||||
|  |  | ||||||
| @@ -1187,7 +1183,7 @@ xmlSwitchInputEncoding(xmlParserCtxtPtr ctxt, xmlParserInputPtr input, | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (in->encoder == handler) |     if (in->encoder == handler) | ||||||
|         return (0); |         return(XML_ERR_OK); | ||||||
|  |  | ||||||
|     if (in->encoder != NULL) { |     if (in->encoder != NULL) { | ||||||
|         /* |         /* | ||||||
| @@ -1201,7 +1197,7 @@ xmlSwitchInputEncoding(xmlParserCtxtPtr ctxt, xmlParserInputPtr input, | |||||||
|  |  | ||||||
|         xmlCharEncCloseFunc(in->encoder); |         xmlCharEncCloseFunc(in->encoder); | ||||||
|         in->encoder = handler; |         in->encoder = handler; | ||||||
|         return (0); |         return(XML_ERR_OK); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     in->encoder = handler; |     in->encoder = handler; | ||||||
| @@ -1214,10 +1210,8 @@ xmlSwitchInputEncoding(xmlParserCtxtPtr ctxt, xmlParserInputPtr input, | |||||||
|         size_t processed; |         size_t processed; | ||||||
|  |  | ||||||
|         buf = xmlBufCreate(); |         buf = xmlBufCreate(); | ||||||
|         if (buf == NULL) { |         if (buf == NULL) | ||||||
|             xmlCtxtErrMemory(ctxt); |             return(XML_ERR_NO_MEMORY); | ||||||
|             return(-1); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         /* |         /* | ||||||
|          * Shrink the current input buffer. |          * Shrink the current input buffer. | ||||||
| @@ -1232,15 +1226,63 @@ xmlSwitchInputEncoding(xmlParserCtxtPtr ctxt, xmlParserInputPtr input, | |||||||
|  |  | ||||||
|         nbchars = xmlCharEncInput(in); |         nbchars = xmlCharEncInput(in); | ||||||
|         xmlBufResetInput(in->buffer, input); |         xmlBufResetInput(in->buffer, input); | ||||||
|         if (nbchars == XML_ENC_ERR_MEMORY) { |         if (nbchars < 0) | ||||||
|             xmlCtxtErrMemory(ctxt); |             return(in->error); | ||||||
|         } else if (nbchars < 0) { |  | ||||||
|             xmlCtxtErrIO(ctxt, in->error, NULL); |  | ||||||
|             xmlHaltParser(ctxt); |  | ||||||
|             return (-1); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     return(XML_ERR_OK); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * xmlInputSetEncoding: | ||||||
|  |  * @input:  the input stream | ||||||
|  |  * @encoding:  the encoding name | ||||||
|  |  * | ||||||
|  |  * Use specified encoding to decode input data. This overrides the | ||||||
|  |  * encoding found in the XML declaration. | ||||||
|  |  * | ||||||
|  |  * Available since 2.14.0. | ||||||
|  |  * | ||||||
|  |  * Returns an xmlParserErrors code. | ||||||
|  |  */ | ||||||
|  | int | ||||||
|  | xmlInputSetEncoding(xmlParserInputPtr input, const char *encoding) { | ||||||
|  |     xmlCharEncodingHandlerPtr handler; | ||||||
|  |     int res; | ||||||
|  |  | ||||||
|  |     if (encoding == NULL) | ||||||
|  |         return(XML_ERR_ARGUMENT); | ||||||
|  |  | ||||||
|  |     res = xmlOpenCharEncodingHandler(encoding, /* output */ 0, &handler); | ||||||
|  |     if (res != 0) | ||||||
|  |         return(res); | ||||||
|  |  | ||||||
|  |     return(xmlInputSetEncodingHandler(input, handler)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * xmlSwitchInputEncoding: | ||||||
|  |  * @ctxt:  the parser context, only for error reporting | ||||||
|  |  * @input:  the input stream | ||||||
|  |  * @handler:  the encoding handler | ||||||
|  |  * | ||||||
|  |  * DEPRECATED: Internal function, don't use. | ||||||
|  |  * | ||||||
|  |  * Use encoding handler to decode input data. | ||||||
|  |  * | ||||||
|  |  * Returns 0 in case of success, -1 otherwise | ||||||
|  |  */ | ||||||
|  | int | ||||||
|  | xmlSwitchInputEncoding(xmlParserCtxtPtr ctxt, xmlParserInputPtr input, | ||||||
|  |                        xmlCharEncodingHandlerPtr handler) { | ||||||
|  |     int code = xmlInputSetEncodingHandler(input, handler); | ||||||
|  |  | ||||||
|  |     if (code != XML_ERR_OK) { | ||||||
|  |         xmlCtxtErrIO(ctxt, code, NULL); | ||||||
|  |         return(-1); | ||||||
|     } |     } | ||||||
|     return (0); |  | ||||||
|  |     return(0); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -1545,25 +1587,25 @@ xmlNewInputURL(xmlParserCtxtPtr ctxt, const char *url, const char *publicId, | |||||||
|  |  | ||||||
| /** | /** | ||||||
|  * xmlNewInputInternal: |  * xmlNewInputInternal: | ||||||
|  * @ctxt:  parser context |  | ||||||
|  * @buf:  parser input buffer |  * @buf:  parser input buffer | ||||||
|  * @filename:  filename or URL |  * @filename:  filename or URL | ||||||
|  * @encoding:  character encoding (optional) |  | ||||||
|  * |  * | ||||||
|  * Internal helper function. |  * Internal helper function. | ||||||
|  * |  * | ||||||
|  * Returns a new parser input. |  * Returns a new parser input. | ||||||
|  */ |  */ | ||||||
| static xmlParserInputPtr | static xmlParserInputPtr | ||||||
| xmlNewInputInternal(xmlParserCtxtPtr ctxt, xmlParserInputBufferPtr buf, | xmlNewInputInternal(xmlParserInputBufferPtr buf, const char *filename) { | ||||||
|                     const char *filename, const char *encoding) { |  | ||||||
|     xmlParserInputPtr input; |     xmlParserInputPtr input; | ||||||
|  |  | ||||||
|     input = xmlNewInputStream(ctxt); |     input = (xmlParserInputPtr) xmlMalloc(sizeof(xmlParserInput)); | ||||||
|     if (input == NULL) { |     if (input == NULL) { | ||||||
| 	xmlFreeParserInputBuffer(buf); | 	xmlFreeParserInputBuffer(buf); | ||||||
| 	return(NULL); | 	return(NULL); | ||||||
|     } |     } | ||||||
|  |     memset(input, 0, sizeof(xmlParserInput)); | ||||||
|  |     input->line = 1; | ||||||
|  |     input->col = 1; | ||||||
|  |  | ||||||
|     input->buf = buf; |     input->buf = buf; | ||||||
|     xmlBufResetInput(input->buf->buffer, input); |     xmlBufResetInput(input->buf->buffer, input); | ||||||
| @@ -1571,25 +1613,19 @@ xmlNewInputInternal(xmlParserCtxtPtr ctxt, xmlParserInputBufferPtr buf, | |||||||
|     if (filename != NULL) { |     if (filename != NULL) { | ||||||
|         input->filename = xmlMemStrdup(filename); |         input->filename = xmlMemStrdup(filename); | ||||||
|         if (input->filename == NULL) { |         if (input->filename == NULL) { | ||||||
|             xmlCtxtErrMemory(ctxt); |  | ||||||
|             xmlFreeInputStream(input); |             xmlFreeInputStream(input); | ||||||
|             return(NULL); |             return(NULL); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (encoding != NULL) |  | ||||||
|         xmlSwitchInputEncodingName(ctxt, input, encoding); |  | ||||||
|  |  | ||||||
|     return(input); |     return(input); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * xmlNewInputMemory: |  * xmlInputCreateMemory: | ||||||
|  * @ctxt:  parser context |  | ||||||
|  * @url:  base URL (optional) |  * @url:  base URL (optional) | ||||||
|  * @mem:  pointer to char array |  * @mem:  pointer to char array | ||||||
|  * @size:  size of array |  * @size:  size of array | ||||||
|  * @encoding:  character encoding (optional) |  | ||||||
|  * @flags:  optimization hints |  * @flags:  optimization hints | ||||||
|  * |  * | ||||||
|  * Creates a new parser input to read from a memory area. |  * Creates a new parser input to read from a memory area. | ||||||
| @@ -1605,32 +1641,61 @@ xmlNewInputInternal(xmlParserCtxtPtr ctxt, xmlParserInputBufferPtr buf, | |||||||
|  * area must contain a zero byte after the buffer at position @size. |  * area must contain a zero byte after the buffer at position @size. | ||||||
|  * This can avoid temporary copies. |  * This can avoid temporary copies. | ||||||
|  * |  * | ||||||
|  * Returns a new parser input. |  * Available since 2.14.0. | ||||||
|  |  * | ||||||
|  |  * Returns a new parser input or NULL if a memory allocation failed. | ||||||
|  |  */ | ||||||
|  | xmlParserInputPtr | ||||||
|  | xmlInputCreateMemory(const char *url, const void *mem, size_t size, | ||||||
|  |                      int flags) { | ||||||
|  |     xmlParserInputBufferPtr buf; | ||||||
|  |  | ||||||
|  |     if (mem == NULL) | ||||||
|  | 	return(NULL); | ||||||
|  |  | ||||||
|  |     buf = xmlNewInputBufferMemory(mem, size, flags, XML_CHAR_ENCODING_NONE); | ||||||
|  |     if (buf == NULL) | ||||||
|  |         return(NULL); | ||||||
|  |  | ||||||
|  |     return(xmlNewInputInternal(buf, url)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * xmlNewInputMemory: | ||||||
|  |  * @ctxt:  parser context | ||||||
|  |  * @url:  base URL (optional) | ||||||
|  |  * @mem:  pointer to char array | ||||||
|  |  * @size:  size of array | ||||||
|  |  * @encoding:  character encoding (optional) | ||||||
|  |  * @flags:  optimization hints | ||||||
|  |  * | ||||||
|  |  * Returns a new parser input or NULL in case of error. | ||||||
|  */ |  */ | ||||||
| xmlParserInputPtr | xmlParserInputPtr | ||||||
| xmlNewInputMemory(xmlParserCtxtPtr ctxt, const char *url, | xmlNewInputMemory(xmlParserCtxtPtr ctxt, const char *url, | ||||||
|                   const void *mem, size_t size, |                   const void *mem, size_t size, | ||||||
|                   const char *encoding, int flags) { |                   const char *encoding, int flags) { | ||||||
|     xmlParserInputBufferPtr buf; |     xmlParserInputPtr input; | ||||||
|  |  | ||||||
|     if ((ctxt == NULL) || (mem == NULL)) |     if ((ctxt == NULL) || (mem == NULL)) | ||||||
| 	return(NULL); | 	return(NULL); | ||||||
|  |  | ||||||
|     buf = xmlNewInputBufferMemory(mem, size, flags, XML_CHAR_ENCODING_NONE); |     input = xmlInputCreateMemory(url, mem, size, flags); | ||||||
|     if (buf == NULL) { |     if (input == NULL) { | ||||||
|         xmlCtxtErrMemory(ctxt); |         xmlCtxtErrMemory(ctxt); | ||||||
|         return(NULL); |         return(NULL); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return(xmlNewInputInternal(ctxt, buf, url, encoding)); |     if (encoding != NULL) | ||||||
|  |         xmlSwitchInputEncodingName(ctxt, input, encoding); | ||||||
|  |  | ||||||
|  |     return(input); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * xmlNewInputString: |  * xmlInputCreateString: | ||||||
|  * @ctxt:  parser context |  | ||||||
|  * @url:  base URL (optional) |  * @url:  base URL (optional) | ||||||
|  * @str:  zero-terminated string |  * @str:  zero-terminated string | ||||||
|  * @encoding:  character encoding (optional) |  | ||||||
|  * @flags:  optimization hints |  * @flags:  optimization hints | ||||||
|  * |  * | ||||||
|  * Creates a new parser input to read from a zero-terminated string. |  * Creates a new parser input to read from a zero-terminated string. | ||||||
| @@ -1642,23 +1707,83 @@ xmlNewInputMemory(xmlParserCtxtPtr ctxt, const char *url, | |||||||
|  * stay unchanged until parsing has finished. This can avoid |  * stay unchanged until parsing has finished. This can avoid | ||||||
|  * temporary copies. |  * temporary copies. | ||||||
|  * |  * | ||||||
|  |  * Available since 2.14.0. | ||||||
|  |  * | ||||||
|  |  * Returns a new parser input or NULL if a memory allocation failed. | ||||||
|  |  */ | ||||||
|  | xmlParserInputPtr | ||||||
|  | xmlInputCreateString(const char *url, const char *str, int flags) { | ||||||
|  |     xmlParserInputBufferPtr buf; | ||||||
|  |  | ||||||
|  |     if (str == NULL) | ||||||
|  | 	return(NULL); | ||||||
|  |  | ||||||
|  |     buf = xmlNewInputBufferString(str, flags); | ||||||
|  |     if (buf == NULL) | ||||||
|  |         return(NULL); | ||||||
|  |  | ||||||
|  |     return(xmlNewInputInternal(buf, url)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * xmlNewInputString: | ||||||
|  |  * @ctxt:  parser context | ||||||
|  |  * @url:  base URL (optional) | ||||||
|  |  * @str:  zero-terminated string | ||||||
|  |  * @encoding:  character encoding (optional) | ||||||
|  |  * @flags:  optimization hints | ||||||
|  |  * | ||||||
|  * Returns a new parser input. |  * Returns a new parser input. | ||||||
|  */ |  */ | ||||||
| xmlParserInputPtr | xmlParserInputPtr | ||||||
| xmlNewInputString(xmlParserCtxtPtr ctxt, const char *url, | xmlNewInputString(xmlParserCtxtPtr ctxt, const char *url, | ||||||
|                   const char *str, const char *encoding, int flags) { |                   const char *str, const char *encoding, int flags) { | ||||||
|     xmlParserInputBufferPtr buf; |     xmlParserInputPtr input; | ||||||
|  |  | ||||||
|     if ((ctxt == NULL) || (str == NULL)) |     if ((ctxt == NULL) || (str == NULL)) | ||||||
| 	return(NULL); | 	return(NULL); | ||||||
|  |  | ||||||
|     buf = xmlNewInputBufferString(str, flags); |     input = xmlInputCreateString(url, str, flags); | ||||||
|     if (buf == NULL) { |     if (input == NULL) { | ||||||
|         xmlCtxtErrMemory(ctxt); |         xmlCtxtErrMemory(ctxt); | ||||||
|         return(NULL); |         return(NULL); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return(xmlNewInputInternal(ctxt, buf, url, encoding)); |     if (encoding != NULL) | ||||||
|  |         xmlSwitchInputEncodingName(ctxt, input, encoding); | ||||||
|  |  | ||||||
|  |     return(input); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * xmlInputCreateFd: | ||||||
|  |  * @url:  base URL (optional) | ||||||
|  |  * @fd:  file descriptor | ||||||
|  |  * @flags:  unused, pass 0 | ||||||
|  |  * | ||||||
|  |  * Creates a new parser input to read from a zero-terminated string. | ||||||
|  |  * | ||||||
|  |  * @url is used as base to resolve external entities and for | ||||||
|  |  * error reporting. | ||||||
|  |  * | ||||||
|  |  * @fd is closed after parsing has finished. | ||||||
|  |  * | ||||||
|  |  * Available since 2.14.0. | ||||||
|  |  * | ||||||
|  |  * Returns a new parser input or NULL if a memory allocation failed. | ||||||
|  |  */ | ||||||
|  | xmlParserInputPtr | ||||||
|  | xmlInputCreateFd(const char *url, int fd, int flags ATTRIBUTE_UNUSED) { | ||||||
|  |     xmlParserInputBufferPtr buf; | ||||||
|  |  | ||||||
|  |     if (fd < 0) | ||||||
|  | 	return(NULL); | ||||||
|  |  | ||||||
|  |     buf = xmlParserInputBufferCreateFd(fd, XML_CHAR_ENCODING_NONE); | ||||||
|  |     if (buf == NULL) | ||||||
|  |         return(NULL); | ||||||
|  |  | ||||||
|  |     return(xmlNewInputInternal(buf, url)); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -1669,40 +1794,34 @@ xmlNewInputString(xmlParserCtxtPtr ctxt, const char *url, | |||||||
|  * @encoding:  character encoding (optional) |  * @encoding:  character encoding (optional) | ||||||
|  * @flags:  unused, pass 0 |  * @flags:  unused, pass 0 | ||||||
|  * |  * | ||||||
|  * Creates a new parser input to read from a zero-terminated string. |  | ||||||
|  * |  | ||||||
|  * @url is used as base to resolve external entities and for |  | ||||||
|  * error reporting. |  | ||||||
|  * |  | ||||||
|  * @fd is closed after parsing has finished. |  | ||||||
|  * |  | ||||||
|  * Returns a new parser input. |  * Returns a new parser input. | ||||||
|  */ |  */ | ||||||
| xmlParserInputPtr | xmlParserInputPtr | ||||||
| xmlNewInputFd(xmlParserCtxtPtr ctxt, const char *url, | xmlNewInputFd(xmlParserCtxtPtr ctxt, const char *url, | ||||||
|               int fd, const char *encoding, int flags ATTRIBUTE_UNUSED) { |               int fd, const char *encoding, int flags) { | ||||||
|     xmlParserInputBufferPtr buf; |     xmlParserInputPtr input; | ||||||
|  |  | ||||||
|     if ((ctxt == NULL) || (fd < 0)) |     if ((ctxt == NULL) || (fd < 0)) | ||||||
| 	return(NULL); | 	return(NULL); | ||||||
|  |  | ||||||
|     buf = xmlParserInputBufferCreateFd(fd, XML_CHAR_ENCODING_NONE); |     input = xmlInputCreateFd(url, fd, flags); | ||||||
|     if (buf == NULL) { |     if (input == NULL) { | ||||||
| 	xmlCtxtErrMemory(ctxt); | 	xmlCtxtErrMemory(ctxt); | ||||||
|         return(NULL); |         return(NULL); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return(xmlNewInputInternal(ctxt, buf, url, encoding)); |     if (encoding != NULL) | ||||||
|  |         xmlSwitchInputEncodingName(ctxt, input, encoding); | ||||||
|  |  | ||||||
|  |     return(input); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * xmlNewInputIO: |  * xmlInputCreateIO: | ||||||
|  * @ctxt:  parser context |  | ||||||
|  * @url:  base URL (optional) |  * @url:  base URL (optional) | ||||||
|  * @ioRead:  read callback |  * @ioRead:  read callback | ||||||
|  * @ioClose:  close callback (optional) |  * @ioClose:  close callback (optional) | ||||||
|  * @ioCtxt:  IO context |  * @ioCtxt:  IO context | ||||||
|  * @encoding:  character encoding (optional) |  | ||||||
|  * @flags:  unused, pass 0 |  * @flags:  unused, pass 0 | ||||||
|  * |  * | ||||||
|  * Creates a new parser input to read from input callbacks and |  * Creates a new parser input to read from input callbacks and | ||||||
| @@ -1719,21 +1838,21 @@ xmlNewInputFd(xmlParserCtxtPtr ctxt, const char *url, | |||||||
|  * |  * | ||||||
|  * @ioCtxt is an opaque pointer passed to the callbacks. |  * @ioCtxt is an opaque pointer passed to the callbacks. | ||||||
|  * |  * | ||||||
|  * Returns a new parser input. |  * Available since 2.14.0. | ||||||
|  |  * | ||||||
|  |  * Returns a new parser input or NULL if a memory allocation failed. | ||||||
|  */ |  */ | ||||||
| xmlParserInputPtr | xmlParserInputPtr | ||||||
| xmlNewInputIO(xmlParserCtxtPtr ctxt, const char *url, | xmlInputCreateIO(const char *url, xmlInputReadCallback ioRead, | ||||||
|               xmlInputReadCallback ioRead, xmlInputCloseCallback ioClose, |                  xmlInputCloseCallback ioClose, void *ioCtxt, | ||||||
|               void *ioCtxt, |                  int flags ATTRIBUTE_UNUSED) { | ||||||
|               const char *encoding, int flags ATTRIBUTE_UNUSED) { |  | ||||||
|     xmlParserInputBufferPtr buf; |     xmlParserInputBufferPtr buf; | ||||||
|  |  | ||||||
|     if ((ctxt == NULL) || (ioRead == NULL)) |     if (ioRead == NULL) | ||||||
| 	return(NULL); | 	return(NULL); | ||||||
|  |  | ||||||
|     buf = xmlAllocParserInputBuffer(XML_CHAR_ENCODING_NONE); |     buf = xmlAllocParserInputBuffer(XML_CHAR_ENCODING_NONE); | ||||||
|     if (buf == NULL) { |     if (buf == NULL) { | ||||||
|         xmlCtxtErrMemory(ctxt); |  | ||||||
|         if (ioClose != NULL) |         if (ioClose != NULL) | ||||||
|             ioClose(ioCtxt); |             ioClose(ioCtxt); | ||||||
|         return(NULL); |         return(NULL); | ||||||
| @@ -1743,7 +1862,40 @@ xmlNewInputIO(xmlParserCtxtPtr ctxt, const char *url, | |||||||
|     buf->readcallback = ioRead; |     buf->readcallback = ioRead; | ||||||
|     buf->closecallback = ioClose; |     buf->closecallback = ioClose; | ||||||
|  |  | ||||||
|     return(xmlNewInputInternal(ctxt, buf, url, encoding)); |     return(xmlNewInputInternal(buf, url)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * xmlNewInputIO: | ||||||
|  |  * @ctxt:  parser context | ||||||
|  |  * @url:  base URL (optional) | ||||||
|  |  * @ioRead:  read callback | ||||||
|  |  * @ioClose:  close callback (optional) | ||||||
|  |  * @ioCtxt:  IO context | ||||||
|  |  * @encoding:  character encoding (optional) | ||||||
|  |  * @flags:  unused, pass 0 | ||||||
|  |  * | ||||||
|  |  * Returns a new parser input. | ||||||
|  |  */ | ||||||
|  | xmlParserInputPtr | ||||||
|  | xmlNewInputIO(xmlParserCtxtPtr ctxt, const char *url, | ||||||
|  |               xmlInputReadCallback ioRead, xmlInputCloseCallback ioClose, | ||||||
|  |               void *ioCtxt, const char *encoding, int flags) { | ||||||
|  |     xmlParserInputPtr input; | ||||||
|  |  | ||||||
|  |     if ((ctxt == NULL) || (ioRead == NULL)) | ||||||
|  | 	return(NULL); | ||||||
|  |  | ||||||
|  |     input = xmlInputCreateIO(url, ioRead, ioClose, ioCtxt, flags); | ||||||
|  |     if (input == NULL) { | ||||||
|  |         xmlCtxtErrMemory(ctxt); | ||||||
|  |         return(NULL); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (encoding != NULL) | ||||||
|  |         xmlSwitchInputEncodingName(ctxt, input, encoding); | ||||||
|  |  | ||||||
|  |     return(input); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -1770,9 +1922,14 @@ xmlNewInputPush(xmlParserCtxtPtr ctxt, const char *url, | |||||||
|         return(NULL); |         return(NULL); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     input = xmlNewInputInternal(ctxt, buf, url, encoding); |     input = xmlNewInputInternal(buf, url); | ||||||
|     if (input == NULL) |     if (input == NULL) { | ||||||
|  |         xmlCtxtErrMemory(ctxt); | ||||||
| 	return(NULL); | 	return(NULL); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (encoding != NULL) | ||||||
|  |         xmlSwitchInputEncodingName(ctxt, input, encoding); | ||||||
|  |  | ||||||
|     input->flags |= XML_INPUT_PROGRESSIVE; |     input->flags |= XML_INPUT_PROGRESSIVE; | ||||||
|  |  | ||||||
| @@ -1805,13 +1962,23 @@ xmlNewInputPush(xmlParserCtxtPtr ctxt, const char *url, | |||||||
| xmlParserInputPtr | xmlParserInputPtr | ||||||
| xmlNewIOInputStream(xmlParserCtxtPtr ctxt, xmlParserInputBufferPtr buf, | xmlNewIOInputStream(xmlParserCtxtPtr ctxt, xmlParserInputBufferPtr buf, | ||||||
| 	            xmlCharEncoding enc) { | 	            xmlCharEncoding enc) { | ||||||
|  |     xmlParserInputPtr input; | ||||||
|     const char *encoding; |     const char *encoding; | ||||||
|  |  | ||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return(NULL); |         return(NULL); | ||||||
|  |  | ||||||
|  |     input = xmlNewInputInternal(buf, NULL); | ||||||
|  |     if (input == NULL) { | ||||||
|  |         xmlCtxtErrMemory(ctxt); | ||||||
|  | 	return(NULL); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     encoding = xmlGetCharEncodingName(enc); |     encoding = xmlGetCharEncodingName(enc); | ||||||
|     return(xmlNewInputInternal(ctxt, buf, NULL, encoding)); |     if (encoding != NULL) | ||||||
|  |         xmlSwitchInputEncodingName(ctxt, input, encoding); | ||||||
|  |  | ||||||
|  |     return(input); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -2011,6 +2178,54 @@ xmlCheckHTTPInput(xmlParserCtxtPtr ctxt, xmlParserInputPtr ret) { | |||||||
|     return(ret); |     return(ret); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * xmlInputCreateUrl: | ||||||
|  |  * @filename:  the filename to use as entity | ||||||
|  |  * @flags:  XML_INPUT flags | ||||||
|  |  * @out:  pointer to new parser input | ||||||
|  |  * | ||||||
|  |  * Create a new input stream based on a file or a URL. | ||||||
|  |  * | ||||||
|  |  * The flag XML_INPUT_UNZIP allows decompression. | ||||||
|  |  * | ||||||
|  |  * Available since 2.14.0. | ||||||
|  |  * | ||||||
|  |  * Returns an xmlParserErrors code. | ||||||
|  |  */ | ||||||
|  | int | ||||||
|  | xmlInputCreateUrl(const char *filename, int flags, xmlParserInputPtr *out) { | ||||||
|  |     xmlParserInputBufferPtr buf; | ||||||
|  |     xmlParserInputPtr input; | ||||||
|  |     int code = XML_ERR_OK; | ||||||
|  |  | ||||||
|  |     if (out == NULL) | ||||||
|  |         return(XML_ERR_ARGUMENT); | ||||||
|  |     *out = NULL; | ||||||
|  |     if (filename == NULL) | ||||||
|  |         return(XML_ERR_ARGUMENT); | ||||||
|  |  | ||||||
|  |     if (xmlParserInputBufferCreateFilenameValue != NULL) { | ||||||
|  |         buf = xmlParserInputBufferCreateFilenameValue(filename, | ||||||
|  |                 XML_CHAR_ENCODING_NONE); | ||||||
|  |         if (buf == NULL) | ||||||
|  |             code = XML_IO_ENOENT; | ||||||
|  |     } else { | ||||||
|  |         code = xmlParserInputBufferCreateUrl(filename, XML_CHAR_ENCODING_NONE, | ||||||
|  |                                              flags, &buf); | ||||||
|  |     } | ||||||
|  |     if (code != XML_ERR_OK) | ||||||
|  | 	return(code); | ||||||
|  |  | ||||||
|  |     input = xmlNewInputInternal(buf, filename); | ||||||
|  |     if (input == NULL) | ||||||
|  | 	return(XML_ERR_NO_MEMORY); | ||||||
|  |  | ||||||
|  |     /*input = xmlCheckHTTPInput(ctxt, input);*/ | ||||||
|  |  | ||||||
|  |     *out = input; | ||||||
|  |     return(XML_ERR_OK); | ||||||
|  | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * xmlNewInputFromFile: |  * xmlNewInputFromFile: | ||||||
|  * @ctxt:  an XML parser context |  * @ctxt:  an XML parser context | ||||||
| @@ -2022,35 +2237,22 @@ xmlCheckHTTPInput(xmlParserCtxtPtr ctxt, xmlParserInputPtr ret) { | |||||||
|  */ |  */ | ||||||
| xmlParserInputPtr | xmlParserInputPtr | ||||||
| xmlNewInputFromFile(xmlParserCtxtPtr ctxt, const char *filename) { | xmlNewInputFromFile(xmlParserCtxtPtr ctxt, const char *filename) { | ||||||
|     xmlParserInputBufferPtr buf; |  | ||||||
|     xmlParserInputPtr input; |     xmlParserInputPtr input; | ||||||
|     int code = XML_ERR_OK; |     int flags = 0; | ||||||
|  |     int code; | ||||||
|  |  | ||||||
|     if ((ctxt == NULL) || (filename == NULL)) |     if ((ctxt == NULL) || (filename == NULL)) | ||||||
|         return(NULL); |         return(NULL); | ||||||
|  |  | ||||||
|     if (xmlParserInputBufferCreateFilenameValue != NULL) { |  | ||||||
|         buf = xmlParserInputBufferCreateFilenameValue(filename, |  | ||||||
|                 XML_CHAR_ENCODING_NONE); |  | ||||||
|         if (buf == NULL) |  | ||||||
|             code = XML_IO_ENOENT; |  | ||||||
|     } else { |  | ||||||
|         int flags = 0; |  | ||||||
|  |  | ||||||
|     if ((ctxt->options & XML_PARSE_NO_UNZIP) == 0) |     if ((ctxt->options & XML_PARSE_NO_UNZIP) == 0) | ||||||
|         flags |= XML_INPUT_UNZIP; |         flags |= XML_INPUT_UNZIP; | ||||||
|         code = xmlParserInputBufferCreateUrl(filename, XML_CHAR_ENCODING_NONE, |  | ||||||
|                                              flags, &buf); |     code = xmlInputCreateUrl(filename, flags, &input); | ||||||
|     } |  | ||||||
|     if (code != XML_ERR_OK) { |     if (code != XML_ERR_OK) { | ||||||
|         xmlCtxtErrIO(ctxt, code, filename); |         xmlCtxtErrIO(ctxt, code, filename); | ||||||
|         return(NULL); |         return(NULL); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     input = xmlNewInputInternal(ctxt, buf, filename, NULL); |  | ||||||
|     if (input == NULL) |  | ||||||
| 	return(NULL); |  | ||||||
|  |  | ||||||
|     input = xmlCheckHTTPInput(ctxt, input); |     input = xmlCheckHTTPInput(ctxt, input); | ||||||
|  |  | ||||||
|     return(input); |     return(input); | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								xmlIO.c
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								xmlIO.c
									
									
									
									
									
								
							| @@ -41,6 +41,7 @@ | |||||||
| #include <libxml/uri.h> | #include <libxml/uri.h> | ||||||
| #include <libxml/nanohttp.h> | #include <libxml/nanohttp.h> | ||||||
| #include <libxml/nanoftp.h> | #include <libxml/nanoftp.h> | ||||||
|  | #include <libxml/parserInternals.h> | ||||||
| #include <libxml/xmlerror.h> | #include <libxml/xmlerror.h> | ||||||
| #ifdef LIBXML_CATALOG_ENABLED | #ifdef LIBXML_CATALOG_ENABLED | ||||||
| #include <libxml/catalog.h> | #include <libxml/catalog.h> | ||||||
| @@ -50,7 +51,6 @@ | |||||||
| #include "private/enc.h" | #include "private/enc.h" | ||||||
| #include "private/error.h" | #include "private/error.h" | ||||||
| #include "private/io.h" | #include "private/io.h" | ||||||
| #include "private/parser.h" |  | ||||||
|  |  | ||||||
| /* #define VERBOSE_FAILURE */ | /* #define VERBOSE_FAILURE */ | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user