mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-24 13:33:01 +03:00 
			
		
		
		
	Avoid memory leak if xmlParserInputBufferCreateIO fails
For https://bugzilla.gnome.org/show_bug.cgi?id=643949 In case of error on an IO creation input the given context is terminated with the given close function, except if the error happened in xmlParserInputBufferCreateIO. This can lead to a resource leak which is fixed by this patch.
This commit is contained in:
		
				
					committed by
					
						 Daniel Veillard
						Daniel Veillard
					
				
			
			
				
	
			
			
			
						parent
						
							868d92da89
						
					
				
				
					commit
					24464be639
				
			
							
								
								
									
										10
									
								
								HTMLparser.c
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								HTMLparser.c
									
									
									
									
									
								
							| @@ -6780,8 +6780,11 @@ htmlReadIO(xmlInputReadCallback ioread, xmlInputCloseCallback ioclose, | ||||
|  | ||||
|     input = xmlParserInputBufferCreateIO(ioread, ioclose, ioctx, | ||||
|                                          XML_CHAR_ENCODING_NONE); | ||||
|     if (input == NULL) | ||||
|     if (input == NULL) { | ||||
|         if (ioclose != NULL) | ||||
|             ioclose(ioctx); | ||||
|         return (NULL); | ||||
|     } | ||||
|     ctxt = htmlNewParserCtxt(); | ||||
|     if (ctxt == NULL) { | ||||
|         xmlFreeParserInputBuffer(input); | ||||
| @@ -6980,8 +6983,11 @@ htmlCtxtReadIO(htmlParserCtxtPtr ctxt, xmlInputReadCallback ioread, | ||||
|  | ||||
|     input = xmlParserInputBufferCreateIO(ioread, ioclose, ioctx, | ||||
|                                          XML_CHAR_ENCODING_NONE); | ||||
|     if (input == NULL) | ||||
|     if (input == NULL) { | ||||
|         if (ioclose != NULL) | ||||
|             ioclose(ioctx); | ||||
|         return (NULL); | ||||
|     } | ||||
|     stream = xmlNewIOInputStream(ctxt, input, XML_CHAR_ENCODING_NONE); | ||||
|     if (stream == NULL) { | ||||
|         xmlFreeParserInputBuffer(input); | ||||
|   | ||||
							
								
								
									
										16
									
								
								parser.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								parser.c
									
									
									
									
									
								
							| @@ -11988,7 +11988,11 @@ xmlCreateIOParserCtxt(xmlSAXHandlerPtr sax, void *user_data, | ||||
|     if (ioread == NULL) return(NULL); | ||||
|  | ||||
|     buf = xmlParserInputBufferCreateIO(ioread, ioclose, ioctx, enc); | ||||
|     if (buf == NULL) return(NULL); | ||||
|     if (buf == NULL) { | ||||
|         if (ioclose != NULL) | ||||
|             ioclose(ioctx); | ||||
|         return (NULL); | ||||
|     } | ||||
|  | ||||
|     ctxt = xmlNewParserCtxt(); | ||||
|     if (ctxt == NULL) { | ||||
| @@ -14803,8 +14807,11 @@ xmlReadIO(xmlInputReadCallback ioread, xmlInputCloseCallback ioclose, | ||||
|  | ||||
|     input = xmlParserInputBufferCreateIO(ioread, ioclose, ioctx, | ||||
|                                          XML_CHAR_ENCODING_NONE); | ||||
|     if (input == NULL) | ||||
|     if (input == NULL) { | ||||
|         if (ioclose != NULL) | ||||
|             ioclose(ioctx); | ||||
|         return (NULL); | ||||
|     } | ||||
|     ctxt = xmlNewParserCtxt(); | ||||
|     if (ctxt == NULL) { | ||||
|         xmlFreeParserInputBuffer(input); | ||||
| @@ -15006,8 +15013,11 @@ xmlCtxtReadIO(xmlParserCtxtPtr ctxt, xmlInputReadCallback ioread, | ||||
|  | ||||
|     input = xmlParserInputBufferCreateIO(ioread, ioclose, ioctx, | ||||
|                                          XML_CHAR_ENCODING_NONE); | ||||
|     if (input == NULL) | ||||
|     if (input == NULL) { | ||||
|         if (ioclose != NULL) | ||||
|             ioclose(ioctx); | ||||
|         return (NULL); | ||||
|     } | ||||
|     stream = xmlNewIOInputStream(ctxt, input, XML_CHAR_ENCODING_NONE); | ||||
|     if (stream == NULL) { | ||||
|         xmlFreeParserInputBuffer(input); | ||||
|   | ||||
							
								
								
									
										13
									
								
								xmlreader.c
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								xmlreader.c
									
									
									
									
									
								
							| @@ -5401,8 +5401,11 @@ xmlReaderForIO(xmlInputReadCallback ioread, xmlInputCloseCallback ioclose, | ||||
|  | ||||
|     input = xmlParserInputBufferCreateIO(ioread, ioclose, ioctx, | ||||
|                                          XML_CHAR_ENCODING_NONE); | ||||
|     if (input == NULL) | ||||
|     if (input == NULL) { | ||||
|         if (ioclose != NULL) | ||||
|             ioclose(ioctx); | ||||
|         return (NULL); | ||||
|     } | ||||
|     reader = xmlNewTextReader(input, URL); | ||||
|     if (reader == NULL) { | ||||
|         xmlFreeParserInputBuffer(input); | ||||
| @@ -5619,10 +5622,14 @@ xmlReaderNewIO(xmlTextReaderPtr reader, xmlInputReadCallback ioread, | ||||
|  | ||||
|     input = xmlParserInputBufferCreateIO(ioread, ioclose, ioctx, | ||||
|                                          XML_CHAR_ENCODING_NONE); | ||||
|     if (input == NULL) | ||||
|         return (-1); | ||||
|     if (input == NULL) { | ||||
|         if (ioclose != NULL) | ||||
|             ioclose(ioctx); | ||||
|         return (NULL); | ||||
|     } | ||||
|     return (xmlTextReaderSetup(reader, input, URL, encoding, options)); | ||||
| } | ||||
|  | ||||
| /************************************************************************ | ||||
|  *									* | ||||
|  *			Utilities					* | ||||
|   | ||||
		Reference in New Issue
	
	Block a user