basic: refactor error handling
Signed-off-by: Alejandro Mery <amery@jpi.io>
This commit is contained in:
+10
-12
@@ -10,24 +10,22 @@ var (
|
|||||||
errInvalidToken = errors.New("invalid token")
|
errInvalidToken = errors.New("invalid token")
|
||||||
)
|
)
|
||||||
|
|
||||||
func newErrInvalidToken(t *token) *lexer.Error {
|
func newError(pos lexer.Position, content, hint string, err error) *lexer.Error {
|
||||||
err := &lexer.Error{
|
return &lexer.Error{
|
||||||
Line: t.pos.Line,
|
|
||||||
Column: t.pos.Column,
|
|
||||||
Content: t.value,
|
|
||||||
Err: errInvalidToken,
|
|
||||||
}
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (dec *decoder) OnError(pos lexer.Position, content string, err error) error {
|
|
||||||
err = &lexer.Error{
|
|
||||||
Line: pos.Line,
|
Line: pos.Line,
|
||||||
Column: pos.Column,
|
Column: pos.Column,
|
||||||
Content: content,
|
Content: content,
|
||||||
|
Hint: hint,
|
||||||
Err: err,
|
Err: err,
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func newErrInvalidToken(t *token) *lexer.Error {
|
||||||
|
return newError(t.pos, t.value, "", errInvalidToken)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (dec *decoder) OnError(pos lexer.Position, content string, err error) error {
|
||||||
|
err = newError(pos, content, "", err)
|
||||||
dec.executeFinal()
|
dec.executeFinal()
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|||||||
+3
-1
@@ -149,6 +149,8 @@ func (dec *decoder) OnToken(pos lexer.Position, typ parser.TokenType, value stri
|
|||||||
return nil
|
return nil
|
||||||
default:
|
default:
|
||||||
// unacceptable
|
// unacceptable
|
||||||
return newErrInvalidToken(t)
|
err := newErrInvalidToken(t)
|
||||||
|
dec.executeFinal()
|
||||||
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user