diff options
-rw-r--r-- | spec/util_serialization_spec.lua | 8 | ||||
-rw-r--r-- | util/serialization.lua | 26 |
2 files changed, 20 insertions, 14 deletions
diff --git a/spec/util_serialization_spec.lua b/spec/util_serialization_spec.lua index 52075bc2..d22cf738 100644 --- a/spec/util_serialization_spec.lua +++ b/spec/util_serialization_spec.lua @@ -44,6 +44,14 @@ describe("util.serialization", function () test({foo={[100]={{"bar"},{baz=1}}}}); test({["goto"] = {["function"]={["do"]="keywords"}}}); end); + + it("can serialize with metatables", function () + local s = serialization.new({ freeze = true }); + local t = setmetatable({ a = "hi" }, { __freeze = function (t) return { t.a } end }); + local rt = serialization.deserialize(s(t)); + assert.same({"hi"}, rt); + end); + end); end); diff --git a/util/serialization.lua b/util/serialization.lua index f7f129b2..852b41da 100644 --- a/util/serialization.lua +++ b/util/serialization.lua @@ -139,25 +139,23 @@ local function new(opt) end o[t] = true; - if freeze then + + if freeze == true then -- opportunity to do pre-serialization local mt = getmetatable(t); - local fr = (type(freeze) == "table" and freeze[mt]); - local mf = mt and mt.__freeze; - local tag; - if type(fr) == "string" then - tag = fr; - fr = mf; - elseif mt then - tag = mt.__type; - end - if type(fr) == "function" then - t = fr(t); - if type(tag) == "string" then - o[l], l = tag, l + 1; + if type(mt) == "table" then + local tag = mt.__name; + local fr = mt.__freeze; + + if type(fr) == "function" then + t = fr(t); + if type(tag) == "string" then + o[l], l = tag, l + 1; + end end end end + o[l], l = tstart, l + 1; local indent = s_rep(indentwith, d); local numkey = 1; |