mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-26 00:37:43 +03:00 
			
		
		
		
	buf: Deprecate static/immutable buffers
This commit is contained in:
		
							
								
								
									
										56
									
								
								buf.c
									
									
									
									
									
								
							
							
						
						
									
										56
									
								
								buf.c
									
									
									
									
									
								
							| @@ -200,8 +200,6 @@ xmlBufDetach(xmlBufPtr buf) { | |||||||
|  |  | ||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return(NULL); |         return(NULL); | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) |  | ||||||
|         return(NULL); |  | ||||||
|     if (buf->buffer != NULL) |     if (buf->buffer != NULL) | ||||||
|         return(NULL); |         return(NULL); | ||||||
|     if (buf->error) |     if (buf->error) | ||||||
| @@ -216,40 +214,6 @@ xmlBufDetach(xmlBufPtr buf) { | |||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * xmlBufCreateStatic: |  | ||||||
|  * @mem: the memory area |  | ||||||
|  * @size:  the size in byte |  | ||||||
|  * |  | ||||||
|  * routine to create an XML buffer from an immutable memory area. |  | ||||||
|  * The area won't be modified nor copied, and is expected to be |  | ||||||
|  * present until the end of the buffer lifetime. |  | ||||||
|  * |  | ||||||
|  * returns the new structure. |  | ||||||
|  */ |  | ||||||
| xmlBufPtr |  | ||||||
| xmlBufCreateStatic(void *mem, size_t size) { |  | ||||||
|     xmlBufPtr ret; |  | ||||||
|  |  | ||||||
|     if (mem == NULL) |  | ||||||
|         return(NULL); |  | ||||||
|  |  | ||||||
|     ret = (xmlBufPtr) xmlMalloc(sizeof(xmlBuf)); |  | ||||||
|     if (ret == NULL) { |  | ||||||
| 	xmlBufMemoryError(NULL, "creating buffer"); |  | ||||||
|         return(NULL); |  | ||||||
|     } |  | ||||||
|     ret->use = size; |  | ||||||
|     ret->size = size; |  | ||||||
|     UPDATE_COMPAT(ret); |  | ||||||
|     ret->alloc = XML_BUFFER_ALLOC_IMMUTABLE; |  | ||||||
|     ret->content = (xmlChar *) mem; |  | ||||||
|     ret->error = 0; |  | ||||||
|     ret->buffer = NULL; |  | ||||||
|     return(ret); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * xmlBufGetAllocationScheme: |  * xmlBufGetAllocationScheme: | ||||||
|  * @buf:  the buffer |  * @buf:  the buffer | ||||||
| @@ -289,13 +253,11 @@ xmlBufSetAllocationScheme(xmlBufPtr buf, | |||||||
| #endif | #endif | ||||||
|         return(-1); |         return(-1); | ||||||
|     } |     } | ||||||
|     if ((buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) || |     if (buf->alloc == XML_BUFFER_ALLOC_IO) | ||||||
|         (buf->alloc == XML_BUFFER_ALLOC_IO)) |  | ||||||
|         return(-1); |         return(-1); | ||||||
|     if ((scheme == XML_BUFFER_ALLOC_DOUBLEIT) || |     if ((scheme == XML_BUFFER_ALLOC_DOUBLEIT) || | ||||||
|         (scheme == XML_BUFFER_ALLOC_EXACT) || |         (scheme == XML_BUFFER_ALLOC_EXACT) || | ||||||
|         (scheme == XML_BUFFER_ALLOC_HYBRID) || |         (scheme == XML_BUFFER_ALLOC_HYBRID) || | ||||||
|         (scheme == XML_BUFFER_ALLOC_IMMUTABLE) || |  | ||||||
| 	(scheme == XML_BUFFER_ALLOC_BOUNDED)) { | 	(scheme == XML_BUFFER_ALLOC_BOUNDED)) { | ||||||
| 	buf->alloc = scheme; | 	buf->alloc = scheme; | ||||||
|         if (buf->buffer) |         if (buf->buffer) | ||||||
| @@ -333,8 +295,7 @@ xmlBufFree(xmlBufPtr buf) { | |||||||
|     if ((buf->alloc == XML_BUFFER_ALLOC_IO) && |     if ((buf->alloc == XML_BUFFER_ALLOC_IO) && | ||||||
|         (buf->contentIO != NULL)) { |         (buf->contentIO != NULL)) { | ||||||
|         xmlFree(buf->contentIO); |         xmlFree(buf->contentIO); | ||||||
|     } else if ((buf->content != NULL) && |     } else if (buf->content != NULL) { | ||||||
|         (buf->alloc != XML_BUFFER_ALLOC_IMMUTABLE)) { |  | ||||||
|         xmlFree(buf->content); |         xmlFree(buf->content); | ||||||
|     } |     } | ||||||
|     xmlFree(buf); |     xmlFree(buf); | ||||||
| @@ -352,9 +313,7 @@ xmlBufEmpty(xmlBufPtr buf) { | |||||||
|     if (buf->content == NULL) return; |     if (buf->content == NULL) return; | ||||||
|     CHECK_COMPAT(buf) |     CHECK_COMPAT(buf) | ||||||
|     buf->use = 0; |     buf->use = 0; | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) { |     if ((buf->alloc == XML_BUFFER_ALLOC_IO) && | ||||||
|         buf->content = BAD_CAST ""; |  | ||||||
|     } else if ((buf->alloc == XML_BUFFER_ALLOC_IO) && |  | ||||||
|                (buf->contentIO != NULL)) { |                (buf->contentIO != NULL)) { | ||||||
|         size_t start_buf = buf->content - buf->contentIO; |         size_t start_buf = buf->content - buf->contentIO; | ||||||
|  |  | ||||||
| @@ -387,8 +346,7 @@ xmlBufShrink(xmlBufPtr buf, size_t len) { | |||||||
|     if (len > buf->use) return(0); |     if (len > buf->use) return(0); | ||||||
|  |  | ||||||
|     buf->use -= len; |     buf->use -= len; | ||||||
|     if ((buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) || |     if ((buf->alloc == XML_BUFFER_ALLOC_IO) && (buf->contentIO != NULL)) { | ||||||
|         ((buf->alloc == XML_BUFFER_ALLOC_IO) && (buf->contentIO != NULL))) { |  | ||||||
| 	/* | 	/* | ||||||
| 	 * we just move the content pointer, but also make sure | 	 * we just move the content pointer, but also make sure | ||||||
| 	 * the perceived buffer size has shrunk accordingly | 	 * the perceived buffer size has shrunk accordingly | ||||||
| @@ -436,7 +394,6 @@ xmlBufGrowInternal(xmlBufPtr buf, size_t len) { | |||||||
|     if ((buf == NULL) || (buf->error != 0)) return(0); |     if ((buf == NULL) || (buf->error != 0)) return(0); | ||||||
|     CHECK_COMPAT(buf) |     CHECK_COMPAT(buf) | ||||||
|  |  | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return(0); |  | ||||||
|     if (len < buf->size - buf->use) |     if (len < buf->size - buf->use) | ||||||
|         return(buf->size - buf->use - 1); |         return(buf->size - buf->use - 1); | ||||||
|     if (len >= SIZE_MAX - buf->use) { |     if (len >= SIZE_MAX - buf->use) { | ||||||
| @@ -701,7 +658,6 @@ xmlBufResize(xmlBufPtr buf, size_t size) | |||||||
|         return(0); |         return(0); | ||||||
|     CHECK_COMPAT(buf) |     CHECK_COMPAT(buf) | ||||||
|  |  | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return(0); |  | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_BOUNDED) { |     if (buf->alloc == XML_BUFFER_ALLOC_BOUNDED) { | ||||||
|         /* |         /* | ||||||
| 	 * Used to provide parsing limits | 	 * Used to provide parsing limits | ||||||
| @@ -827,7 +783,6 @@ xmlBufAdd(xmlBufPtr buf, const xmlChar *str, int len) { | |||||||
| 	return -1; | 	return -1; | ||||||
|     CHECK_COMPAT(buf) |     CHECK_COMPAT(buf) | ||||||
|  |  | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return -1; |  | ||||||
|     if (len < -1) { |     if (len < -1) { | ||||||
| #ifdef DEBUG_BUFFER | #ifdef DEBUG_BUFFER | ||||||
|         xmlGenericError(xmlGenericErrorContext, |         xmlGenericError(xmlGenericErrorContext, | ||||||
| @@ -887,7 +842,6 @@ xmlBufCat(xmlBufPtr buf, const xmlChar *str) { | |||||||
|     if ((buf == NULL) || (buf->error)) |     if ((buf == NULL) || (buf->error)) | ||||||
|         return(-1); |         return(-1); | ||||||
|     CHECK_COMPAT(buf) |     CHECK_COMPAT(buf) | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return -1; |  | ||||||
|     if (str == NULL) return -1; |     if (str == NULL) return -1; | ||||||
|     return xmlBufAdd(buf, str, -1); |     return xmlBufAdd(buf, str, -1); | ||||||
| } | } | ||||||
| @@ -925,8 +879,6 @@ xmlBufWriteQuotedString(xmlBufPtr buf, const xmlChar *string) { | |||||||
|     if ((buf == NULL) || (buf->error)) |     if ((buf == NULL) || (buf->error)) | ||||||
|         return(-1); |         return(-1); | ||||||
|     CHECK_COMPAT(buf) |     CHECK_COMPAT(buf) | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) |  | ||||||
|         return(-1); |  | ||||||
|     if (xmlStrchr(string, '\"')) { |     if (xmlStrchr(string, '\"')) { | ||||||
|         if (xmlStrchr(string, '\'')) { |         if (xmlStrchr(string, '\'')) { | ||||||
| #ifdef DEBUG_BUFFER | #ifdef DEBUG_BUFFER | ||||||
|   | |||||||
| @@ -2584,7 +2584,6 @@ retry: | |||||||
| 		xmlEncodingErr(XML_I18N_CONV_FAILED, | 		xmlEncodingErr(XML_I18N_CONV_FAILED, | ||||||
| 		    "output conversion failed due to conv error, bytes %s\n", | 		    "output conversion failed due to conv error, bytes %s\n", | ||||||
| 			       buf); | 			       buf); | ||||||
| 		if (xmlBufGetAllocationScheme(in) != XML_BUFFER_ALLOC_IMMUTABLE) |  | ||||||
| 		content[0] = ' '; | 		content[0] = ' '; | ||||||
|                 break; |                 break; | ||||||
| 	    } | 	    } | ||||||
| @@ -2745,7 +2744,6 @@ retry: | |||||||
| 		xmlEncodingErr(XML_I18N_CONV_FAILED, | 		xmlEncodingErr(XML_I18N_CONV_FAILED, | ||||||
| 		    "output conversion failed due to conv error, bytes %s\n", | 		    "output conversion failed due to conv error, bytes %s\n", | ||||||
| 			       buf); | 			       buf); | ||||||
| 		if (in->alloc != XML_BUFFER_ALLOC_IMMUTABLE) |  | ||||||
| 		in->content[0] = ' '; | 		in->content[0] = ' '; | ||||||
| 	        break; | 	        break; | ||||||
| 	    } | 	    } | ||||||
|   | |||||||
| @@ -1011,7 +1011,6 @@ xmlCopyEntitiesTable(xmlEntitiesTablePtr table) { | |||||||
|  */ |  */ | ||||||
| static void | static void | ||||||
| xmlDumpEntityContent(xmlBufferPtr buf, const xmlChar *content) { | xmlDumpEntityContent(xmlBufferPtr buf, const xmlChar *content) { | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return; |  | ||||||
|     if (xmlStrchr(content, '%')) { |     if (xmlStrchr(content, '%')) { | ||||||
|         const xmlChar * base, *cur; |         const xmlChar * base, *cur; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -261,7 +261,6 @@ extra_post_call = { | |||||||
|    "xmlParseChunk": "if (ctxt != NULL) {xmlFreeDoc(ctxt->myDoc); ctxt->myDoc = NULL;}", |    "xmlParseChunk": "if (ctxt != NULL) {xmlFreeDoc(ctxt->myDoc); ctxt->myDoc = NULL;}", | ||||||
|    "xmlParseExtParsedEnt": "if (ctxt != NULL) {xmlFreeDoc(ctxt->myDoc); ctxt->myDoc = NULL;}", |    "xmlParseExtParsedEnt": "if (ctxt != NULL) {xmlFreeDoc(ctxt->myDoc); ctxt->myDoc = NULL;}", | ||||||
|    "xmlDOMWrapAdoptNode": "if ((node != NULL) && (node->parent == NULL)) {xmlUnlinkNode(node);xmlFreeNode(node);node = NULL;}", |    "xmlDOMWrapAdoptNode": "if ((node != NULL) && (node->parent == NULL)) {xmlUnlinkNode(node);xmlFreeNode(node);node = NULL;}", | ||||||
|    "xmlBufferSetAllocationScheme": "if ((buf != NULL) && (scheme == XML_BUFFER_ALLOC_IMMUTABLE) && (buf->content != NULL) && (buf->content != static_buf_content)) { xmlFree(buf->content); buf->content = NULL;}" |  | ||||||
| } | } | ||||||
|  |  | ||||||
| modules = [] | modules = [] | ||||||
|   | |||||||
| @@ -74,7 +74,7 @@ typedef xmlEntity *xmlEntityPtr; | |||||||
| typedef enum { | typedef enum { | ||||||
|     XML_BUFFER_ALLOC_DOUBLEIT,	/* double each time one need to grow */ |     XML_BUFFER_ALLOC_DOUBLEIT,	/* double each time one need to grow */ | ||||||
|     XML_BUFFER_ALLOC_EXACT,	/* grow only to the minimal size */ |     XML_BUFFER_ALLOC_EXACT,	/* grow only to the minimal size */ | ||||||
|     XML_BUFFER_ALLOC_IMMUTABLE, /* immutable buffer */ |     XML_BUFFER_ALLOC_IMMUTABLE, /* immutable buffer, deprecated */ | ||||||
|     XML_BUFFER_ALLOC_IO,	/* special allocation scheme used for I/O */ |     XML_BUFFER_ALLOC_IO,	/* special allocation scheme used for I/O */ | ||||||
|     XML_BUFFER_ALLOC_HYBRID,	/* exact up to a threshold, and doubleit thereafter */ |     XML_BUFFER_ALLOC_HYBRID,	/* exact up to a threshold, and doubleit thereafter */ | ||||||
|     XML_BUFFER_ALLOC_BOUNDED	/* limit the upper size of the buffer */ |     XML_BUFFER_ALLOC_BOUNDED	/* limit the upper size of the buffer */ | ||||||
|   | |||||||
| @@ -178,6 +178,7 @@ XMLPUBFUN xmlParserInputBufferPtr XMLCALL | |||||||
| XMLPUBFUN xmlParserInputBufferPtr XMLCALL | XMLPUBFUN xmlParserInputBufferPtr XMLCALL | ||||||
| 	xmlParserInputBufferCreateMem		(const char *mem, int size, | 	xmlParserInputBufferCreateMem		(const char *mem, int size, | ||||||
| 	                                         xmlCharEncoding enc); | 	                                         xmlCharEncoding enc); | ||||||
|  | XML_DEPRECATED | ||||||
| XMLPUBFUN xmlParserInputBufferPtr XMLCALL | XMLPUBFUN xmlParserInputBufferPtr XMLCALL | ||||||
| 	xmlParserInputBufferCreateStatic	(const char *mem, int size, | 	xmlParserInputBufferCreateStatic	(const char *mem, int size, | ||||||
| 	                                         xmlCharEncoding enc); | 	                                         xmlCharEncoding enc); | ||||||
|   | |||||||
| @@ -5,7 +5,6 @@ | |||||||
|  |  | ||||||
| xmlBufPtr xmlBufCreate(void); | xmlBufPtr xmlBufCreate(void); | ||||||
| xmlBufPtr xmlBufCreateSize(size_t size); | xmlBufPtr xmlBufCreateSize(size_t size); | ||||||
| xmlBufPtr xmlBufCreateStatic(void *mem, size_t size); |  | ||||||
|  |  | ||||||
| int xmlBufSetAllocationScheme(xmlBufPtr buf, | int xmlBufSetAllocationScheme(xmlBufPtr buf, | ||||||
|                               xmlBufferAllocationScheme scheme); |                               xmlBufferAllocationScheme scheme); | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								parser.c
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								parser.c
									
									
									
									
									
								
							| @@ -14377,7 +14377,6 @@ xmlCreateMemoryParserCtxt(const char *buffer, int size) { | |||||||
|     if (ctxt == NULL) |     if (ctxt == NULL) | ||||||
| 	return(NULL); | 	return(NULL); | ||||||
|  |  | ||||||
|     /* TODO: xmlParserInputBufferCreateStatic, requires some serious changes */ |  | ||||||
|     buf = xmlParserInputBufferCreateMem(buffer, size, XML_CHAR_ENCODING_NONE); |     buf = xmlParserInputBufferCreateMem(buffer, size, XML_CHAR_ENCODING_NONE); | ||||||
|     if (buf == NULL) { |     if (buf == NULL) { | ||||||
| 	xmlFreeParserCtxt(ctxt); | 	xmlFreeParserCtxt(ctxt); | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								testchar.c
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								testchar.c
									
									
									
									
									
								
							| @@ -259,9 +259,10 @@ static int testDocumentRanges(void) { | |||||||
|     return(test_ret); |     return(test_ret); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int testCharRangeByte1(xmlParserCtxtPtr ctxt, char *data) { | static int testCharRangeByte1(xmlParserCtxtPtr ctxt) { | ||||||
|     int i = 0; |     int i = 0; | ||||||
|     int len, c; |     int len, c; | ||||||
|  |     char *data = (char *) ctxt->input->cur; | ||||||
|  |  | ||||||
|     data[1] = 0; |     data[1] = 0; | ||||||
|     data[2] = 0; |     data[2] = 0; | ||||||
| @@ -292,9 +293,10 @@ static int testCharRangeByte1(xmlParserCtxtPtr ctxt, char *data) { | |||||||
|     return(0); |     return(0); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int testCharRangeByte2(xmlParserCtxtPtr ctxt, char *data) { | static int testCharRangeByte2(xmlParserCtxtPtr ctxt) { | ||||||
|     int i, j; |     int i, j; | ||||||
|     int len, c; |     int len, c; | ||||||
|  |     char *data = (char *) ctxt->input->cur; | ||||||
|  |  | ||||||
|     data[2] = 0; |     data[2] = 0; | ||||||
|     data[3] = 0; |     data[3] = 0; | ||||||
| @@ -379,10 +381,11 @@ static int testCharRangeByte2(xmlParserCtxtPtr ctxt, char *data) { | |||||||
|     return(0); |     return(0); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int testCharRangeByte3(xmlParserCtxtPtr ctxt, char *data) { | static int testCharRangeByte3(xmlParserCtxtPtr ctxt) { | ||||||
|     int i, j, k, K; |     int i, j, k, K; | ||||||
|     int len, c; |     int len, c; | ||||||
|     unsigned char lows[6] = {0, 0x80, 0x81, 0xC1, 0xFF, 0xBF}; |     unsigned char lows[6] = {0, 0x80, 0x81, 0xC1, 0xFF, 0xBF}; | ||||||
|  |     char *data = (char *) ctxt->input->cur; | ||||||
|     int value; |     int value; | ||||||
|  |  | ||||||
|     data[3] = 0; |     data[3] = 0; | ||||||
| @@ -476,10 +479,11 @@ static int testCharRangeByte3(xmlParserCtxtPtr ctxt, char *data) { | |||||||
|     return(0); |     return(0); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int testCharRangeByte4(xmlParserCtxtPtr ctxt, char *data) { | static int testCharRangeByte4(xmlParserCtxtPtr ctxt) { | ||||||
|     int i, j, k, K, l, L; |     int i, j, k, K, l, L; | ||||||
|     int len, c; |     int len, c; | ||||||
|     unsigned char lows[6] = {0, 0x80, 0x81, 0xC1, 0xFF, 0xBF}; |     unsigned char lows[6] = {0, 0x80, 0x81, 0xC1, 0xFF, 0xBF}; | ||||||
|  |     char *data = (char *) ctxt->input->cur; | ||||||
|     int value; |     int value; | ||||||
|  |  | ||||||
|     data[4] = 0; |     data[4] = 0; | ||||||
| @@ -606,7 +610,7 @@ static int testCharRanges(void) { | |||||||
|         fprintf(stderr, "Failed to allocate parser context\n"); |         fprintf(stderr, "Failed to allocate parser context\n"); | ||||||
| 	return(1); | 	return(1); | ||||||
|     } |     } | ||||||
|     buf = xmlParserInputBufferCreateStatic(data, sizeof(data), |     buf = xmlParserInputBufferCreateMem(data, sizeof(data), | ||||||
|                                         XML_CHAR_ENCODING_NONE); |                                         XML_CHAR_ENCODING_NONE); | ||||||
|     if (buf == NULL) { |     if (buf == NULL) { | ||||||
|         fprintf(stderr, "Failed to allocate input buffer\n"); |         fprintf(stderr, "Failed to allocate input buffer\n"); | ||||||
| @@ -628,16 +632,16 @@ static int testCharRanges(void) { | |||||||
|  |  | ||||||
|     printf("testing char range: 1"); |     printf("testing char range: 1"); | ||||||
|     fflush(stdout); |     fflush(stdout); | ||||||
|     test_ret += testCharRangeByte1(ctxt, data); |     test_ret += testCharRangeByte1(ctxt); | ||||||
|     printf(" 2"); |     printf(" 2"); | ||||||
|     fflush(stdout); |     fflush(stdout); | ||||||
|     test_ret += testCharRangeByte2(ctxt, data); |     test_ret += testCharRangeByte2(ctxt); | ||||||
|     printf(" 3"); |     printf(" 3"); | ||||||
|     fflush(stdout); |     fflush(stdout); | ||||||
|     test_ret += testCharRangeByte3(ctxt, data); |     test_ret += testCharRangeByte3(ctxt); | ||||||
|     printf(" 4"); |     printf(" 4"); | ||||||
|     fflush(stdout); |     fflush(stdout); | ||||||
|     test_ret += testCharRangeByte4(ctxt, data); |     test_ret += testCharRangeByte4(ctxt); | ||||||
|     printf(" done\n"); |     printf(" done\n"); | ||||||
|     fflush(stdout); |     fflush(stdout); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										53
									
								
								tree.c
									
									
									
									
									
								
							
							
						
						
									
										53
									
								
								tree.c
									
									
									
									
									
								
							| @@ -7207,8 +7207,6 @@ xmlBufferDetach(xmlBufferPtr buf) { | |||||||
|  |  | ||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return(NULL); |         return(NULL); | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) |  | ||||||
|         return(NULL); |  | ||||||
|  |  | ||||||
|     ret = buf->content; |     ret = buf->content; | ||||||
|     buf->content = NULL; |     buf->content = NULL; | ||||||
| @@ -7224,31 +7222,14 @@ xmlBufferDetach(xmlBufferPtr buf) { | |||||||
|  * @mem: the memory area |  * @mem: the memory area | ||||||
|  * @size:  the size in byte |  * @size:  the size in byte | ||||||
|  * |  * | ||||||
|  * routine to create an XML buffer from an immutable memory area. |  * Create an XML buffer initialized with bytes. | ||||||
|  * The area won't be modified nor copied, and is expected to be |  | ||||||
|  * present until the end of the buffer lifetime. |  | ||||||
|  * |  | ||||||
|  * returns the new structure. |  | ||||||
|  */ |  */ | ||||||
| xmlBufferPtr | xmlBufferPtr | ||||||
| xmlBufferCreateStatic(void *mem, size_t size) { | xmlBufferCreateStatic(void *mem, size_t size) { | ||||||
|     xmlBufferPtr ret; |     xmlBufferPtr buf = xmlBufferCreateSize(size); | ||||||
|  |  | ||||||
|     if ((mem == NULL) || (size == 0)) |     xmlBufferAdd(buf, mem, size); | ||||||
|         return(NULL); |     return(buf); | ||||||
|     if (size > UINT_MAX) |  | ||||||
|         return(NULL); |  | ||||||
|  |  | ||||||
|     ret = (xmlBufferPtr) xmlMalloc(sizeof(xmlBuffer)); |  | ||||||
|     if (ret == NULL) { |  | ||||||
| 	xmlTreeErrMemory("creating buffer"); |  | ||||||
|         return(NULL); |  | ||||||
|     } |  | ||||||
|     ret->use = size; |  | ||||||
|     ret->size = size; |  | ||||||
|     ret->alloc = XML_BUFFER_ALLOC_IMMUTABLE; |  | ||||||
|     ret->content = (xmlChar *) mem; |  | ||||||
|     return(ret); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -7268,12 +7249,10 @@ xmlBufferSetAllocationScheme(xmlBufferPtr buf, | |||||||
| #endif | #endif | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     if ((buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) || |     if (buf->alloc == XML_BUFFER_ALLOC_IO) return; | ||||||
|         (buf->alloc == XML_BUFFER_ALLOC_IO)) return; |  | ||||||
|     if ((scheme == XML_BUFFER_ALLOC_DOUBLEIT) || |     if ((scheme == XML_BUFFER_ALLOC_DOUBLEIT) || | ||||||
|         (scheme == XML_BUFFER_ALLOC_EXACT) || |         (scheme == XML_BUFFER_ALLOC_EXACT) || | ||||||
|         (scheme == XML_BUFFER_ALLOC_HYBRID) || |         (scheme == XML_BUFFER_ALLOC_HYBRID)) | ||||||
|         (scheme == XML_BUFFER_ALLOC_IMMUTABLE)) |  | ||||||
| 	buf->alloc = scheme; | 	buf->alloc = scheme; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -7297,8 +7276,7 @@ xmlBufferFree(xmlBufferPtr buf) { | |||||||
|     if ((buf->alloc == XML_BUFFER_ALLOC_IO) && |     if ((buf->alloc == XML_BUFFER_ALLOC_IO) && | ||||||
|         (buf->contentIO != NULL)) { |         (buf->contentIO != NULL)) { | ||||||
|         xmlFree(buf->contentIO); |         xmlFree(buf->contentIO); | ||||||
|     } else if ((buf->content != NULL) && |     } else if (buf->content != NULL) { | ||||||
|         (buf->alloc != XML_BUFFER_ALLOC_IMMUTABLE)) { |  | ||||||
|         xmlFree(buf->content); |         xmlFree(buf->content); | ||||||
|     } |     } | ||||||
|     xmlFree(buf); |     xmlFree(buf); | ||||||
| @@ -7315,10 +7293,7 @@ xmlBufferEmpty(xmlBufferPtr buf) { | |||||||
|     if (buf == NULL) return; |     if (buf == NULL) return; | ||||||
|     if (buf->content == NULL) return; |     if (buf->content == NULL) return; | ||||||
|     buf->use = 0; |     buf->use = 0; | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) { |     if ((buf->alloc == XML_BUFFER_ALLOC_IO) && (buf->contentIO != NULL)) { | ||||||
|         buf->content = BAD_CAST ""; |  | ||||||
|     } else if ((buf->alloc == XML_BUFFER_ALLOC_IO) && |  | ||||||
|                (buf->contentIO != NULL)) { |  | ||||||
|         size_t start_buf = buf->content - buf->contentIO; |         size_t start_buf = buf->content - buf->contentIO; | ||||||
|  |  | ||||||
| 	buf->size += start_buf; | 	buf->size += start_buf; | ||||||
| @@ -7345,8 +7320,7 @@ xmlBufferShrink(xmlBufferPtr buf, unsigned int len) { | |||||||
|     if (len > buf->use) return(-1); |     if (len > buf->use) return(-1); | ||||||
|  |  | ||||||
|     buf->use -= len; |     buf->use -= len; | ||||||
|     if ((buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) || |     if ((buf->alloc == XML_BUFFER_ALLOC_IO) && (buf->contentIO != NULL)) { | ||||||
|         ((buf->alloc == XML_BUFFER_ALLOC_IO) && (buf->contentIO != NULL))) { |  | ||||||
| 	/* | 	/* | ||||||
| 	 * we just move the content pointer, but also make sure | 	 * we just move the content pointer, but also make sure | ||||||
| 	 * the perceived buffer size has shrunk accordingly | 	 * the perceived buffer size has shrunk accordingly | ||||||
| @@ -7390,7 +7364,6 @@ xmlBufferGrow(xmlBufferPtr buf, unsigned int len) { | |||||||
|  |  | ||||||
|     if (buf == NULL) return(-1); |     if (buf == NULL) return(-1); | ||||||
|  |  | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return(0); |  | ||||||
|     if (len < buf->size - buf->use) |     if (len < buf->size - buf->use) | ||||||
|         return(0); |         return(0); | ||||||
|     if (len >= UINT_MAX - buf->use) { |     if (len >= UINT_MAX - buf->use) { | ||||||
| @@ -7514,8 +7487,6 @@ xmlBufferResize(xmlBufferPtr buf, unsigned int size) | |||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return(0); |         return(0); | ||||||
|  |  | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return(0); |  | ||||||
|  |  | ||||||
|     /* Don't resize if we don't have to */ |     /* Don't resize if we don't have to */ | ||||||
|     if (size < buf->size) |     if (size < buf->size) | ||||||
|         return 1; |         return 1; | ||||||
| @@ -7633,7 +7604,6 @@ xmlBufferAdd(xmlBufferPtr buf, const xmlChar *str, int len) { | |||||||
|     if ((str == NULL) || (buf == NULL)) { |     if ((str == NULL) || (buf == NULL)) { | ||||||
| 	return -1; | 	return -1; | ||||||
|     } |     } | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return -1; |  | ||||||
|     if (len < -1) { |     if (len < -1) { | ||||||
| #ifdef DEBUG_BUFFER | #ifdef DEBUG_BUFFER | ||||||
|         xmlGenericError(xmlGenericErrorContext, |         xmlGenericError(xmlGenericErrorContext, | ||||||
| @@ -7686,7 +7656,6 @@ xmlBufferAddHead(xmlBufferPtr buf, const xmlChar *str, int len) { | |||||||
|  |  | ||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return(-1); |         return(-1); | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return -1; |  | ||||||
|     if (str == NULL) { |     if (str == NULL) { | ||||||
| #ifdef DEBUG_BUFFER | #ifdef DEBUG_BUFFER | ||||||
|         xmlGenericError(xmlGenericErrorContext, |         xmlGenericError(xmlGenericErrorContext, | ||||||
| @@ -7757,7 +7726,6 @@ int | |||||||
| xmlBufferCat(xmlBufferPtr buf, const xmlChar *str) { | xmlBufferCat(xmlBufferPtr buf, const xmlChar *str) { | ||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return(-1); |         return(-1); | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return -1; |  | ||||||
|     if (str == NULL) return -1; |     if (str == NULL) return -1; | ||||||
|     return xmlBufferAdd(buf, str, -1); |     return xmlBufferAdd(buf, str, -1); | ||||||
| } | } | ||||||
| @@ -7789,7 +7757,6 @@ void | |||||||
| xmlBufferWriteCHAR(xmlBufferPtr buf, const xmlChar *string) { | xmlBufferWriteCHAR(xmlBufferPtr buf, const xmlChar *string) { | ||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return; |         return; | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return; |  | ||||||
|     xmlBufferCat(buf, string); |     xmlBufferCat(buf, string); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -7805,7 +7772,6 @@ void | |||||||
| xmlBufferWriteChar(xmlBufferPtr buf, const char *string) { | xmlBufferWriteChar(xmlBufferPtr buf, const char *string) { | ||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return; |         return; | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return; |  | ||||||
|     xmlBufferCCat(buf, string); |     xmlBufferCCat(buf, string); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -7824,7 +7790,6 @@ xmlBufferWriteQuotedString(xmlBufferPtr buf, const xmlChar *string) { | |||||||
|     const xmlChar *cur, *base; |     const xmlChar *cur, *base; | ||||||
|     if (buf == NULL) |     if (buf == NULL) | ||||||
|         return; |         return; | ||||||
|     if (buf->alloc == XML_BUFFER_ALLOC_IMMUTABLE) return; |  | ||||||
|     if (xmlStrchr(string, '\"')) { |     if (xmlStrchr(string, '\"')) { | ||||||
|         if (xmlStrchr(string, '\'')) { |         if (xmlStrchr(string, '\'')) { | ||||||
| #ifdef DEBUG_BUFFER | #ifdef DEBUG_BUFFER | ||||||
|   | |||||||
							
								
								
									
										36
									
								
								xmlIO.c
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								xmlIO.c
									
									
									
									
									
								
							| @@ -2950,43 +2950,14 @@ xmlParserInputBufferCreateMem(const char *mem, int size, xmlCharEncoding enc) { | |||||||
|  * @size:  the length of the memory block |  * @size:  the length of the memory block | ||||||
|  * @enc:  the charset encoding if known |  * @enc:  the charset encoding if known | ||||||
|  * |  * | ||||||
|  * Create a buffered parser input for the progressive parsing for the input |  * DEPRECATED: Use xmlParserInputBufferCreateMem. | ||||||
|  * from an immutable memory area. This will not copy the memory area to |  | ||||||
|  * the buffer, but the memory is expected to be available until the end of |  | ||||||
|  * the parsing, this is useful for example when using mmap'ed file. |  | ||||||
|  * |  * | ||||||
|  * Returns the new parser input or NULL |  * Returns the new parser input or NULL | ||||||
|  */ |  */ | ||||||
| xmlParserInputBufferPtr | xmlParserInputBufferPtr | ||||||
| xmlParserInputBufferCreateStatic(const char *mem, int size, | xmlParserInputBufferCreateStatic(const char *mem, int size, | ||||||
|                                  xmlCharEncoding enc) { |                                  xmlCharEncoding enc) { | ||||||
|     xmlParserInputBufferPtr ret; |     return(xmlParserInputBufferCreateMem(mem, size, enc)); | ||||||
|  |  | ||||||
|     if (size < 0) return(NULL); |  | ||||||
|     if (mem == NULL) return(NULL); |  | ||||||
|  |  | ||||||
|     ret = (xmlParserInputBufferPtr) xmlMalloc(sizeof(xmlParserInputBuffer)); |  | ||||||
|     if (ret == NULL) { |  | ||||||
| 	xmlIOErrMemory("creating input buffer"); |  | ||||||
| 	return(NULL); |  | ||||||
|     } |  | ||||||
|     memset(ret, 0, sizeof(xmlParserInputBuffer)); |  | ||||||
|     ret->buffer = xmlBufCreateStatic((void *)mem, size); |  | ||||||
|     if (ret->buffer == NULL) { |  | ||||||
|         xmlFree(ret); |  | ||||||
| 	return(NULL); |  | ||||||
|     } |  | ||||||
|     ret->encoder = xmlGetCharEncodingHandler(enc); |  | ||||||
|     if (ret->encoder != NULL) |  | ||||||
|         ret->raw = xmlBufCreateSize(2 * xmlDefaultBufferSize); |  | ||||||
|     else |  | ||||||
|         ret->raw = NULL; |  | ||||||
|     ret->compressed = -1; |  | ||||||
|     ret->context = (void *) mem; |  | ||||||
|     ret->readcallback = NULL; |  | ||||||
|     ret->closecallback = NULL; |  | ||||||
|  |  | ||||||
|     return(ret); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifdef LIBXML_OUTPUT_ENABLED | #ifdef LIBXML_OUTPUT_ENABLED | ||||||
| @@ -3504,8 +3475,7 @@ xmlOutputBufferWriteEscape(xmlOutputBufferPtr out, const xmlChar *str, | |||||||
|     int cons;        /* byte from str consumed */ |     int cons;        /* byte from str consumed */ | ||||||
|  |  | ||||||
|     if ((out == NULL) || (out->error) || (str == NULL) || |     if ((out == NULL) || (out->error) || (str == NULL) || | ||||||
|         (out->buffer == NULL) || |         (out->buffer == NULL)) | ||||||
| 	(xmlBufGetAllocationScheme(out->buffer) == XML_BUFFER_ALLOC_IMMUTABLE)) |  | ||||||
|         return(-1); |         return(-1); | ||||||
|     len = strlen((const char *)str); |     len = strlen((const char *)str); | ||||||
|     if (len < 0) return(0); |     if (len < 0) return(0); | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								xmlreader.c
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								xmlreader.c
									
									
									
									
									
								
							| @@ -773,7 +773,6 @@ xmlTextReaderPushData(xmlTextReaderPtr reader) { | |||||||
|     xmlBufPtr inbuf; |     xmlBufPtr inbuf; | ||||||
|     int val, s; |     int val, s; | ||||||
|     xmlTextReaderState oldstate; |     xmlTextReaderState oldstate; | ||||||
|     int alloc; |  | ||||||
|  |  | ||||||
|     if ((reader->input == NULL) || (reader->input->buffer == NULL)) |     if ((reader->input == NULL) || (reader->input->buffer == NULL)) | ||||||
| 	return(-1); | 	return(-1); | ||||||
| @@ -781,7 +780,6 @@ xmlTextReaderPushData(xmlTextReaderPtr reader) { | |||||||
|     oldstate = reader->state; |     oldstate = reader->state; | ||||||
|     reader->state = XML_TEXTREADER_NONE; |     reader->state = XML_TEXTREADER_NONE; | ||||||
|     inbuf = reader->input->buffer; |     inbuf = reader->input->buffer; | ||||||
|     alloc = xmlBufGetAllocationScheme(inbuf); |  | ||||||
|  |  | ||||||
|     while (reader->state == XML_TEXTREADER_NONE) { |     while (reader->state == XML_TEXTREADER_NONE) { | ||||||
| 	if (xmlBufUse(inbuf) < reader->cur + CHUNK_SIZE) { | 	if (xmlBufUse(inbuf) < reader->cur + CHUNK_SIZE) { | ||||||
| @@ -790,13 +788,7 @@ xmlTextReaderPushData(xmlTextReaderPtr reader) { | |||||||
| 	     */ | 	     */ | ||||||
| 	    if (reader->mode != XML_TEXTREADER_MODE_EOF) { | 	    if (reader->mode != XML_TEXTREADER_MODE_EOF) { | ||||||
| 		val = xmlParserInputBufferRead(reader->input, 4096); | 		val = xmlParserInputBufferRead(reader->input, 4096); | ||||||
| 		if ((val == 0) && | 		if (val < 0) { | ||||||
| 		    (alloc == XML_BUFFER_ALLOC_IMMUTABLE)) { |  | ||||||
| 		    if (xmlBufUse(inbuf) == reader->cur) { |  | ||||||
| 			reader->mode = XML_TEXTREADER_MODE_EOF; |  | ||||||
| 			reader->state = oldstate; |  | ||||||
| 		    } |  | ||||||
| 		} else if (val < 0) { |  | ||||||
| 		    reader->mode = XML_TEXTREADER_MODE_EOF; | 		    reader->mode = XML_TEXTREADER_MODE_EOF; | ||||||
| 		    reader->state = oldstate; | 		    reader->state = oldstate; | ||||||
| 		    if ((oldstate != XML_TEXTREADER_START) || | 		    if ((oldstate != XML_TEXTREADER_START) || | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user