webmcp

view framework/env/param/_get_parser.lua @ 556:c228db239964

Only treat tables without metatable as array
author jbe
date Tue Feb 18 18:15:42 2020 +0100 (2020-02-18)
parents 9fdfb27f8e67
children
line source
1 function param._get_parser(format_info, param_type)
2 if format_info == nil or format_info == "" then
3 return function(str)
4 return param_type:load(str)
5 end
6 else
7 local format_options = {}
8 local format_type, rest = string.match(
9 format_info,
10 "^([A-Za-z][A-Za-z0-9_]*)(.*)$"
11 )
12 if format_type then
13 rest = string.gsub(rest, "\\\\", "\\e")
14 rest = string.gsub(rest, "\\'", "\\q")
15 if
16 string.find(rest, "\\$") or
17 string.find(rest, "\\[^eq]")
18 then
19 format_type = nil
20 else
21 while rest ~= "" do
22 local key, value, new_rest
23 key, value, new_rest = string.match(
24 rest,
25 "^-([A-Za-z][A-Za-z0-9_]*)-'([^']*)'(.*)$"
26 )
27 if value then
28 value = string.gsub(value, "\\q", "'")
29 value = string.gsub(value, "\\e", "\\")
30 format_options[key] = value
31 else
32 key, value, new_rest = string.match(
33 rest,
34 "^-([A-Za-z][A-Za-z0-9_]*)-([^-]*)(.*)$"
35 )
36 if value then
37 if string.find(value, "^[0-9.Ee+-]+$") then
38 local num = tonumber(value)
39 if not num then
40 format_type = nil
41 break
42 end
43 format_options[key] = num
44 elseif value == "t" then
45 format_options[key] = true
46 elseif value == "f" then
47 format_options[key] = false
48 else
49 format_type = nil
50 break
51 end
52 else
53 format_type = nil
54 break
55 end
56 end
57 rest = new_rest
58 end
59 end
60 end
61 if not format_type then
62 error("Illegal format string in GET/POST parameters found.")
63 end
64 local parse_func = parse[format_type]
65 if not parse_func then
66 error("Unknown format identifier in GET/POST parameters encountered.")
67 end
68 return function(str)
69 return parse_func(str, param_type, format_options)
70 end
71 end
72 end

Impressum / About Us