aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2019-03-17 20:40:01 +0100
committerKim Alvefur <zash@zash.se>2019-03-17 20:40:01 +0100
commit8dbde146973dbdf875e1a5fc5a455218426f454c (patch)
treee72a94bcbc46c7b61bf6c80cd171fbf91c677dc1
parentb4f63e714100773e131d69792239875583595c15 (diff)
downloadprosody-8dbde146973dbdf875e1a5fc5a455218426f454c.tar.gz
prosody-8dbde146973dbdf875e1a5fc5a455218426f454c.zip
util.serialization: Optimize handling of last table separator
Fewer next() calls and a step towards allowing use of a different iterator.
-rw-r--r--util/serialization.lua12
1 files changed, 5 insertions, 7 deletions
diff --git a/util/serialization.lua b/util/serialization.lua
index 7ae77a3a..c64bfec1 100644
--- a/util/serialization.lua
+++ b/util/serialization.lua
@@ -163,7 +163,9 @@ local function new(opt)
local indent = s_rep(indentwith, d);
local numkey = 1;
local ktyp, vtyp;
+ local had_items = false;
for k,v in next,t do
+ had_items = true;
o[l], l = itemstart, l + 1;
o[l], l = indent, l + 1;
ktyp, vtyp = type(k), type(v);
@@ -194,14 +196,10 @@ local function new(opt)
else
o[l], l = ser(v), l + 1;
end
- -- last item?
- if next(t, k) ~= nil then
- o[l], l = itemsep, l + 1;
- else
- o[l], l = itemlast, l + 1;
- end
+ o[l], l = itemsep, l + 1;
end
- if next(t) ~= nil then
+ if had_items then
+ o[l - 1] = itemlast;
o[l], l = s_rep(indentwith, d-1), l + 1;
end
o[l], l = tend, l +1;