mirror of
https://gitea.com/gitea/tea.git
synced 2024-12-19 07:35:06 +01:00
89e93d90b3
Merge branch 'master' into use-glamour select Glamour Theme based on BackgroundColor Merge branch 'master' into use-glamour Merge branch 'master' into use-glamour update termev update go.mod label color colorate use glamour for issue content Vendor: Add glamour Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: 6543 <6543@obermui.de> Reviewed-on: https://gitea.com/gitea/tea/pulls/181 Reviewed-by: techknowlogick <techknowlogick@gitea.io> Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com>
80 lines
1.9 KiB
Go
80 lines
1.9 KiB
Go
package parser
|
|
|
|
import (
|
|
"github.com/yuin/goldmark/ast"
|
|
"github.com/yuin/goldmark/text"
|
|
"github.com/yuin/goldmark/util"
|
|
)
|
|
|
|
type codeBlockParser struct {
|
|
}
|
|
|
|
// CodeBlockParser is a BlockParser implementation that parses indented code blocks.
|
|
var defaultCodeBlockParser = &codeBlockParser{}
|
|
|
|
// NewCodeBlockParser returns a new BlockParser that
|
|
// parses code blocks.
|
|
func NewCodeBlockParser() BlockParser {
|
|
return defaultCodeBlockParser
|
|
}
|
|
|
|
func (b *codeBlockParser) Trigger() []byte {
|
|
return nil
|
|
}
|
|
|
|
func (b *codeBlockParser) Open(parent ast.Node, reader text.Reader, pc Context) (ast.Node, State) {
|
|
line, segment := reader.PeekLine()
|
|
pos, padding := util.IndentPosition(line, reader.LineOffset(), 4)
|
|
if pos < 0 || util.IsBlank(line) {
|
|
return nil, NoChildren
|
|
}
|
|
node := ast.NewCodeBlock()
|
|
reader.AdvanceAndSetPadding(pos, padding)
|
|
_, segment = reader.PeekLine()
|
|
node.Lines().Append(segment)
|
|
reader.Advance(segment.Len() - 1)
|
|
return node, NoChildren
|
|
|
|
}
|
|
|
|
func (b *codeBlockParser) Continue(node ast.Node, reader text.Reader, pc Context) State {
|
|
line, segment := reader.PeekLine()
|
|
if util.IsBlank(line) {
|
|
node.Lines().Append(segment.TrimLeftSpaceWidth(4, reader.Source()))
|
|
return Continue | NoChildren
|
|
}
|
|
pos, padding := util.IndentPosition(line, reader.LineOffset(), 4)
|
|
if pos < 0 {
|
|
return Close
|
|
}
|
|
reader.AdvanceAndSetPadding(pos, padding)
|
|
_, segment = reader.PeekLine()
|
|
node.Lines().Append(segment)
|
|
reader.Advance(segment.Len() - 1)
|
|
return Continue | NoChildren
|
|
}
|
|
|
|
func (b *codeBlockParser) Close(node ast.Node, reader text.Reader, pc Context) {
|
|
// trim trailing blank lines
|
|
lines := node.Lines()
|
|
length := lines.Len() - 1
|
|
source := reader.Source()
|
|
for length >= 0 {
|
|
line := lines.At(length)
|
|
if util.IsBlank(line.Value(source)) {
|
|
length--
|
|
} else {
|
|
break
|
|
}
|
|
}
|
|
lines.SetSliced(0, length+1)
|
|
}
|
|
|
|
func (b *codeBlockParser) CanInterruptParagraph() bool {
|
|
return false
|
|
}
|
|
|
|
func (b *codeBlockParser) CanAcceptIndentedLine() bool {
|
|
return true
|
|
}
|