diff options
author | Waqas Hussain <waqas20@gmail.com> | 2013-04-23 14:41:52 -0400 |
---|---|---|
committer | Waqas Hussain <waqas20@gmail.com> | 2013-04-23 14:41:52 -0400 |
commit | 8cf79c1fbe0cafeb495e7a404b75a043bc4cfc9e (patch) | |
tree | a87980637405b12cc785451aca642a5ac738140c /util | |
parent | 5468423a19fc09b010d0c4aa92e486ecbe0c9dae (diff) | |
download | prosody-8cf79c1fbe0cafeb495e7a404b75a043bc4cfc9e.tar.gz prosody-8cf79c1fbe0cafeb495e7a404b75a043bc4cfc9e.zip |
util.json: Make encode(decode("[]"))=="[]".
Diffstat (limited to 'util')
-rw-r--r-- | util/json.lua | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/util/json.lua b/util/json.lua index ff7351a7..e8de4d2d 100644 --- a/util/json.lua +++ b/util/json.lua @@ -18,6 +18,9 @@ local error = error; local newproxy, getmetatable = newproxy, getmetatable; local print = print; +local has_array, array = pcall(require, "util.array"); +local array_mt = hasarray and getmetatable(array()) or {}; + --module("json") local json = {}; @@ -165,7 +168,12 @@ function simplesave(o, buffer) elseif t == "string" then stringsave(o, buffer); elseif t == "table" then - tablesave(o, buffer); + local mt = getmetatable(o); + if mt == array_mt then + arraysave(o, buffer); + else + tablesave(o, buffer); + end elseif t == "boolean" then t_insert(buffer, (o and "true" or "false")); else @@ -237,7 +245,7 @@ function json.decode(json) local readvalue; local function readarray() - local t = {}; + local t = setmetatable({}, array_mt); next(); -- skip '[' skipstuff(); if ch == "]" then next(); return t; end |