diff options
author | Simon Rettberg | 2014-08-13 05:05:36 +0200 |
---|---|---|
committer | Simon Rettberg | 2014-08-13 05:05:36 +0200 |
commit | 0826374029fc16af30fe1d66d65c897c9e25a30f (patch) | |
tree | 5abd9cd4ed0a5a835d3dc376f8970ec16ebb8a4a /inc/up_json_encode.php | |
parent | Merge branch 'i18n' of https://gitlab.c3sl.ufpr.br/cdn/slx-admin into i18n (diff) | |
download | slx-admin-0826374029fc16af30fe1d66d65c897c9e25a30f.tar.gz slx-admin-0826374029fc16af30fe1d66d65c897c9e25a30f.tar.xz slx-admin-0826374029fc16af30fe1d66d65c897c9e25a30f.zip |
Fix up_json_encode to actually work properly on assoc arrays
Diffstat (limited to 'inc/up_json_encode.php')
-rw-r--r-- | inc/up_json_encode.php | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/inc/up_json_encode.php b/inc/up_json_encode.php index b3b843c1..07fcb0c7 100644 --- a/inc/up_json_encode.php +++ b/inc/up_json_encode.php @@ -82,21 +82,26 @@ function up_json_encode($var, $options = 0, $_indent = "") ${'.json_last_error'} = JSON_ERROR_NONE; #-- prepare JSON string - $obj = ($options & JSON_FORCE_OBJECT); list($_space, $_tab, $_nl) = ($options & JSON_PRETTY_PRINT) ? array(" ", " $_indent", "\n") : array("", "", ""); $json = "$_indent"; - if ($options & JSON_NUMERIC_CHECK and is_string($var) and is_numeric($var)) { + if (($options & JSON_NUMERIC_CHECK) and is_string($var) and is_numeric($var)) { $var = (strpos($var, ".") || strpos($var, "e")) ? floatval($var) : intval($var); } #-- add array entries if (is_array($var) || ($obj = is_object($var))) { - + $obj = is_object($var); #-- check if array is associative - if (!$obj) { - $keys = array_keys((array) $var); - $obj = !($keys == array_keys($keys)); // keys must be in 0,1,2,3, ordering, but PHP treats integers==strings otherwise + if (!$obj && !($options & JSON_FORCE_OBJECT)) { + $keys = array_keys($var); + sort($keys); + for ($i = 0; $i < count($keys); ++$i) { + if (!is_numeric($keys[$i]) || (int)$keys[$i] !== $i) + $obj = true; + } + } else { + $obj = true; } #-- concat individual entries @@ -104,7 +109,7 @@ function up_json_encode($var, $options = 0, $_indent = "") $json = ""; foreach ((array) $var as $i => $v) { $json .= ($empty++ ? ",$_nl" : "") // comma separators - . $_tab . ($obj ? (up_json_encode($i, $options & ~JSON_NUMERIC_CHECK, $_tab) . ":$_space") : "") // assoc prefix + . $_tab . ($obj ? (up_json_encode((string)$i, $options & ~JSON_NUMERIC_CHECK, $_tab) . ":$_space") : "") // assoc prefix . (up_json_encode($v, $options, $_tab)); // value } |