-
Notifications
You must be signed in to change notification settings - Fork 0
/
node.go
34 lines (25 loc) · 925 Bytes
/
node.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
33
34
package parse
import "github.com/markusbkk/elvish/pkg/diag"
// Node represents a parse tree as well as an AST.
type Node interface {
diag.Ranger
parse(*parser)
n() *node
}
type node struct {
diag.Ranging
sourceText string
parent Node
children []Node
}
func (n *node) n() *node { return n }
func (n *node) addChild(ch Node) { n.children = append(n.children, ch) }
// Range returns the range within the full source text that parses to the node.
func (n *node) Range() diag.Ranging { return n.Ranging }
// Parent returns the parent of a node. It returns nil if the node is the root
// of the parse tree.
func Parent(n Node) Node { return n.n().parent }
// SourceText returns the part of the source text that parses to the node.
func SourceText(n Node) string { return n.n().sourceText }
// Children returns all children of the node in the parse tree.
func Children(n Node) []Node { return n.n().children }