diff options
author | Xinchen Hui <laruence@gmail.com> | 2016-04-22 21:41:52 -0700 |
---|---|---|
committer | Xinchen Hui <laruence@gmail.com> | 2016-04-22 21:41:52 -0700 |
commit | fa5f28a0a176ecf9b7617eb24b757620a5355ca6 (patch) | |
tree | 96da473b96b002f6ed5007efb46219edbeeca513 /ext/json/json_encoder.c | |
parent | 67947d0fda85a8383a5018f3aa7a17a61d521cdf (diff) | |
parent | 589d0e0f187ff82f90110057f624c958f0d3ec86 (diff) | |
download | php-git-fa5f28a0a176ecf9b7617eb24b757620a5355ca6.tar.gz |
Merge branch 'PHP-7.0'
Diffstat (limited to 'ext/json/json_encoder.c')
-rw-r--r-- | ext/json/json_encoder.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/ext/json/json_encoder.c b/ext/json/json_encoder.c index 8da5abd088..62df102847 100644 --- a/ext/json/json_encoder.c +++ b/ext/json/json_encoder.c @@ -457,6 +457,7 @@ static void php_json_encode_serializable_object(smart_str *buf, zval *val, int o zend_class_entry *ce = Z_OBJCE_P(val); zval retval, fname; HashTable* myht; + int origin_error_code; if (Z_TYPE_P(val) == IS_ARRAY) { myht = Z_ARRVAL_P(val); @@ -470,8 +471,10 @@ static void php_json_encode_serializable_object(smart_str *buf, zval *val, int o return; } + ZVAL_STRING(&fname, "jsonSerialize"); + origin_error_code = JSON_G(error_code); if (FAILURE == call_user_function_ex(EG(function_table), val, &fname, &retval, 0, NULL, 1, NULL) || Z_TYPE(retval) == IS_UNDEF) { zend_throw_exception_ex(NULL, 0, "Failed calling %s::jsonSerialize()", ZSTR_VAL(ce->name)); smart_str_appendl(buf, "null", sizeof("null") - 1); @@ -479,6 +482,7 @@ static void php_json_encode_serializable_object(smart_str *buf, zval *val, int o return; } + JSON_G(error_code) = origin_error_code; if (EG(exception)) { /* Error already raised */ zval_ptr_dtor(&retval); |