mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-26 00:37:43 +03:00 
			
		
		
		
	lot of out of memory handling fixes from Ashwin work around a problem with
* parser.c: lot of out of memory handling fixes from Ashwin * elfgcchack.h doc/elfgcchack.xsl: work around a problem with xmlDllMain * include/libxml/threads.h: indenting cleanups Daniel svn path=/trunk/; revision=3720
This commit is contained in:
		| @@ -1,3 +1,9 @@ | |||||||
|  | Mon Mar 31 11:23:19 CEST 2008 Daniel Veillard <daniel@veillard.com> | ||||||
|  |  | ||||||
|  | 	* parser.c: lot of out of memory handling fixes from Ashwin | ||||||
|  | 	* elfgcchack.h doc/elfgcchack.xsl: work around a problem with xmlDllMain | ||||||
|  | 	* include/libxml/threads.h: indenting cleanups | ||||||
|  |  | ||||||
| Mon Mar 31 10:25:37 CEST 2008 Daniel Veillard <daniel@veillard.com> | Mon Mar 31 10:25:37 CEST 2008 Daniel Veillard <daniel@veillard.com> | ||||||
|  |  | ||||||
| 	* parser.c docs/*: trying to clarify even more the xmlCleanupParser() | 	* parser.c docs/*: trying to clarify even more the xmlCleanupParser() | ||||||
|   | |||||||
| @@ -106,7 +106,7 @@ extern __typeof (__xmlGenericErrorContext) __xmlGenericErrorContext__internal_al | |||||||
|  |  | ||||||
|   <xsl:template match="function"> |   <xsl:template match="function"> | ||||||
|     <xsl:variable name="str" select="string(@name)"/> |     <xsl:variable name="str" select="string(@name)"/> | ||||||
|     <xsl:if test="starts-with(@name, 'xml') or starts-with(@name, 'html') or contains(@name, 'Push') or contains(@name, 'Pop')"> |     <xsl:if test="(starts-with(@name, 'xml') or starts-with(@name, 'html') or contains(@name, 'Push') or contains(@name, 'Pop')) and (not(contains(@name, 'xmlDllMain')))"> | ||||||
|       <xsl:variable name="alias" select="concat($str, '__internal_alias')"/> |       <xsl:variable name="alias" select="concat($str, '__internal_alias')"/> | ||||||
|       <xsl:apply-templates select="cond"/> |       <xsl:apply-templates select="cond"/> | ||||||
|       <xsl:text>#ifdef bottom_</xsl:text> |       <xsl:text>#ifdef bottom_</xsl:text> | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								elfgcchack.h
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								elfgcchack.h
									
									
									
									
									
								
							| @@ -2877,16 +2877,6 @@ extern __typeof (xmlDictSize) xmlDictSize__internal_alias __attribute((visibilit | |||||||
| #endif | #endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef bottom_threads |  | ||||||
| #undef xmlDllMain |  | ||||||
| extern __typeof (xmlDllMain) xmlDllMain __attribute((alias("xmlDllMain__internal_alias"))); |  | ||||||
| #else |  | ||||||
| #ifndef xmlDllMain |  | ||||||
| extern __typeof (xmlDllMain) xmlDllMain__internal_alias __attribute((visibility("hidden"))); |  | ||||||
| #define xmlDllMain xmlDllMain__internal_alias |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifdef bottom_tree | #ifdef bottom_tree | ||||||
| #undef xmlDocCopyNode | #undef xmlDocCopyNode | ||||||
| extern __typeof (xmlDocCopyNode) xmlDocCopyNode __attribute((alias("xmlDocCopyNode__internal_alias"))); | extern __typeof (xmlDocCopyNode) xmlDocCopyNode __attribute((alias("xmlDocCopyNode__internal_alias"))); | ||||||
|   | |||||||
| @@ -36,40 +36,40 @@ typedef xmlRMutex *xmlRMutexPtr; | |||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
| XMLPUBFUN xmlMutexPtr XMLCALL		 | XMLPUBFUN xmlMutexPtr XMLCALL | ||||||
| 			xmlNewMutex	(void); | 			xmlNewMutex	(void); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlMutexLock	(xmlMutexPtr tok); | 			xmlMutexLock	(xmlMutexPtr tok); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlMutexUnlock	(xmlMutexPtr tok); | 			xmlMutexUnlock	(xmlMutexPtr tok); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlFreeMutex	(xmlMutexPtr tok); | 			xmlFreeMutex	(xmlMutexPtr tok); | ||||||
|  |  | ||||||
| XMLPUBFUN xmlRMutexPtr XMLCALL		 | XMLPUBFUN xmlRMutexPtr XMLCALL | ||||||
| 			xmlNewRMutex	(void); | 			xmlNewRMutex	(void); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlRMutexLock	(xmlRMutexPtr tok); | 			xmlRMutexLock	(xmlRMutexPtr tok); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlRMutexUnlock	(xmlRMutexPtr tok); | 			xmlRMutexUnlock	(xmlRMutexPtr tok); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlFreeRMutex	(xmlRMutexPtr tok); | 			xmlFreeRMutex	(xmlRMutexPtr tok); | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Library wide APIs. |  * Library wide APIs. | ||||||
|  */ |  */ | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlInitThreads	(void); | 			xmlInitThreads	(void); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlLockLibrary	(void); | 			xmlLockLibrary	(void); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlUnlockLibrary(void); | 			xmlUnlockLibrary(void); | ||||||
| XMLPUBFUN int XMLCALL			 | XMLPUBFUN int XMLCALL | ||||||
| 			xmlGetThreadId	(void); | 			xmlGetThreadId	(void); | ||||||
| XMLPUBFUN int XMLCALL			 | XMLPUBFUN int XMLCALL | ||||||
| 			xmlIsMainThread	(void); | 			xmlIsMainThread	(void); | ||||||
| XMLPUBFUN void XMLCALL			 | XMLPUBFUN void XMLCALL | ||||||
| 			xmlCleanupThreads(void); | 			xmlCleanupThreads(void); | ||||||
| XMLPUBFUN xmlGlobalStatePtr XMLCALL	 | XMLPUBFUN xmlGlobalStatePtr XMLCALL | ||||||
| 			xmlGetGlobalState(void); | 			xmlGetGlobalState(void); | ||||||
|  |  | ||||||
| #if defined(HAVE_WIN32_THREADS) && !defined(HAVE_COMPILER_TLS) && defined(LIBXML_STATIC_FOR_DLL) | #if defined(HAVE_WIN32_THREADS) && !defined(HAVE_COMPILER_TLS) && defined(LIBXML_STATIC_FOR_DLL) | ||||||
|   | |||||||
							
								
								
									
										68
									
								
								parser.c
									
									
									
									
									
								
							
							
						
						
									
										68
									
								
								parser.c
									
									
									
									
									
								
							| @@ -1016,7 +1016,11 @@ xmlAddDefAttrs(xmlParserCtxtPtr ctxt, | |||||||
| 	    goto mem_error; | 	    goto mem_error; | ||||||
| 	defaults->nbAttrs = 0; | 	defaults->nbAttrs = 0; | ||||||
| 	defaults->maxAttrs = 4; | 	defaults->maxAttrs = 4; | ||||||
| 	xmlHashUpdateEntry2(ctxt->attsDefault, name, prefix, defaults, NULL); | 	if (xmlHashUpdateEntry2(ctxt->attsDefault, name, prefix, | ||||||
|  | 	                        defaults, NULL) < 0) { | ||||||
|  | 	    xmlFree(defaults); | ||||||
|  | 	    goto mem_error; | ||||||
|  | 	} | ||||||
|     } else if (defaults->nbAttrs >= defaults->maxAttrs) { |     } else if (defaults->nbAttrs >= defaults->maxAttrs) { | ||||||
|         xmlDefAttrsPtr temp; |         xmlDefAttrsPtr temp; | ||||||
|  |  | ||||||
| @@ -1026,7 +1030,11 @@ xmlAddDefAttrs(xmlParserCtxtPtr ctxt, | |||||||
| 	    goto mem_error; | 	    goto mem_error; | ||||||
| 	defaults = temp; | 	defaults = temp; | ||||||
| 	defaults->maxAttrs *= 2; | 	defaults->maxAttrs *= 2; | ||||||
| 	xmlHashUpdateEntry2(ctxt->attsDefault, name, prefix, defaults, NULL); | 	if (xmlHashUpdateEntry2(ctxt->attsDefault, name, prefix, | ||||||
|  | 	                        defaults, NULL) < 0) { | ||||||
|  | 	    xmlFree(defaults); | ||||||
|  | 	    goto mem_error; | ||||||
|  | 	} | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
| @@ -2074,6 +2082,7 @@ xmlNewBlanksWrapperInputStream(xmlParserCtxtPtr ctxt, xmlEntityPtr entity) { | |||||||
|     buffer = xmlMallocAtomic(length); |     buffer = xmlMallocAtomic(length); | ||||||
|     if (buffer == NULL) { |     if (buffer == NULL) { | ||||||
| 	xmlErrMemory(ctxt, NULL); | 	xmlErrMemory(ctxt, NULL); | ||||||
|  |         xmlFree(input); | ||||||
|     	return(NULL); |     	return(NULL); | ||||||
|     } |     } | ||||||
|     buffer [0] = ' '; |     buffer [0] = ' '; | ||||||
| @@ -2290,7 +2299,7 @@ xmlParserHandlePEReference(xmlParserCtxtPtr ctxt) { | |||||||
|     xmlChar *tmp;							\ |     xmlChar *tmp;							\ | ||||||
|     buffer##_size *= 2;							\ |     buffer##_size *= 2;							\ | ||||||
|     tmp = (xmlChar *)							\ |     tmp = (xmlChar *)							\ | ||||||
|     		xmlRealloc(buffer, buffer##_size * sizeof(xmlChar));	\ | 		xmlRealloc(buffer, buffer##_size * sizeof(xmlChar));	\ | ||||||
|     if (tmp == NULL) goto mem_error;					\ |     if (tmp == NULL) goto mem_error;					\ | ||||||
|     buffer = tmp;							\ |     buffer = tmp;							\ | ||||||
| } | } | ||||||
| @@ -2321,6 +2330,7 @@ xmlStringLenDecodeEntities(xmlParserCtxtPtr ctxt, const xmlChar *str, int len, | |||||||
|     int buffer_size = 0; |     int buffer_size = 0; | ||||||
|  |  | ||||||
|     xmlChar *current = NULL; |     xmlChar *current = NULL; | ||||||
|  |     xmlChar *rep = NULL; | ||||||
|     const xmlChar *last; |     const xmlChar *last; | ||||||
|     xmlEntityPtr ent; |     xmlEntityPtr ent; | ||||||
|     int c,l; |     int c,l; | ||||||
| @@ -2380,8 +2390,6 @@ xmlStringLenDecodeEntities(xmlParserCtxtPtr ctxt, const xmlChar *str, int len, | |||||||
| 			    "predefined entity has no content\n"); | 			    "predefined entity has no content\n"); | ||||||
| 		} | 		} | ||||||
| 	    } else if ((ent != NULL) && (ent->content != NULL)) { | 	    } else if ((ent != NULL) && (ent->content != NULL)) { | ||||||
| 		xmlChar *rep; |  | ||||||
|  |  | ||||||
| 		ctxt->depth++; | 		ctxt->depth++; | ||||||
| 		rep = xmlStringDecodeEntities(ctxt, ent->content, what, | 		rep = xmlStringDecodeEntities(ctxt, ent->content, what, | ||||||
| 			                      0, 0, 0); | 			                      0, 0, 0); | ||||||
| @@ -2396,6 +2404,7 @@ xmlStringLenDecodeEntities(xmlParserCtxtPtr ctxt, const xmlChar *str, int len, | |||||||
| 			} | 			} | ||||||
| 		    } | 		    } | ||||||
| 		    xmlFree(rep); | 		    xmlFree(rep); | ||||||
|  | 		    rep = NULL; | ||||||
| 		} | 		} | ||||||
| 	    } else if (ent != NULL) { | 	    } else if (ent != NULL) { | ||||||
| 		int i = xmlStrlen(ent->name); | 		int i = xmlStrlen(ent->name); | ||||||
| @@ -2415,8 +2424,6 @@ xmlStringLenDecodeEntities(xmlParserCtxtPtr ctxt, const xmlChar *str, int len, | |||||||
| 			"String decoding PE Reference: %.30s\n", str); | 			"String decoding PE Reference: %.30s\n", str); | ||||||
| 	    ent = xmlParseStringPEReference(ctxt, &str); | 	    ent = xmlParseStringPEReference(ctxt, &str); | ||||||
| 	    if (ent != NULL) { | 	    if (ent != NULL) { | ||||||
| 		xmlChar *rep; |  | ||||||
|  |  | ||||||
|                 if (ent->content == NULL) { |                 if (ent->content == NULL) { | ||||||
| 		    if (xmlLoadEntityContent(ctxt, ent) < 0) { | 		    if (xmlLoadEntityContent(ctxt, ent) < 0) { | ||||||
| 		    } | 		    } | ||||||
| @@ -2435,6 +2442,7 @@ xmlStringLenDecodeEntities(xmlParserCtxtPtr ctxt, const xmlChar *str, int len, | |||||||
| 			} | 			} | ||||||
| 		    } | 		    } | ||||||
| 		    xmlFree(rep); | 		    xmlFree(rep); | ||||||
|  | 		    rep = NULL; | ||||||
| 		} | 		} | ||||||
| 	    } | 	    } | ||||||
| 	} else { | 	} else { | ||||||
| @@ -2454,6 +2462,10 @@ xmlStringLenDecodeEntities(xmlParserCtxtPtr ctxt, const xmlChar *str, int len, | |||||||
|  |  | ||||||
| mem_error: | mem_error: | ||||||
|     xmlErrMemory(ctxt, NULL); |     xmlErrMemory(ctxt, NULL); | ||||||
|  |     if (rep != NULL) | ||||||
|  |         xmlFree(rep); | ||||||
|  |     if (buffer != NULL) | ||||||
|  |         xmlFree(buffer); | ||||||
|     return(NULL); |     return(NULL); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -2634,7 +2646,7 @@ xmlSplitQName(xmlParserCtxtPtr ctxt, const xmlChar *name, xmlChar **prefix) { | |||||||
| 		tmp = (xmlChar *) xmlRealloc(buffer, | 		tmp = (xmlChar *) xmlRealloc(buffer, | ||||||
| 						max * sizeof(xmlChar)); | 						max * sizeof(xmlChar)); | ||||||
| 		if (tmp == NULL) { | 		if (tmp == NULL) { | ||||||
| 		    xmlFree(tmp); | 		    xmlFree(buffer); | ||||||
| 		    xmlErrMemory(ctxt, NULL); | 		    xmlErrMemory(ctxt, NULL); | ||||||
| 		    return(NULL); | 		    return(NULL); | ||||||
| 		} | 		} | ||||||
| @@ -2698,7 +2710,7 @@ xmlSplitQName(xmlParserCtxtPtr ctxt, const xmlChar *name, xmlChar **prefix) { | |||||||
| 	     * for the processing speed. | 	     * for the processing speed. | ||||||
| 	     */ | 	     */ | ||||||
| 	    max = len * 2; | 	    max = len * 2; | ||||||
| 	     |  | ||||||
| 	    buffer = (xmlChar *) xmlMallocAtomic(max * sizeof(xmlChar)); | 	    buffer = (xmlChar *) xmlMallocAtomic(max * sizeof(xmlChar)); | ||||||
| 	    if (buffer == NULL) { | 	    if (buffer == NULL) { | ||||||
| 	        xmlErrMemory(ctxt, NULL); | 	        xmlErrMemory(ctxt, NULL); | ||||||
| @@ -2724,7 +2736,7 @@ xmlSplitQName(xmlParserCtxtPtr ctxt, const xmlChar *name, xmlChar **prefix) { | |||||||
| 	    } | 	    } | ||||||
| 	    buffer[len] = 0; | 	    buffer[len] = 0; | ||||||
| 	} | 	} | ||||||
| 	 |  | ||||||
| 	if (buffer == NULL) | 	if (buffer == NULL) | ||||||
| 	    ret = xmlStrndup(buf, len); | 	    ret = xmlStrndup(buf, len); | ||||||
| 	else { | 	else { | ||||||
| @@ -3197,6 +3209,7 @@ static xmlChar * | |||||||
| xmlParseAttValueComplex(xmlParserCtxtPtr ctxt, int *attlen, int normalize) { | xmlParseAttValueComplex(xmlParserCtxtPtr ctxt, int *attlen, int normalize) { | ||||||
|     xmlChar limit = 0; |     xmlChar limit = 0; | ||||||
|     xmlChar *buf = NULL; |     xmlChar *buf = NULL; | ||||||
|  |     xmlChar *rep = NULL; | ||||||
|     int len = 0; |     int len = 0; | ||||||
|     int buf_size = 0; |     int buf_size = 0; | ||||||
|     int c, l, in_space = 0; |     int c, l, in_space = 0; | ||||||
| @@ -3215,7 +3228,7 @@ xmlParseAttValueComplex(xmlParserCtxtPtr ctxt, int *attlen, int normalize) { | |||||||
| 	xmlFatalErr(ctxt, XML_ERR_ATTRIBUTE_NOT_STARTED, NULL); | 	xmlFatalErr(ctxt, XML_ERR_ATTRIBUTE_NOT_STARTED, NULL); | ||||||
| 	return(NULL); | 	return(NULL); | ||||||
|     } |     } | ||||||
|      |  | ||||||
|     /* |     /* | ||||||
|      * allocate a translation buffer. |      * allocate a translation buffer. | ||||||
|      */ |      */ | ||||||
| @@ -3280,8 +3293,6 @@ xmlParseAttValueComplex(xmlParserCtxtPtr ctxt, int *attlen, int normalize) { | |||||||
| 		    } | 		    } | ||||||
| 		} else if ((ent != NULL) &&  | 		} else if ((ent != NULL) &&  | ||||||
| 		           (ctxt->replaceEntities != 0)) { | 		           (ctxt->replaceEntities != 0)) { | ||||||
| 		    xmlChar *rep; |  | ||||||
|  |  | ||||||
| 		    if (ent->etype != XML_INTERNAL_PREDEFINED_ENTITY) { | 		    if (ent->etype != XML_INTERNAL_PREDEFINED_ENTITY) { | ||||||
| 			rep = xmlStringDecodeEntities(ctxt, ent->content, | 			rep = xmlStringDecodeEntities(ctxt, ent->content, | ||||||
| 						      XML_SUBSTITUTE_REF, | 						      XML_SUBSTITUTE_REF, | ||||||
| @@ -3295,6 +3306,7 @@ xmlParseAttValueComplex(xmlParserCtxtPtr ctxt, int *attlen, int normalize) { | |||||||
| 				} | 				} | ||||||
| 			    } | 			    } | ||||||
| 			    xmlFree(rep); | 			    xmlFree(rep); | ||||||
|  | 			    rep = NULL; | ||||||
| 			} | 			} | ||||||
| 		    } else { | 		    } else { | ||||||
| 			if (len > buf_size - 10) { | 			if (len > buf_size - 10) { | ||||||
| @@ -3315,9 +3327,11 @@ xmlParseAttValueComplex(xmlParserCtxtPtr ctxt, int *attlen, int normalize) { | |||||||
| 			(ent->content != NULL)) { | 			(ent->content != NULL)) { | ||||||
| 			xmlChar *rep; | 			xmlChar *rep; | ||||||
| 			rep = xmlStringDecodeEntities(ctxt, ent->content, | 			rep = xmlStringDecodeEntities(ctxt, ent->content, | ||||||
| 						      XML_SUBSTITUTE_REF, 0, 0, 0); | 						  XML_SUBSTITUTE_REF, 0, 0, 0); | ||||||
| 			if (rep != NULL) | 			if (rep != NULL) { | ||||||
| 			    xmlFree(rep); | 			    xmlFree(rep); | ||||||
|  | 			    rep = NULL; | ||||||
|  | 			} | ||||||
| 		    } | 		    } | ||||||
|  |  | ||||||
| 		    /* | 		    /* | ||||||
| @@ -3376,6 +3390,10 @@ xmlParseAttValueComplex(xmlParserCtxtPtr ctxt, int *attlen, int normalize) { | |||||||
|  |  | ||||||
| mem_error: | mem_error: | ||||||
|     xmlErrMemory(ctxt, NULL); |     xmlErrMemory(ctxt, NULL); | ||||||
|  |     if (buf != NULL) | ||||||
|  |         xmlFree(buf); | ||||||
|  |     if (rep != NULL) | ||||||
|  |         xmlFree(rep); | ||||||
|     return(NULL); |     return(NULL); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -4644,6 +4662,10 @@ xmlParseEntityDecl(xmlParserCtxtPtr ctxt) { | |||||||
| 		    (xmlStrEqual(ctxt->myDoc->version, SAX_COMPAT_MODE))) { | 		    (xmlStrEqual(ctxt->myDoc->version, SAX_COMPAT_MODE))) { | ||||||
| 		    if (ctxt->myDoc == NULL) { | 		    if (ctxt->myDoc == NULL) { | ||||||
| 			ctxt->myDoc = xmlNewDoc(SAX_COMPAT_MODE); | 			ctxt->myDoc = xmlNewDoc(SAX_COMPAT_MODE); | ||||||
|  | 			if (ctxt->myDoc == NULL) { | ||||||
|  | 			    xmlErrMemory(ctxt, "New Doc failed"); | ||||||
|  | 			    return; | ||||||
|  | 			} | ||||||
| 		    } | 		    } | ||||||
| 		    if (ctxt->myDoc->intSubset == NULL) | 		    if (ctxt->myDoc->intSubset == NULL) | ||||||
| 			ctxt->myDoc->intSubset = xmlNewDtd(ctxt->myDoc, | 			ctxt->myDoc->intSubset = xmlNewDtd(ctxt->myDoc, | ||||||
| @@ -4712,6 +4734,10 @@ xmlParseEntityDecl(xmlParserCtxtPtr ctxt) { | |||||||
| 			(xmlStrEqual(ctxt->myDoc->version, SAX_COMPAT_MODE)))) { | 			(xmlStrEqual(ctxt->myDoc->version, SAX_COMPAT_MODE)))) { | ||||||
| 			if (ctxt->myDoc == NULL) { | 			if (ctxt->myDoc == NULL) { | ||||||
| 			    ctxt->myDoc = xmlNewDoc(SAX_COMPAT_MODE); | 			    ctxt->myDoc = xmlNewDoc(SAX_COMPAT_MODE); | ||||||
|  | 			    if (ctxt->myDoc == NULL) { | ||||||
|  | 			        xmlErrMemory(ctxt, "New Doc failed"); | ||||||
|  | 				return; | ||||||
|  | 			    } | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			if (ctxt->myDoc->intSubset == NULL) | 			if (ctxt->myDoc->intSubset == NULL) | ||||||
| @@ -5216,6 +5242,8 @@ xmlParseElementMixedContentDecl(xmlParserCtxtPtr ctxt, int inputchk) { | |||||||
| 	    } | 	    } | ||||||
| 	    NEXT; | 	    NEXT; | ||||||
| 	    ret = xmlNewDocElementContent(ctxt->myDoc, NULL, XML_ELEMENT_CONTENT_PCDATA); | 	    ret = xmlNewDocElementContent(ctxt->myDoc, NULL, XML_ELEMENT_CONTENT_PCDATA); | ||||||
|  | 	    if (ret == NULL) | ||||||
|  | 	        return(NULL); | ||||||
| 	    if (RAW == '*') { | 	    if (RAW == '*') { | ||||||
| 		ret->ocur = XML_ELEMENT_CONTENT_MULT; | 		ret->ocur = XML_ELEMENT_CONTENT_MULT; | ||||||
| 		NEXT; | 		NEXT; | ||||||
| @@ -5471,6 +5499,11 @@ xmlParseElementChildrenContentDecl (xmlParserCtxtPtr ctxt, int inputchk) { | |||||||
| 		return(NULL); | 		return(NULL); | ||||||
| 	    } | 	    } | ||||||
| 	    last = xmlNewDocElementContent(ctxt->myDoc, elem, XML_ELEMENT_CONTENT_ELEMENT); | 	    last = xmlNewDocElementContent(ctxt->myDoc, elem, XML_ELEMENT_CONTENT_ELEMENT); | ||||||
|  | 	    if (last == NULL) { | ||||||
|  | 		if (ret != NULL) | ||||||
|  | 		    xmlFreeDocElementContent(ctxt->myDoc, ret); | ||||||
|  | 		return(NULL); | ||||||
|  | 	    } | ||||||
| 	    if (RAW == '?') { | 	    if (RAW == '?') { | ||||||
| 		last->ocur = XML_ELEMENT_CONTENT_OPT; | 		last->ocur = XML_ELEMENT_CONTENT_OPT; | ||||||
| 		NEXT; | 		NEXT; | ||||||
| @@ -8980,6 +9013,7 @@ xmlParseVersionNum(xmlParserCtxtPtr ctxt) { | |||||||
| 	    size *= 2; | 	    size *= 2; | ||||||
| 	    tmp = (xmlChar *) xmlRealloc(buf, size * sizeof(xmlChar)); | 	    tmp = (xmlChar *) xmlRealloc(buf, size * sizeof(xmlChar)); | ||||||
| 	    if (tmp == NULL) { | 	    if (tmp == NULL) { | ||||||
|  | 	        xmlFree(buf); | ||||||
| 		xmlErrMemory(ctxt, NULL); | 		xmlErrMemory(ctxt, NULL); | ||||||
| 		return(NULL); | 		return(NULL); | ||||||
| 	    } | 	    } | ||||||
| @@ -8996,11 +9030,11 @@ xmlParseVersionNum(xmlParserCtxtPtr ctxt) { | |||||||
| /** | /** | ||||||
|  * xmlParseVersionInfo: |  * xmlParseVersionInfo: | ||||||
|  * @ctxt:  an XML parser context |  * @ctxt:  an XML parser context | ||||||
|  *  |  * | ||||||
|  * parse the XML version. |  * parse the XML version. | ||||||
|  * |  * | ||||||
|  * [24] VersionInfo ::= S 'version' Eq (' VersionNum ' | " VersionNum ") |  * [24] VersionInfo ::= S 'version' Eq (' VersionNum ' | " VersionNum ") | ||||||
|  *  |  * | ||||||
|  * [25] Eq ::= S? '=' S? |  * [25] Eq ::= S? '=' S? | ||||||
|  * |  * | ||||||
|  * Returns the version string, e.g. "1.0" |  * Returns the version string, e.g. "1.0" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user