aboutsummaryrefslogtreecommitdiff
path: root/mardown/ast_code.go
diff options
context:
space:
mode:
authorAnhgelus Morhtuuzh <william@herges.fr>2025-10-02 19:52:38 +0200
committerAnhgelus Morhtuuzh <william@herges.fr>2025-10-02 19:52:38 +0200
commit94dceb4f7c1740de9215b36ec183f93ca4337ee7 (patch)
tree5ad184efb0b74dd3aa4da7585f88a3e3f6cb4ecc /mardown/ast_code.go
parent8b249c9ce8bd1c351daf80c6c9b095fb1bccafe2 (diff)
style(markdown): fix typo in package name
Diffstat (limited to 'mardown/ast_code.go')
-rw-r--r--mardown/ast_code.go66
1 files changed, 0 insertions, 66 deletions
diff --git a/mardown/ast_code.go b/mardown/ast_code.go
deleted file mode 100644
index f029df2..0000000
--- a/mardown/ast_code.go
+++ /dev/null
@@ -1,66 +0,0 @@
-package mardown
-
-import (
- "errors"
- "fmt"
- "html/template"
-)
-
-var (
- ErrUnknownCodeType = errors.New("unkown code type")
- ErrInvalidCodeFormat = errors.New("invalid code format")
- ErrInvalidCodeBlockPosition = errors.Join(ErrInvalidParagraph, errors.New("invalid code block position"))
-)
-
-type codeType uint
-
-const (
- codeOneLine codeType = 1
- codeMultiLine codeType = 2
-)
-
-type astCode struct {
- content string
- before string
- codeType codeType
-}
-
-func (a *astCode) Eval() (template.HTML, *ParseError) {
- switch a.codeType {
- case codeOneLine:
- return template.HTML(fmt.Sprintf("<code>%s</code>", template.HTMLEscapeString(a.content))), nil
- case codeMultiLine:
- return template.HTML(fmt.Sprintf("<pre><code>%s</code></pre>", template.HTMLEscapeString(a.content))), nil
- default:
- return "", &ParseError{lxs: lexers{}, internal: ErrUnknownCodeType}
- }
-}
-
-func code(lxs *lexers) (*astCode, *ParseError) {
- tree := new(astCode)
- current := lxs.Current().Value
- if len(current) == 3 {
- tree.codeType = codeMultiLine
- } else if len(current) == 1 {
- tree.codeType = codeOneLine
- } else {
- return nil, &ParseError{lxs: *lxs, internal: ErrInvalidCodeFormat}
- }
- started := false
- for lxs.Next() && lxs.Current().Value != current {
- if lxs.Current().Type == lexerBreak {
- if tree.codeType == codeOneLine {
- return nil, &ParseError{lxs: *lxs, internal: ErrInvalidCodeFormat}
- }
- if !started {
- started = true
- }
- }
- if started || tree.codeType == codeOneLine {
- tree.content += lxs.Current().Value
- } else {
- tree.before += lxs.Current().Value
- }
- }
- return tree, nil
-}