forked from vektah/goparsify
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patherrors.go
32 lines (25 loc) · 1000 Bytes
/
errors.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
package goparsify
import "fmt"
// Error represents a parse error. These will often be set, the parser will back up a little and
// find another viable path. In general when combining errors the longest error should be returned.
type Error struct {
pos int
expected string
}
// Pos is the offset into the document the error was found
func (e *Error) Pos() int { return e.pos }
// Error satisfies the golang error interface
func (e *Error) Error() string { return fmt.Sprintf("offset %d: expected %s", e.pos, e.expected) }
// UnparsedInputError is returned by Run when not all of the input was consumed. There may still be a valid result
type UnparsedInputError struct {
remaining string
}
// Is tells whether the target is of type UnparsedInputError
func (e UnparsedInputError) Is(target error) bool {
_, ok := target.(UnparsedInputError)
return ok
}
// Error satisfies the golang error interface
func (e UnparsedInputError) Error() string {
return "left unparsed: " + e.remaining
}