blob: 819d73a04990ac1f52c62a0d1b667297ba6289d5 (
plain)
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
package mardown
import (
"errors"
"fmt"
)
var ErrUnkownLexType = errors.New("unkown lex type")
type block interface {
Eval() error
}
type tree struct {
blocks []block
}
func (t *tree) Eval() error {
return nil
}
func ast(lxs lexers) (*tree, error) {
tr := new(tree)
for lxs.Next() {
b, err := getBlock(lxs)
if err != nil {
return nil, err
}
tr.blocks = append(tr.blocks, b)
}
return tr, nil
}
func getBlock(lxs lexers) (block, error) {
var b block
var err error
switch lxs.Current().Type {
case lexerHeader:
b, err = header(lxs)
case lexerExternal:
case lexerModifier:
case lexerCode:
case lexerEscape:
case lexerQuote:
case lexerLiteral, lexerBreak:
b = astLiteral(lxs.Current().Value)
default:
err = errors.Join(ErrUnkownLexType, fmt.Errorf("type received: %s", lxs.Current().Type))
}
return b, err
}
|