x.json2: add custom errors (#9523)
parent
70b189d751
commit
28018c6fc9
|
@ -22,6 +22,16 @@ mut:
|
||||||
convert_type bool = true
|
convert_type bool = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct InvalidTokenError {
|
||||||
|
msg string
|
||||||
|
code int
|
||||||
|
}
|
||||||
|
|
||||||
|
struct UnknownTokenError {
|
||||||
|
msg string
|
||||||
|
code int
|
||||||
|
}
|
||||||
|
|
||||||
fn (mut p Parser) next() {
|
fn (mut p Parser) next() {
|
||||||
p.p_tok = p.tok
|
p.p_tok = p.tok
|
||||||
p.tok = p.n_tok
|
p.tok = p.n_tok
|
||||||
|
@ -74,7 +84,9 @@ fn (mut p Parser) decode() ?Any {
|
||||||
p.next_with_err() ?
|
p.next_with_err() ?
|
||||||
fi := p.decode_value() ?
|
fi := p.decode_value() ?
|
||||||
if p.tok.kind != .eof {
|
if p.tok.kind != .eof {
|
||||||
return error(p.emit_error('invalid token `$p.tok.kind`'))
|
return IError(&InvalidTokenError{
|
||||||
|
msg: p.emit_error('invalid token `$p.tok.kind`')
|
||||||
|
})
|
||||||
}
|
}
|
||||||
return fi
|
return fi
|
||||||
}
|
}
|
||||||
|
@ -127,7 +139,9 @@ fn (mut p Parser) decode_value() ?Any {
|
||||||
return Any(str)
|
return Any(str)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return error(p.emit_error('invalid token `$p.tok.kind`'))
|
return IError(&InvalidTokenError{
|
||||||
|
msg: p.emit_error('invalid token `$p.tok.kind`')
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return Any{}
|
return Any{}
|
||||||
|
@ -142,12 +156,16 @@ fn (mut p Parser) decode_array() ?Any {
|
||||||
if p.tok.kind == .comma {
|
if p.tok.kind == .comma {
|
||||||
p.next_with_err() ?
|
p.next_with_err() ?
|
||||||
if p.tok.kind == .rsbr || p.tok.kind == .rcbr {
|
if p.tok.kind == .rsbr || p.tok.kind == .rcbr {
|
||||||
return error(p.emit_error('invalid token `$p.tok.lit'))
|
return IError(&InvalidTokenError{
|
||||||
|
msg: p.emit_error('invalid token `$p.tok.lit')
|
||||||
|
})
|
||||||
}
|
}
|
||||||
} else if p.tok.kind == .rsbr {
|
} else if p.tok.kind == .rsbr {
|
||||||
break
|
break
|
||||||
} else {
|
} else {
|
||||||
return error(p.emit_error("unknown token '$p.tok.lit' when decoding array."))
|
return IError(&UnknownTokenError{
|
||||||
|
msg: p.emit_error("unknown token '$p.tok.lit' when decoding array.")
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
p.next_with_err() ?
|
p.next_with_err() ?
|
||||||
|
@ -160,7 +178,9 @@ fn (mut p Parser) decode_object() ?Any {
|
||||||
for p.tok.kind != .rcbr {
|
for p.tok.kind != .rcbr {
|
||||||
is_key := p.tok.kind == .str_ && p.n_tok.kind == .colon
|
is_key := p.tok.kind == .str_ && p.n_tok.kind == .colon
|
||||||
if !is_key {
|
if !is_key {
|
||||||
return error(p.emit_error('invalid token `$p.tok.kind`, expecting `str_`'))
|
return IError(&InvalidTokenError{
|
||||||
|
msg: p.emit_error('invalid token `$p.tok.kind`, expecting `str_`')
|
||||||
|
})
|
||||||
}
|
}
|
||||||
cur_key := p.tok.lit.bytestr()
|
cur_key := p.tok.lit.bytestr()
|
||||||
p.next_with_err() ?
|
p.next_with_err() ?
|
||||||
|
@ -169,7 +189,9 @@ fn (mut p Parser) decode_object() ?Any {
|
||||||
if p.tok.kind == .comma {
|
if p.tok.kind == .comma {
|
||||||
p.next_with_err() ?
|
p.next_with_err() ?
|
||||||
if p.tok.kind != .str_ {
|
if p.tok.kind != .str_ {
|
||||||
return error(p.emit_error("unknown token '$p.tok.lit' when decoding object."))
|
return IError(&UnknownTokenError{
|
||||||
|
msg: p.emit_error("unknown token '$p.tok.lit' when decoding object.")
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue