diff options
author | Kim Alvefur <zash@zash.se> | 2021-03-22 22:24:39 +0100 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2021-03-22 22:24:39 +0100 |
commit | e783d99cc2eb5703de84757e8ac7346946a77648 (patch) | |
tree | 447247ec286faaaa77ac51f4fd2b08ef06143163 /util | |
parent | f2f1714e47fb441f70fd77319765221c5e06c800 (diff) | |
download | prosody-e783d99cc2eb5703de84757e8ac7346946a77648.tar.gz prosody-e783d99cc2eb5703de84757e8ac7346946a77648.zip |
util.datamapper: Factor out conversion from any value to XML string
Since this was the last severely duplicated code left.
Diffstat (limited to 'util')
-rw-r--r-- | util/datamapper.lua | 46 |
1 files changed, 17 insertions, 29 deletions
diff --git a/util/datamapper.lua b/util/datamapper.lua index 96b4a42e..3377413f 100644 --- a/util/datamapper.lua +++ b/util/datamapper.lua @@ -199,6 +199,18 @@ local function parse(schema, s) end end +local function toxmlstring(proptype, v) + if proptype == "string" and type(v) == "string" then + return v + elseif proptype == "number" and type(v) == "number" then + return string.format("%g", v) + elseif proptype == "integer" and type(v) == "number" then + return string.format("%d", v) + elseif proptype == "boolean" then + return v and "1" or "0" + end +end + local unparse local function unparse_property(out, v, proptype, propschema, value_where, name, namespace, current_ns, prefix, single_attribute) @@ -210,19 +222,9 @@ local function unparse_property(out, v, proptype, propschema, value_where, name, attr = namespace .. "\1" .. name end - if proptype == "string" and type(v) == "string" then - out.attr[attr] = v - elseif proptype == "number" and type(v) == "number" then - out.attr[attr] = string.format("%g", v) - elseif proptype == "integer" and type(v) == "number" then - out.attr[attr] = string.format("%d", v) - elseif proptype == "boolean" then - out.attr[attr] = v and "1" or "0" - end + out.attr[attr] = toxmlstring(proptype, v) elseif value_where == "in_text" then - if type(v) == "string" then - out:text(v) - end + out:text(toxmlstring(proptype, v)) elseif value_where == "in_single_attribute" then assert(single_attribute) local propattr = {} @@ -231,15 +233,7 @@ local function unparse_property(out, v, proptype, propschema, value_where, name, propattr.xmlns = namespace end - if proptype == "string" and type(v) == "string" then - propattr[single_attribute] = v - elseif proptype == "number" and type(v) == "number" then - propattr[single_attribute] = string.format("%g", v) - elseif proptype == "integer" and type(v) == "number" then - propattr[single_attribute] = string.format("%d", v) - elseif proptype == "boolean" and type(v) == "boolean" then - propattr[single_attribute] = v and "1" or "0" - end + propattr[single_attribute] = toxmlstring(proptype, v) out:tag(name, propattr):up(); else @@ -253,14 +247,6 @@ local function unparse_property(out, v, proptype, propschema, value_where, name, elseif proptype == "boolean" and v == true then out:tag(name, propattr):up(); end - elseif proptype == "string" and type(v) == "string" then - out:text_tag(name, v, propattr) - elseif proptype == "number" and type(v) == "number" then - out:text_tag(name, string.format("%g", v), propattr) - elseif proptype == "integer" and type(v) == "number" then - out:text_tag(name, string.format("%d", v), propattr) - elseif proptype == "boolean" and type(v) == "boolean" then - out:text_tag(name, v and "1" or "0", propattr) elseif proptype == "object" and type(propschema) == "table" and type(v) == "table" then local c = unparse(propschema, v, name, namespace); if c then @@ -275,6 +261,8 @@ local function unparse_property(out, v, proptype, propschema, value_where, name, else unparse(propschema, v, name, namespace, out); end + else + out:text_tag(name, toxmlstring(proptype, v), propattr) end end end |