blob: acd2ea85b5d44b690d104cd8d4e4af11efbe7be4 [file] [log] [blame]
Bram Moolenaar520e1e42016-01-23 19:46:28 +01001" Test for JSON functions.
Bram Moolenaarc5215e92016-02-28 16:29:50 +01002
Bram Moolenaarac105ed2016-07-21 20:33:32 +02003" JSON requires using utf-8, because conversion breaks the asserts.
Bram Moolenaarc5215e92016-02-28 16:29:50 +01004if !has('multi_byte')
5 finish
6endif
Bram Moolenaar520e1e42016-01-23 19:46:28 +01007
8let s:json1 = '"str\"in\\g"'
9let s:var1 = "str\"in\\g"
10let s:json2 = '"\u0001\u0002\u0003\u0004\u0005\u0006\u0007"'
11let s:var2 = "\x01\x02\x03\x04\x05\x06\x07"
12let s:json3 = '"\b\t\n\u000b\f\r\u000e\u000f"'
13let s:var3 = "\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f"
14let s:json4 = '"\u0010\u0011\u0012\u0013\u0014\u0015\u0016\u0017"'
15let s:var4 = "\x10\x11\x12\x13\x14\x15\x16\x17"
16let s:json5 = '"\u0018\u0019\u001a\u001b\u001c\u001d\u001e\u001f"'
17let s:var5 = "\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f"
18
Bram Moolenaarb6ff8112016-02-27 18:41:27 +010019" surrogate pair
20let s:jsonsp1 = '"\ud83c\udf63"'
21let s:varsp1 = "\xf0\x9f\x8d\xa3"
22let s:jsonsp2 = '"\ud83c\u00a0"'
23let s:varsp2 = "\ud83c\u00a0"
24
Bram Moolenaar520e1e42016-01-23 19:46:28 +010025let s:jsonmb = '"s¢cĴgё"'
26let s:varmb = "s¢cĴgё"
27let s:jsonnr = '1234'
28let s:varnr = 1234
Bram Moolenaarf1b6ac72016-02-23 21:26:43 +010029if has('float')
30 let s:jsonfl = '12.34'
31 let s:varfl = 12.34
Bram Moolenaar7ce686c2016-02-27 16:33:22 +010032 let s:jsoninf = 'Infinity'
Bram Moolenaarf1b6ac72016-02-23 21:26:43 +010033 let s:varinf = 1.0 / 0.0
Bram Moolenaar7ce686c2016-02-27 16:33:22 +010034 let s:jsonnan = 'NaN'
Bram Moolenaarf1b6ac72016-02-23 21:26:43 +010035 let s:varnan = 0.0 / 0.0
36endif
Bram Moolenaar520e1e42016-01-23 19:46:28 +010037
38let s:jsonl1 = '[1,"a",3]'
39let s:varl1 = [1, "a", 3]
40let s:jsonl2 = '[1,["a",[],"c"],3]'
41let s:jsonl2s = " [\r1 , [ \"a\" , [ ] , \"c\" ] , 3\<Tab>]\r\n"
42let s:varl2 = [1, 2, 3]
43let l2 = ['a', s:varl2, 'c']
44let s:varl2[1] = l2
45let s:varl2x = [1, ["a", [], "c"], 3]
Bram Moolenaarfcaaae62016-01-24 16:49:11 +010046let s:jsonl3 = '[[1,2],[1,2]]'
47let l3 = [1, 2]
48let s:varl3 = [l3, l3]
Bram Moolenaar520e1e42016-01-23 19:46:28 +010049
50let s:jsond1 = '{"a":1,"b":"bee","c":[1,2]}'
Bram Moolenaar595e64e2016-02-07 19:19:53 +010051let s:jsd1 = '{a:1,b:"bee",c:[1,2]}'
Bram Moolenaar520e1e42016-01-23 19:46:28 +010052let s:vard1 = {"a": 1, "b": "bee","c": [1,2]}
53let s:jsond2 = '{"1":1,"2":{"a":"aa","b":{},"c":"cc"},"3":3}'
Bram Moolenaar595e64e2016-02-07 19:19:53 +010054let s:jsd2 = '{"1":1,"2":{a:"aa",b:{},c:"cc"},"3":3}'
Bram Moolenaar520e1e42016-01-23 19:46:28 +010055let s:jsond2s = " { \"1\" : 1 , \"2\" :\n{ \"a\"\r: \"aa\" , \"b\" : {\<Tab>} , \"c\" : \"cc\" } , \"3\" : 3 }\r\n"
Bram Moolenaar595e64e2016-02-07 19:19:53 +010056let s:jsd2s = " { \"1\" : 1 , \"2\" :\n{ a\r: \"aa\" , b : {\<Tab>} , c : \"cc\" } , \"3\" : 3 }\r\n"
Bram Moolenaar520e1e42016-01-23 19:46:28 +010057let s:vard2 = {"1": 1, "2": 2, "3": 3}
58let d2 = {"a": "aa", "b": s:vard2, "c": "cc"}
59let s:vard2["2"] = d2
60let s:vard2x = {"1": 1, "2": {"a": "aa", "b": {}, "c": "cc"}, "3": 3}
Bram Moolenaarfcaaae62016-01-24 16:49:11 +010061let d3 = {"a": 1, "b": 2}
62let s:vard3 = {"x": d3, "y": d3}
63let s:jsond3 = '{"x":{"a":1,"b":2},"y":{"a":1,"b":2}}'
Bram Moolenaar595e64e2016-02-07 19:19:53 +010064let s:jsd3 = '{x:{a:1,b:2},y:{a:1,b:2}}'
65let s:vard4 = {"key": v:none}
66let s:vard4x = {"key": v:null}
67let s:jsond4 = '{"key":null}'
68let s:jsd4 = '{key:null}'
Bram Moolenaar520e1e42016-01-23 19:46:28 +010069
Bram Moolenaar595e64e2016-02-07 19:19:53 +010070let s:jsonvals = '[true,false,null,null]'
71let s:varvals = [v:true, v:false, v:null, v:null]
Bram Moolenaar520e1e42016-01-23 19:46:28 +010072
Bram Moolenaar595e64e2016-02-07 19:19:53 +010073func Test_json_encode()
Bram Moolenaar7823a3b2016-02-11 21:08:32 +010074 call assert_equal(s:json1, json_encode(s:var1))
75 call assert_equal(s:json2, json_encode(s:var2))
76 call assert_equal(s:json3, json_encode(s:var3))
77 call assert_equal(s:json4, json_encode(s:var4))
78 call assert_equal(s:json5, json_encode(s:var5))
Bram Moolenaar520e1e42016-01-23 19:46:28 +010079
80 if has('multi_byte')
Bram Moolenaar7823a3b2016-02-11 21:08:32 +010081 call assert_equal(s:jsonmb, json_encode(s:varmb))
Bram Moolenaarfc2457e2016-02-28 20:04:09 +010082 " no test for surrogate pair, json_encode() doesn't create them.
Bram Moolenaar520e1e42016-01-23 19:46:28 +010083 endif
84
Bram Moolenaar7823a3b2016-02-11 21:08:32 +010085 call assert_equal(s:jsonnr, json_encode(s:varnr))
Bram Moolenaar520e1e42016-01-23 19:46:28 +010086 if has('float')
Bram Moolenaar7823a3b2016-02-11 21:08:32 +010087 call assert_equal(s:jsonfl, json_encode(s:varfl))
Bram Moolenaarf1b6ac72016-02-23 21:26:43 +010088 call assert_equal(s:jsoninf, json_encode(s:varinf))
89 call assert_equal(s:jsonnan, json_encode(s:varnan))
Bram Moolenaar520e1e42016-01-23 19:46:28 +010090 endif
91
Bram Moolenaar7823a3b2016-02-11 21:08:32 +010092 call assert_equal(s:jsonl1, json_encode(s:varl1))
93 call assert_equal(s:jsonl2, json_encode(s:varl2))
94 call assert_equal(s:jsonl3, json_encode(s:varl3))
Bram Moolenaar520e1e42016-01-23 19:46:28 +010095
Bram Moolenaar7823a3b2016-02-11 21:08:32 +010096 call assert_equal(s:jsond1, json_encode(s:vard1))
97 call assert_equal(s:jsond2, json_encode(s:vard2))
98 call assert_equal(s:jsond3, json_encode(s:vard3))
99 call assert_equal(s:jsond4, json_encode(s:vard4))
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100100
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100101 call assert_equal(s:jsonvals, json_encode(s:varvals))
Bram Moolenaarfcaaae62016-01-24 16:49:11 +0100102
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100103 call assert_fails('echo json_encode(function("tr"))', 'E474:')
104 call assert_fails('echo json_encode([function("tr")])', 'E474:')
Bram Moolenaar55fab432016-02-07 16:53:13 +0100105
Bram Moolenaarb29d3282017-12-15 21:25:01 +0100106 call assert_equal('{"a":""}', json_encode({'a': test_null_string()}))
107 call assert_equal('{"a":[]}', json_encode({"a": test_null_list()}))
108 call assert_equal('{"a":{}}', json_encode({"a": test_null_dict()}))
109
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100110 silent! let res = json_encode(function("tr"))
Bram Moolenaar55fab432016-02-07 16:53:13 +0100111 call assert_equal("", res)
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100112endfunc
113
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100114func Test_json_decode()
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100115 call assert_equal(s:var1, json_decode(s:json1))
116 call assert_equal(s:var2, json_decode(s:json2))
117 call assert_equal(s:var3, json_decode(s:json3))
118 call assert_equal(s:var4, json_decode(s:json4))
119 call assert_equal(s:var5, json_decode(s:json5))
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100120
121 if has('multi_byte')
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100122 call assert_equal(s:varmb, json_decode(s:jsonmb))
Bram Moolenaarfc2457e2016-02-28 20:04:09 +0100123 call assert_equal(s:varsp1, json_decode(s:jsonsp1))
124 call assert_equal(s:varsp2, json_decode(s:jsonsp2))
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100125 endif
126
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100127 call assert_equal(s:varnr, json_decode(s:jsonnr))
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100128 if has('float')
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100129 call assert_equal(s:varfl, json_decode(s:jsonfl))
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100130 endif
131
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100132 call assert_equal(s:varl1, json_decode(s:jsonl1))
133 call assert_equal(s:varl2x, json_decode(s:jsonl2))
134 call assert_equal(s:varl2x, json_decode(s:jsonl2s))
135 call assert_equal(s:varl3, json_decode(s:jsonl3))
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100136
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100137 call assert_equal(s:vard1, json_decode(s:jsond1))
138 call assert_equal(s:vard2x, json_decode(s:jsond2))
139 call assert_equal(s:vard2x, json_decode(s:jsond2s))
140 call assert_equal(s:vard3, json_decode(s:jsond3))
141 call assert_equal(s:vard4x, json_decode(s:jsond4))
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100142
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100143 call assert_equal(s:varvals, json_decode(s:jsonvals))
Bram Moolenaarf95534c2016-01-23 21:59:52 +0100144
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100145 call assert_equal(v:true, json_decode('true'))
146 call assert_equal(type(v:true), type(json_decode('true')))
147 call assert_equal(v:none, json_decode(''))
148 call assert_equal(type(v:none), type(json_decode('')))
149 call assert_equal("", json_decode('""'))
Bram Moolenaarf95534c2016-01-23 21:59:52 +0100150
Bram Moolenaar059b7482017-02-05 16:34:43 +0100151 " empty key is OK
152 call assert_equal({'': 'ok'}, json_decode('{"": "ok"}'))
153 " but not twice
154 call assert_fails("call json_decode('{\"\": \"ok\", \"\": \"bad\"}')", 'E938:')
155
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100156 call assert_equal({'n': 1}, json_decode('{"n":1,}'))
Bram Moolenaaree142ad2017-01-11 21:50:08 +0100157 call assert_fails("call json_decode(\"{'n':'1',}\")", 'E474:')
158 call assert_fails("call json_decode(\"'n'\")", 'E474:')
Bram Moolenaar6039c7f2016-01-24 15:05:32 +0100159
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100160 call assert_fails('call json_decode("\"")', "E474:")
161 call assert_fails('call json_decode("blah")', "E474:")
Bram Moolenaar03c60c12017-01-10 15:15:37 +0100162 call assert_fails('call json_decode("true blah")', "E488:")
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100163 call assert_fails('call json_decode("<foobar>")', "E474:")
Bram Moolenaar83381f72017-01-14 14:36:08 +0100164 call assert_fails('call json_decode("{\"a\":1,\"a\":2}")', "E938:")
Bram Moolenaar6039c7f2016-01-24 15:05:32 +0100165
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100166 call assert_fails('call json_decode("{")', "E474:")
167 call assert_fails('call json_decode("{foobar}")', "E474:")
168 call assert_fails('call json_decode("{\"n\",")', "E474:")
169 call assert_fails('call json_decode("{\"n\":")', "E474:")
170 call assert_fails('call json_decode("{\"n\":1")', "E474:")
171 call assert_fails('call json_decode("{\"n\":1,")', "E474:")
172 call assert_fails('call json_decode("{\"n\",1}")', "E474:")
173 call assert_fails('call json_decode("{-}")', "E474:")
Bram Moolenaar6039c7f2016-01-24 15:05:32 +0100174
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100175 call assert_fails('call json_decode("[foobar]")', "E474:")
176 call assert_fails('call json_decode("[")', "E474:")
177 call assert_fails('call json_decode("[1")', "E474:")
178 call assert_fails('call json_decode("[1,")', "E474:")
179 call assert_fails('call json_decode("[1 2]")', "E474:")
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100180
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100181 call assert_fails('call json_decode("[1,,2]")', "E474:")
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100182endfunc
183
184let s:jsl5 = '[7,,,]'
185let s:varl5 = [7, v:none, v:none]
186
187func Test_js_encode()
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100188 call assert_equal(s:json1, js_encode(s:var1))
189 call assert_equal(s:json2, js_encode(s:var2))
190 call assert_equal(s:json3, js_encode(s:var3))
191 call assert_equal(s:json4, js_encode(s:var4))
192 call assert_equal(s:json5, js_encode(s:var5))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100193
194 if has('multi_byte')
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100195 call assert_equal(s:jsonmb, js_encode(s:varmb))
Bram Moolenaarfc2457e2016-02-28 20:04:09 +0100196 " no test for surrogate pair, js_encode() doesn't create them.
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100197 endif
198
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100199 call assert_equal(s:jsonnr, js_encode(s:varnr))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100200 if has('float')
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100201 call assert_equal(s:jsonfl, js_encode(s:varfl))
Bram Moolenaar7ce686c2016-02-27 16:33:22 +0100202 call assert_equal(s:jsoninf, js_encode(s:varinf))
203 call assert_equal(s:jsonnan, js_encode(s:varnan))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100204 endif
205
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100206 call assert_equal(s:jsonl1, js_encode(s:varl1))
207 call assert_equal(s:jsonl2, js_encode(s:varl2))
208 call assert_equal(s:jsonl3, js_encode(s:varl3))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100209
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100210 call assert_equal(s:jsd1, js_encode(s:vard1))
211 call assert_equal(s:jsd2, js_encode(s:vard2))
212 call assert_equal(s:jsd3, js_encode(s:vard3))
213 call assert_equal(s:jsd4, js_encode(s:vard4))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100214
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100215 call assert_equal(s:jsonvals, js_encode(s:varvals))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100216
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100217 call assert_fails('echo js_encode(function("tr"))', 'E474:')
218 call assert_fails('echo js_encode([function("tr")])', 'E474:')
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100219
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100220 silent! let res = js_encode(function("tr"))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100221 call assert_equal("", res)
222
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100223 call assert_equal(s:jsl5, js_encode(s:varl5))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100224endfunc
225
226func Test_js_decode()
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100227 call assert_equal(s:var1, js_decode(s:json1))
228 call assert_equal(s:var2, js_decode(s:json2))
229 call assert_equal(s:var3, js_decode(s:json3))
230 call assert_equal(s:var4, js_decode(s:json4))
231 call assert_equal(s:var5, js_decode(s:json5))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100232
233 if has('multi_byte')
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100234 call assert_equal(s:varmb, js_decode(s:jsonmb))
Bram Moolenaarfc2457e2016-02-28 20:04:09 +0100235 call assert_equal(s:varsp1, js_decode(s:jsonsp1))
236 call assert_equal(s:varsp2, js_decode(s:jsonsp2))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100237 endif
238
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100239 call assert_equal(s:varnr, js_decode(s:jsonnr))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100240 if has('float')
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100241 call assert_equal(s:varfl, js_decode(s:jsonfl))
Bram Moolenaar7ce686c2016-02-27 16:33:22 +0100242 call assert_equal(s:varinf, js_decode(s:jsoninf))
243 call assert_true(isnan(js_decode(s:jsonnan)))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100244 endif
245
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100246 call assert_equal(s:varl1, js_decode(s:jsonl1))
247 call assert_equal(s:varl2x, js_decode(s:jsonl2))
248 call assert_equal(s:varl2x, js_decode(s:jsonl2s))
249 call assert_equal(s:varl3, js_decode(s:jsonl3))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100250
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100251 call assert_equal(s:vard1, js_decode(s:jsond1))
252 call assert_equal(s:vard1, js_decode(s:jsd1))
253 call assert_equal(s:vard2x, js_decode(s:jsond2))
254 call assert_equal(s:vard2x, js_decode(s:jsd2))
255 call assert_equal(s:vard2x, js_decode(s:jsond2s))
256 call assert_equal(s:vard2x, js_decode(s:jsd2s))
257 call assert_equal(s:vard3, js_decode(s:jsond3))
258 call assert_equal(s:vard3, js_decode(s:jsd3))
259 call assert_equal(s:vard4x, js_decode(s:jsond4))
260 call assert_equal(s:vard4x, js_decode(s:jsd4))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100261
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100262 call assert_equal(s:varvals, js_decode(s:jsonvals))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100263
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100264 call assert_equal(v:true, js_decode('true'))
265 call assert_equal(type(v:true), type(js_decode('true')))
266 call assert_equal(v:none, js_decode(''))
267 call assert_equal(type(v:none), type(js_decode('')))
268 call assert_equal("", js_decode('""'))
Bram Moolenaaree142ad2017-01-11 21:50:08 +0100269 call assert_equal("", js_decode("''"))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100270
Bram Moolenaaree142ad2017-01-11 21:50:08 +0100271 call assert_equal('n', js_decode("'n'"))
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100272 call assert_equal({'n': 1}, js_decode('{"n":1,}'))
Bram Moolenaaree142ad2017-01-11 21:50:08 +0100273 call assert_equal({'n': '1'}, js_decode("{'n':'1',}"))
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100274
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100275 call assert_fails('call js_decode("\"")', "E474:")
276 call assert_fails('call js_decode("blah")', "E474:")
277 call assert_fails('call js_decode("true blah")', "E474:")
278 call assert_fails('call js_decode("<foobar>")', "E474:")
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100279
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100280 call assert_fails('call js_decode("{")', "E474:")
281 call assert_fails('call js_decode("{foobar}")', "E474:")
282 call assert_fails('call js_decode("{\"n\",")', "E474:")
283 call assert_fails('call js_decode("{\"n\":")', "E474:")
284 call assert_fails('call js_decode("{\"n\":1")', "E474:")
285 call assert_fails('call js_decode("{\"n\":1,")', "E474:")
286 call assert_fails('call js_decode("{\"n\",1}")', "E474:")
287 call assert_fails('call js_decode("{-}")', "E474:")
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100288
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100289 call assert_fails('call js_decode("[foobar]")', "E474:")
290 call assert_fails('call js_decode("[")', "E474:")
291 call assert_fails('call js_decode("[1")', "E474:")
292 call assert_fails('call js_decode("[1,")', "E474:")
293 call assert_fails('call js_decode("[1 2]")', "E474:")
Bram Moolenaar595e64e2016-02-07 19:19:53 +0100294
Bram Moolenaar7823a3b2016-02-11 21:08:32 +0100295 call assert_equal(s:varl5, js_decode(s:jsl5))
Bram Moolenaar520e1e42016-01-23 19:46:28 +0100296endfunc