From c36263e3500b2e030c7ded02d4a1357d8b9ff451 Mon Sep 17 00:00:00 2001 From: etienne Date: Mon, 14 Dec 2020 15:08:16 +0100 Subject: [PATCH] Manage JSON_THROW_ON_ERROR conflict --- lib/special_cases.php | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/lib/special_cases.php b/lib/special_cases.php index d18e2118..f4cfaa80 100644 --- a/lib/special_cases.php +++ b/lib/special_cases.php @@ -30,6 +30,15 @@ */ function json_decode(string $json, bool $assoc = false, int $depth = 512, int $options = 0) { + if ($options & 4194304) { // options has JSON_THROW_ON_ERROR + try { + $data = \json_decode($json, $assoc, $depth, $options); + } catch (\Exception $e) { + throw new JsonException($e->getMessage(), (int) $e->getCode()); + } + return $data; + } + $data = \json_decode($json, $assoc, $depth, $options); if (JSON_ERROR_NONE !== json_last_error()) { throw JsonException::createFromPhpError();