Merge branch 'PHP-8.2' into PHP-8.3

* PHP-8.2:
  Fix libxml2 2.12 build due to API breaks
This commit is contained in:
Niels Dossche 2023-12-01 18:07:13 +01:00
commit f61f8d439c
2 changed files with 12 additions and 6 deletions

View file

@ -608,7 +608,11 @@ static void _php_libxml_free_error(void *ptr)
xmlResetError((xmlErrorPtr) ptr);
}
static void _php_list_set_error_structure(xmlErrorPtr error, const char *msg)
#if LIBXML_VERSION >= 21200
static void _php_list_set_error_structure(const xmlError *error, const char *msg)
#else
static void _php_list_set_error_structure(xmlError *error, const char *msg)
#endif
{
xmlError error_copy;
int ret;
@ -839,7 +843,11 @@ PHP_LIBXML_API void php_libxml_ctx_warning(void *ctx, const char *msg, ...)
va_end(args);
}
static void php_libxml_structured_error_handler(void *userData, xmlErrorPtr error)
#if LIBXML_VERSION >= 21200
void php_libxml_structured_error_handler(void *userData, const xmlError *error)
#else
void php_libxml_structured_error_handler(void *userData, xmlErrorPtr error)
#endif
{
_php_list_set_error_structure(error, NULL);
@ -1071,11 +1079,9 @@ PHP_FUNCTION(libxml_use_internal_errors)
/* {{{ Retrieve last error from libxml */
PHP_FUNCTION(libxml_get_last_error)
{
xmlErrorPtr error;
ZEND_PARSE_PARAMETERS_NONE();
error = xmlGetLastError();
const xmlError *error = xmlGetLastError();
if (error) {
object_init_ex(return_value, libxmlerror_class_entry);