mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-24 13:33:01 +03:00 
			
		
		
		
	malloc-fail: Fix memory leak in xmlRegexpCompile
Found with libFuzzer, see #344.
This commit is contained in:
		
							
								
								
									
										18
									
								
								xmlregexp.c
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								xmlregexp.c
									
									
									
									
									
								
							| @@ -5603,7 +5603,7 @@ xmlRegexpPrint(FILE *output, xmlRegexpPtr regexp) { | |||||||
|  */ |  */ | ||||||
| xmlRegexpPtr | xmlRegexpPtr | ||||||
| xmlRegexpCompile(const xmlChar *regexp) { | xmlRegexpCompile(const xmlChar *regexp) { | ||||||
|     xmlRegexpPtr ret; |     xmlRegexpPtr ret = NULL; | ||||||
|     xmlRegParserCtxtPtr ctxt; |     xmlRegParserCtxtPtr ctxt; | ||||||
|  |  | ||||||
|     ctxt = xmlRegNewParserCtxt(regexp); |     ctxt = xmlRegNewParserCtxt(regexp); | ||||||
| @@ -5613,7 +5613,7 @@ xmlRegexpCompile(const xmlChar *regexp) { | |||||||
|     /* initialize the parser */ |     /* initialize the parser */ | ||||||
|     ctxt->state = xmlRegStatePush(ctxt); |     ctxt->state = xmlRegStatePush(ctxt); | ||||||
|     if (ctxt->state == NULL) |     if (ctxt->state == NULL) | ||||||
|         return(NULL); |         goto error; | ||||||
|     ctxt->start = ctxt->state; |     ctxt->start = ctxt->state; | ||||||
|     ctxt->end = NULL; |     ctxt->end = NULL; | ||||||
|  |  | ||||||
| @@ -5622,10 +5622,8 @@ xmlRegexpCompile(const xmlChar *regexp) { | |||||||
|     if (CUR != 0) { |     if (CUR != 0) { | ||||||
| 	ERROR("xmlFAParseRegExp: extra characters"); | 	ERROR("xmlFAParseRegExp: extra characters"); | ||||||
|     } |     } | ||||||
|     if (ctxt->error != 0) { |     if (ctxt->error != 0) | ||||||
| 	xmlRegFreeParserCtxt(ctxt); |         goto error; | ||||||
| 	return(NULL); |  | ||||||
|     } |  | ||||||
|     ctxt->end = ctxt->state; |     ctxt->end = ctxt->state; | ||||||
|     ctxt->start->type = XML_REGEXP_START_STATE; |     ctxt->start->type = XML_REGEXP_START_STATE; | ||||||
|     ctxt->end->type = XML_REGEXP_FINAL_STATE; |     ctxt->end->type = XML_REGEXP_FINAL_STATE; | ||||||
| @@ -5634,11 +5632,11 @@ xmlRegexpCompile(const xmlChar *regexp) { | |||||||
|     xmlFAEliminateEpsilonTransitions(ctxt); |     xmlFAEliminateEpsilonTransitions(ctxt); | ||||||
|  |  | ||||||
|  |  | ||||||
|     if (ctxt->error != 0) { |     if (ctxt->error != 0) | ||||||
| 	xmlRegFreeParserCtxt(ctxt); |         goto error; | ||||||
| 	return(NULL); |  | ||||||
|     } |  | ||||||
|     ret = xmlRegEpxFromParse(ctxt); |     ret = xmlRegEpxFromParse(ctxt); | ||||||
|  |  | ||||||
|  | error: | ||||||
|     xmlRegFreeParserCtxt(ctxt); |     xmlRegFreeParserCtxt(ctxt); | ||||||
|     return(ret); |     return(ret); | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user