|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
Patch jsonserializedepth-55 for JSON related Bug #72073Patch version 2016-04-22 15:09 UTC Return to Bug #72073 | Download this patchThis patch is obsolete Obsoleted by patches: Patch Revisions:Developer: jani.ollikainen@valve.fi
--- php-json-1.3.2.orig/jsonc-1.3.2/json.c
+++ php-json-1.3.2/jsonc-1.3.2/json.c
@@ -681,7 +681,7 @@ static void json_escape_string(smart_str
static void json_encode_serializable_object(smart_str *buf, zval *val, int options TSRMLS_DC) /* {{{ */
{
zend_class_entry *ce = Z_OBJCE_P(val);
- zval *retval = NULL, fname;
+ zval *retval = NULL, fname, **args[1], *depth;
HashTable* myht;
if (Z_TYPE_P(val) == IS_ARRAY) {
@@ -696,9 +696,12 @@ static void json_encode_serializable_obj
return;
}
+ MAKE_STD_ZVAL(depth);
+ ZVAL_LONG(depth, JSON_G(encoder_depth));
+ args[0] = &depth;
ZVAL_STRING(&fname, "jsonSerialize", 0);
- if (FAILURE == call_user_function_ex(EG(function_table), &val, &fname, &retval, 0, NULL, 1, NULL TSRMLS_CC) || !retval) {
+ if (FAILURE == call_user_function_ex(EG(function_table), &val, &fname, &retval, 1, args, 1, NULL TSRMLS_CC) || !retval) {
zend_throw_exception_ex(NULL, 0 TSRMLS_CC, "Failed calling %s::jsonSerialize()", ce->name);
smart_str_appendl(buf, "null", sizeof("null") - 1);
return;
@@ -720,6 +723,7 @@ static void json_encode_serializable_obj
php_json_encode(buf, retval, options TSRMLS_CC);
}
+ zval_ptr_dtor(&depth);
zval_ptr_dtor(&retval);
}
/* }}} */
|
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Mon Oct 27 16:00:01 2025 UTC |