mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
json: fix [raw] for option string (#17899)
This commit is contained in:
parent
a773e44430
commit
1113205376
38
vlib/json/json_raw_test.v
Normal file
38
vlib/json/json_raw_test.v
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import json
|
||||||
|
|
||||||
|
struct TestOptionalRawString {
|
||||||
|
id int
|
||||||
|
data ?string [raw]
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_raw_opt() {
|
||||||
|
test := TestOptionalRawString{
|
||||||
|
id: 1
|
||||||
|
data: 't
|
||||||
|
e
|
||||||
|
s
|
||||||
|
t'
|
||||||
|
}
|
||||||
|
encoded := json.encode(test)
|
||||||
|
assert json.decode(TestOptionalRawString, encoded)!.data? == r'"t\ne\ns\nt"'
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_raw_none() {
|
||||||
|
test := TestOptionalRawString{
|
||||||
|
id: 1
|
||||||
|
data: none
|
||||||
|
}
|
||||||
|
encoded := json.encode(test)
|
||||||
|
r := json.decode(TestOptionalRawString, encoded)!.data
|
||||||
|
assert r == none
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_raw_empty_string() {
|
||||||
|
test := TestOptionalRawString{
|
||||||
|
id: 1
|
||||||
|
data: ''
|
||||||
|
}
|
||||||
|
encoded := json.encode(test)
|
||||||
|
r := json.decode(TestOptionalRawString, encoded)!.data or { 'z' }
|
||||||
|
assert r == '""'
|
||||||
|
}
|
@ -534,8 +534,17 @@ fn (mut g Gen) gen_struct_enc_dec(utyp ast.Type, type_info ast.TypeInfo, styp st
|
|||||||
prefix := if utyp.has_flag(.option) { '(*(${g.base_type(utyp)}*)res.data)' } else { 'res' }
|
prefix := if utyp.has_flag(.option) { '(*(${g.base_type(utyp)}*)res.data)' } else { 'res' }
|
||||||
// First generate decoding
|
// First generate decoding
|
||||||
if is_raw {
|
if is_raw {
|
||||||
|
if field.typ.has_flag(.option) {
|
||||||
|
g.gen_json_for_type(field.typ)
|
||||||
|
base_typ := g.base_type(field.typ)
|
||||||
|
dec.writeln('\tif (!cJSON_IsString(js_get(root, "${name}")))')
|
||||||
|
dec.writeln('\t\t_option_none(&(${base_typ}[]) { {0} }, &${prefix}${op}${c_name(field.name)}, sizeof(${base_typ}));')
|
||||||
|
dec.writeln('\telse')
|
||||||
|
dec.writeln('\t\t_option_ok(&(${base_typ}[]) { tos5(cJSON_PrintUnformatted(js_get(root, "${name}"))) }, &${prefix}${op}${c_name(field.name)}, sizeof(${base_typ}));')
|
||||||
|
} else {
|
||||||
dec.writeln('\tres${op}${c_name(field.name)} = tos5(cJSON_PrintUnformatted(' +
|
dec.writeln('\tres${op}${c_name(field.name)} = tos5(cJSON_PrintUnformatted(' +
|
||||||
'js_get(root, "${name}")));')
|
'js_get(root, "${name}")));')
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// Now generate decoders for all field types in this struct
|
// Now generate decoders for all field types in this struct
|
||||||
// need to do it here so that these functions are generated first
|
// need to do it here so that these functions are generated first
|
||||||
|
Loading…
Reference in New Issue
Block a user