mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-24 13:33:01 +03:00 
			
		
		
		
	Stop using doc->charset outside parser code
doc->charset does not specify the in-memory encoding which is always UTF-8.
This commit is contained in:
		
							
								
								
									
										38
									
								
								HTMLtree.c
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								HTMLtree.c
									
									
									
									
									
								
							| @@ -570,16 +570,7 @@ htmlDocDumpMemoryFormat(xmlDocPtr cur, xmlChar**mem, int *size, int format) { | |||||||
| 	xmlCharEncoding enc; | 	xmlCharEncoding enc; | ||||||
|  |  | ||||||
| 	enc = xmlParseCharEncoding(encoding); | 	enc = xmlParseCharEncoding(encoding); | ||||||
| 	if (enc != cur->charset) { | 	if (enc != XML_CHAR_ENCODING_UTF8) { | ||||||
| 	    if (cur->charset != XML_CHAR_ENCODING_UTF8) { |  | ||||||
| 		/* |  | ||||||
| 		 * Not supported yet |  | ||||||
| 		 */ |  | ||||||
| 		*mem = NULL; |  | ||||||
| 		*size = 0; |  | ||||||
| 		return; |  | ||||||
| 	    } |  | ||||||
|  |  | ||||||
| 	    handler = xmlFindCharEncodingHandler(encoding); | 	    handler = xmlFindCharEncodingHandler(encoding); | ||||||
| 	    if (handler == NULL) | 	    if (handler == NULL) | ||||||
|                 htmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding); |                 htmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding); | ||||||
| @@ -1101,14 +1092,7 @@ htmlDocDump(FILE *f, xmlDocPtr cur) { | |||||||
| 	xmlCharEncoding enc; | 	xmlCharEncoding enc; | ||||||
|  |  | ||||||
| 	enc = xmlParseCharEncoding(encoding); | 	enc = xmlParseCharEncoding(encoding); | ||||||
| 	if (enc != cur->charset) { | 	if (enc != XML_CHAR_ENCODING_UTF8) { | ||||||
| 	    if (cur->charset != XML_CHAR_ENCODING_UTF8) { |  | ||||||
| 		/* |  | ||||||
| 		 * Not supported yet |  | ||||||
| 		 */ |  | ||||||
| 		return(-1); |  | ||||||
| 	    } |  | ||||||
|  |  | ||||||
| 	    handler = xmlFindCharEncodingHandler(encoding); | 	    handler = xmlFindCharEncodingHandler(encoding); | ||||||
| 	    if (handler == NULL) | 	    if (handler == NULL) | ||||||
| 		htmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding); | 		htmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding); | ||||||
| @@ -1160,14 +1144,7 @@ htmlSaveFile(const char *filename, xmlDocPtr cur) { | |||||||
| 	xmlCharEncoding enc; | 	xmlCharEncoding enc; | ||||||
|  |  | ||||||
| 	enc = xmlParseCharEncoding(encoding); | 	enc = xmlParseCharEncoding(encoding); | ||||||
| 	if (enc != cur->charset) { | 	if (enc != XML_CHAR_ENCODING_UTF8) { | ||||||
| 	    if (cur->charset != XML_CHAR_ENCODING_UTF8) { |  | ||||||
| 		/* |  | ||||||
| 		 * Not supported yet |  | ||||||
| 		 */ |  | ||||||
| 		return(-1); |  | ||||||
| 	    } |  | ||||||
|  |  | ||||||
| 	    handler = xmlFindCharEncodingHandler(encoding); | 	    handler = xmlFindCharEncodingHandler(encoding); | ||||||
| 	    if (handler == NULL) | 	    if (handler == NULL) | ||||||
| 		htmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding); | 		htmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding); | ||||||
| @@ -1221,14 +1198,7 @@ htmlSaveFileFormat(const char *filename, xmlDocPtr cur, | |||||||
| 	xmlCharEncoding enc; | 	xmlCharEncoding enc; | ||||||
|  |  | ||||||
| 	enc = xmlParseCharEncoding(encoding); | 	enc = xmlParseCharEncoding(encoding); | ||||||
| 	if (enc != cur->charset) { | 	if (enc != XML_CHAR_ENCODING_UTF8) { | ||||||
| 	    if (cur->charset != XML_CHAR_ENCODING_UTF8) { |  | ||||||
| 		/* |  | ||||||
| 		 * Not supported yet |  | ||||||
| 		 */ |  | ||||||
| 		return(-1); |  | ||||||
| 	    } |  | ||||||
|  |  | ||||||
| 	    handler = xmlFindCharEncodingHandler(encoding); | 	    handler = xmlFindCharEncodingHandler(encoding); | ||||||
| 	    if (handler == NULL) | 	    if (handler == NULL) | ||||||
| 		htmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding); | 		htmlSaveErr(XML_SAVE_UNKNOWN_ENCODING, NULL, encoding); | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								c14n.c
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								c14n.c
									
									
									
									
									
								
							| @@ -1797,15 +1797,6 @@ xmlC14NNewCtx(xmlDocPtr doc, | |||||||
|         return (NULL); |         return (NULL); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* |  | ||||||
|      *  Validate the XML document encoding value, if provided. |  | ||||||
|      */ |  | ||||||
|     if (doc->charset != XML_CHAR_ENCODING_UTF8) { |  | ||||||
|         xmlC14NErr(ctx, (xmlNodePtr) doc, XML_C14N_REQUIRES_UTF8, |  | ||||||
| 		   "xmlC14NNewCtx: source document not in UTF8\n"); |  | ||||||
|         return (NULL); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
|      * Allocate a new xmlC14NCtxPtr and fill the fields. |      * Allocate a new xmlC14NCtxPtr and fill the fields. | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -575,7 +575,7 @@ struct _xmlDoc { | |||||||
|     void           *ids;        /* Hash table for ID attributes if any */ |     void           *ids;        /* Hash table for ID attributes if any */ | ||||||
|     void           *refs;       /* Hash table for IDREFs attributes if any */ |     void           *refs;       /* Hash table for IDREFs attributes if any */ | ||||||
|     const xmlChar  *URL;	/* The URI for that document */ |     const xmlChar  *URL;	/* The URI for that document */ | ||||||
|     int             charset;    /* encoding of the in-memory content |     int             charset;    /* Internal flag for charset handling, | ||||||
| 				   actually an xmlCharEncoding */ | 				   actually an xmlCharEncoding */ | ||||||
|     struct _xmlDict *dict;      /* dict used to allocate names or NULL */ |     struct _xmlDict *dict;      /* dict used to allocate names or NULL */ | ||||||
|     void           *psvi;	/* for type/PSVI informations */ |     void           *psvi;	/* for type/PSVI informations */ | ||||||
|   | |||||||
| @@ -1123,9 +1123,6 @@ xmlDocContentDumpOutput(xmlSaveCtxtPtr ctxt, xmlDocPtr cur) { | |||||||
|         cur->encoding = BAD_CAST ctxt->encoding; |         cur->encoding = BAD_CAST ctxt->encoding; | ||||||
|     } else if (cur->encoding != NULL) { |     } else if (cur->encoding != NULL) { | ||||||
| 	encoding = cur->encoding; | 	encoding = cur->encoding; | ||||||
|     } else if (cur->charset != XML_CHAR_ENCODING_UTF8) { |  | ||||||
| 	encoding = (const xmlChar *) |  | ||||||
| 		     xmlGetCharEncodingName((xmlCharEncoding) cur->charset); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (((cur->type == XML_HTML_DOCUMENT_NODE) && |     if (((cur->type == XML_HTML_DOCUMENT_NODE) && | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user