]> granicus.if.org Git - php/commitdiff
Do not wrap user exception in case of custom JSON serialization
authorJulien Pauli <jpauli@php.net>
Mon, 19 Sep 2016 14:06:12 +0000 (16:06 +0200)
committerJulien Pauli <jpauli@php.net>
Mon, 19 Sep 2016 14:06:12 +0000 (16:06 +0200)
ext/json/json.c
ext/json/tests/bug73113.phpt [new file with mode: 0644]

index 8c4d20fb2abf0d668ad6b7982379b317751b9aea..1e37e50ccbb99c55dd4982c0281f9dcde98f48ff 100644 (file)
@@ -589,7 +589,9 @@ static void json_encode_serializable_object(smart_str *buf, zval *val, int optio
        ZVAL_STRING(&fname, "jsonSerialize", 0);
 
        if (FAILURE == call_user_function_ex(EG(function_table), &val, &fname, &retval, 0, NULL, 1, NULL TSRMLS_CC) || !retval) {
-               zend_throw_exception_ex(NULL, 0 TSRMLS_CC, "Failed calling %s::jsonSerialize()", ce->name);
+               if (!EG(exception)) {
+                       zend_throw_exception_ex(NULL, 0 TSRMLS_CC, "Failed calling %s::jsonSerialize()", ce->name);
+               }
                smart_str_appendl(buf, "null", sizeof("null") - 1);
                return;
     }
diff --git a/ext/json/tests/bug73113.phpt b/ext/json/tests/bug73113.phpt
new file mode 100644 (file)
index 0000000..b1d70bc
--- /dev/null
@@ -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