From c4ba44b1c3e066f98ccc406c15a8c1de170e4709 Mon Sep 17 00:00:00 2001 From: Anhgelus Morhtuuzh Date: Tue, 30 Sep 2025 21:29:07 +0200 Subject: fix(markdown): bad condition in finished lexer and missing return value in ast --- mardown/ast.go | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) (limited to 'mardown/ast.go') diff --git a/mardown/ast.go b/mardown/ast.go index d9d2b1d..298b313 100644 --- a/mardown/ast.go +++ b/mardown/ast.go @@ -1,6 +1,7 @@ package mardown import ( + "encoding/json" "errors" "fmt" "html/template" @@ -17,7 +18,20 @@ type tree struct { } func (t *tree) Eval() (template.HTML, error) { - return "", nil + var content template.HTML + for _, c := range t.blocks { + ct, err := c.Eval() + if err != nil { + return "", err + } + content += ct + } + return content, nil +} + +func (t *tree) String() string { + b, _ := json.MarshalIndent(t, "", " ") + return string(b) } func ast(lxs *lexers) (*tree, error) { @@ -29,7 +43,9 @@ func ast(lxs *lexers) (*tree, error) { return nil, err } tr.blocks = append(tr.blocks, b) - newLine = lxs.Current().Type == lexerBreak + if !lxs.Finished() { + newLine = lxs.Current().Type == lexerBreak + } } return tr, nil } -- cgit v1.2.3