mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-24 13:33:01 +03:00 
			
		
		
		
	Fix SetGenericErrorFunc and SetStructured clash
* include/libxml/globals.h globals.c global.data: define a new global variable (per thread) for structured error reporting, to not conflict with generic one * error.c: when defined use the structured error report over any generic one
This commit is contained in:
		
				
					committed by
					
						 Daniel Veillard
						Daniel Veillard
					
				
			
			
				
	
			
			
			
						parent
						
							c78988acb7
						
					
				
				
					commit
					1de382eb06
				
			
							
								
								
									
										13
									
								
								error.c
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								error.c
									
									
									
									
									
								
							| @@ -132,7 +132,7 @@ xmlSetGenericErrorFunc(void *ctx, xmlGenericErrorFunc handler) { | ||||
|  */ | ||||
| void | ||||
| xmlSetStructuredErrorFunc(void *ctx, xmlStructuredErrorFunc handler) { | ||||
|     xmlGenericErrorContext = ctx; | ||||
|     xmlStructuredErrorContext = ctx; | ||||
|     xmlStructuredError = handler; | ||||
| } | ||||
|  | ||||
| @@ -471,7 +471,7 @@ __xmlRaiseError(xmlStructuredErrorFunc schannel, | ||||
| 	 * if user has defined handler, change data ptr to user's choice | ||||
| 	 */ | ||||
| 	if (schannel != NULL) | ||||
| 	    data = xmlGenericErrorContext; | ||||
| 	    data = xmlStructuredErrorContext; | ||||
|     } | ||||
|     if ((domain == XML_FROM_VALID) && | ||||
|         ((channel == xmlParserValidityError) || | ||||
| @@ -593,21 +593,24 @@ __xmlRaiseError(xmlStructuredErrorFunc schannel, | ||||
|     /* | ||||
|      * Find the callback channel if channel param is NULL | ||||
|      */ | ||||
|     if ((ctxt != NULL) && (channel == NULL) && (xmlStructuredError == NULL) && (ctxt->sax != NULL)) { | ||||
|     if ((ctxt != NULL) && (channel == NULL) && | ||||
|         (xmlStructuredError == NULL) && (ctxt->sax != NULL)) { | ||||
|         if (level == XML_ERR_WARNING) | ||||
| 	    channel = ctxt->sax->warning; | ||||
|         else | ||||
| 	    channel = ctxt->sax->error; | ||||
| 	data = ctxt->userData; | ||||
|     } else if (channel == NULL) { | ||||
|         if ((schannel == NULL) && (xmlStructuredError != NULL)) | ||||
|         if ((schannel == NULL) && (xmlStructuredError != NULL)) { | ||||
| 	    schannel = xmlStructuredError; | ||||
| 	else | ||||
| 	    data = xmlStructuredErrorContext; | ||||
| 	} else { | ||||
| 	    channel = xmlGenericError; | ||||
| 	    if (!data) { | ||||
| 		data = xmlGenericErrorContext; | ||||
| 	    } | ||||
| 	} | ||||
|     } | ||||
|     if (schannel != NULL) { | ||||
|         schannel(data, to); | ||||
| 	return; | ||||
|   | ||||
| @@ -2,11 +2,13 @@ | ||||
| int,oldXMLWDcompatibility,, | ||||
| xmlBufferAllocationScheme,xmlBufferAllocScheme,,1 | ||||
| int,xmlDefaultBufferSize,,1 | ||||
| xmlSAXHandler,xmlDefaultSAXHandler,, | ||||
| xmlSAXHandlerV1,xmlDefaultSAXHandler,, | ||||
| xmlSAXLocator,xmlDefaultSAXLocator,, | ||||
| int,xmlDoValidityCheckingDefaultValue,,1 | ||||
| xmlGenericErrorFunc,xmlGenericError,, | ||||
| xmlStructuredErrorFunc,xmlStructuredError,, | ||||
| void *,xmlGenericErrorContext,, | ||||
| void *,xmlStructuredErrorContext,, | ||||
| int,xmlGetWarningsDefaultValue,,1 | ||||
| int,xmlIndentTreeOutput,,1 | ||||
| const char *,xmlTreeIndentString,,1 | ||||
| @@ -23,3 +25,5 @@ int,xmlSaveNoEmptyTags,,1 | ||||
| int,xmlSubstituteEntitiesDefaultValue,,1 | ||||
| xmlRegisterNodeFunc,xmlRegisterNodeDefaultValue,, | ||||
| xmlDeregisterNodeFunc,xmlDeregisterNodeDefaultValue,, | ||||
| xmlParserInputBufferCreateFilenameFunc,xmlParserInputBufferCreateFilenameValue,, | ||||
| xmlOutputBufferCreateFilenameFunc,xmlOutputBufferCreateFilenameValue,, | ||||
|   | ||||
							
								
								
									
										20
									
								
								globals.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								globals.c
									
									
									
									
									
								
							| @@ -148,6 +148,7 @@ xmlStrdupFunc xmlMemStrdup = (xmlStrdupFunc) xmlStrdup; | ||||
| #undef	xmlGenericError | ||||
| #undef	xmlStructuredError | ||||
| #undef	xmlGenericErrorContext | ||||
| #undef	xmlStructuredErrorContext | ||||
| #undef	xmlGetWarningsDefaultValue | ||||
| #undef	xmlIndentTreeOutput | ||||
| #undef  xmlTreeIndentString | ||||
| @@ -314,6 +315,13 @@ static xmlStructuredErrorFunc xmlStructuredErrorThrDef = NULL; | ||||
|  */ | ||||
| void *xmlGenericErrorContext = NULL; | ||||
| static void *xmlGenericErrorContextThrDef = NULL; | ||||
| /** | ||||
|  * xmlStructuredErrorContext: | ||||
|  * | ||||
|  * Global setting passed to structured error callbacks | ||||
|  */ | ||||
| void *xmlStructuredErrorContext = NULL; | ||||
| static void *xmlStructuredErrorContextThrDef = NULL; | ||||
| xmlError xmlLastError; | ||||
|  | ||||
| /* | ||||
| @@ -545,6 +553,7 @@ xmlInitializeGlobalState(xmlGlobalStatePtr gs) | ||||
|     gs->xmlGenericError = xmlGenericErrorThrDef; | ||||
|     gs->xmlStructuredError = xmlStructuredErrorThrDef; | ||||
|     gs->xmlGenericErrorContext = xmlGenericErrorContextThrDef; | ||||
|     gs->xmlStructuredErrorContext = xmlStructuredErrorContextThrDef; | ||||
|     gs->xmlRegisterNodeDefaultValue = xmlRegisterNodeDefaultValueThrDef; | ||||
|     gs->xmlDeregisterNodeDefaultValue = xmlDeregisterNodeDefaultValueThrDef; | ||||
|  | ||||
| @@ -573,7 +582,7 @@ xmlThrDefSetGenericErrorFunc(void *ctx, xmlGenericErrorFunc handler) { | ||||
| void | ||||
| xmlThrDefSetStructuredErrorFunc(void *ctx, xmlStructuredErrorFunc handler) { | ||||
|     xmlMutexLock(xmlThrDefMutex); | ||||
|     xmlGenericErrorContextThrDef = ctx; | ||||
|     xmlStructuredErrorContextThrDef = ctx; | ||||
|     xmlStructuredErrorThrDef = handler; | ||||
|     xmlMutexUnlock(xmlThrDefMutex); | ||||
| } | ||||
| @@ -876,6 +885,15 @@ __xmlGenericErrorContext(void) { | ||||
| 	return (&xmlGetGlobalState()->xmlGenericErrorContext); | ||||
| } | ||||
|  | ||||
| #undef	xmlStructuredErrorContext | ||||
| void * * | ||||
| __xmlStructuredErrorContext(void) { | ||||
|     if (IS_MAIN_THREAD) | ||||
| 	return (&xmlStructuredErrorContext); | ||||
|     else | ||||
| 	return (&xmlGetGlobalState()->xmlStructuredErrorContext); | ||||
| } | ||||
|  | ||||
| #undef	xmlGetWarningsDefaultValue | ||||
| int * | ||||
| __xmlGetWarningsDefaultValue(void) { | ||||
|   | ||||
| @@ -76,6 +76,7 @@ XMLCALL xmlOutputBufferCreateFilenameDefault (xmlOutputBufferCreateFilenameFunc | ||||
| #undef	xmlGenericError | ||||
| #undef	xmlStructuredError | ||||
| #undef	xmlGenericErrorContext | ||||
| #undef	xmlStructuredErrorContext | ||||
| #undef	xmlGetWarningsDefaultValue | ||||
| #undef	xmlIndentTreeOutput | ||||
| #undef  xmlTreeIndentString | ||||
| @@ -158,6 +159,8 @@ struct _xmlGlobalState | ||||
|  | ||||
| 	xmlParserInputBufferCreateFilenameFunc xmlParserInputBufferCreateFilenameValue; | ||||
| 	xmlOutputBufferCreateFilenameFunc xmlOutputBufferCreateFilenameValue; | ||||
|  | ||||
| 	void *xmlStructuredErrorContext; | ||||
| }; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| @@ -354,6 +357,14 @@ XMLPUBFUN void * * XMLCALL __xmlGenericErrorContext(void); | ||||
| XMLPUBVAR void * xmlGenericErrorContext; | ||||
| #endif | ||||
|  | ||||
| XMLPUBFUN void * * XMLCALL __xmlStructuredErrorContext(void); | ||||
| #ifdef LIBXML_THREAD_ENABLED | ||||
| #define xmlStructuredErrorContext \ | ||||
| (*(__xmlStructuredErrorContext())) | ||||
| #else | ||||
| LIBXML_DLL_IMPORT extern void * xmlStructuredErrorContext; | ||||
| #endif | ||||
|  | ||||
| XMLPUBFUN int * XMLCALL __xmlGetWarningsDefaultValue(void); | ||||
| #ifdef LIBXML_THREAD_ENABLED | ||||
| #define xmlGetWarningsDefaultValue \ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user