summaryrefslogtreecommitdiff
path: root/ext/json
diff options
context:
space:
mode:
authorJulien Pauli <jpauli@php.net>2016-09-19 16:08:37 +0200
committerJulien Pauli <jpauli@php.net>2016-09-19 16:11:17 +0200
commitc4f3ea10e49a2a44e767ce38c57329934a6bbaba (patch)
tree168fe7732a5b216389c16e5c9e1e0e6587c1eb47 /ext/json
parent01759c43463c30b57c15e32c5f4b454fba81f039 (diff)
parent1ed4b13fb62eafc53fca06c1929613c334b51edb (diff)
downloadphp-git-c4f3ea10e49a2a44e767ce38c57329934a6bbaba.tar.gz
Merge branch 'PHP-5.6' into PHP-7.0
* PHP-5.6: Do not wrap user exception in case of custom JSON serialization Conflicts: ext/json/json.c
Diffstat (limited to 'ext/json')
-rw-r--r--ext/json/json_encoder.c4
-rw-r--r--ext/json/tests/bug73113.phpt24
2 files changed, 27 insertions, 1 deletions
diff --git a/ext/json/json_encoder.c b/ext/json/json_encoder.c
index ae9e086fc0..8da2761e99 100644
--- a/ext/json/json_encoder.c
+++ b/ext/json/json_encoder.c
@@ -467,7 +467,9 @@ static void php_json_encode_serializable_object(smart_str *buf, zval *val, int o
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));
+ if (!EG(exception)) {
+ zend_throw_exception_ex(NULL, 0, "Failed calling %s::jsonSerialize()", ZSTR_VAL(ce->name));
+ }
smart_str_appendl(buf, "null", sizeof("null") - 1);
zval_ptr_dtor(&fname);
return;
diff --git a/ext/json/tests/bug73113.phpt b/ext/json/tests/bug73113.phpt
new file mode 100644
index 0000000000..b1d70bc4c7
--- /dev/null
+++ b/ext/json/tests/bug73113.phpt
@@ -0,0 +1,24 @@
+--TEST--
+Bug #73113 (Segfault with throwing JsonSerializable)
+Also test that the custom exception is not wrapped by ext/json
+--SKIPIF--
+<?php if (!extension_loaded("json")) print "skip"; ?>
+--FILE--
+<?php
+
+class JsonSerializableObject implements \JsonSerializable
+{
+ public function jsonSerialize()
+ {
+ throw new \Exception('This error is expected');
+ }
+}
+
+$obj = new JsonSerializableObject();
+try {
+ echo json_encode($obj);
+} catch (\Exception $e) {
+ echo $e->getMessage();
+}
+--EXPECTF--
+This error is expected