aboutsummaryrefslogtreecommitdiffstats
path: root/modules/markup/markdown/math/block_parser.go
diff options
context:
space:
mode:
authorwxiaoguang <wxiaoguang@gmail.com>2024-12-14 13:43:05 +0800
committerGitHub <noreply@github.com>2024-12-14 13:43:05 +0800
commitcc5ff98e0d510c1923ad7cabc3e339f9cf0b570f (patch)
tree36e6c850a686beda2ae7cca8ed38d6234fbc6968 /modules/markup/markdown/math/block_parser.go
parent82c59d52ea650ce42bbca2c6740d9449d06e77be (diff)
downloadgitea-cc5ff98e0d510c1923ad7cabc3e339f9cf0b570f.tar.gz
gitea-cc5ff98e0d510c1923ad7cabc3e339f9cf0b570f.zip
Refactor markdown math render (#32831)
Add more tests
Diffstat (limited to 'modules/markup/markdown/math/block_parser.go')
-rw-r--r--modules/markup/markdown/math/block_parser.go25
1 files changed, 17 insertions, 8 deletions
diff --git a/modules/markup/markdown/math/block_parser.go b/modules/markup/markdown/math/block_parser.go
index 3f37ce8333..2c5553550a 100644
--- a/modules/markup/markdown/math/block_parser.go
+++ b/modules/markup/markdown/math/block_parser.go
@@ -16,16 +16,18 @@ import (
type blockParser struct {
parseDollars bool
+ parseSquare bool
endBytesDollars []byte
- endBytesBracket []byte
+ endBytesSquare []byte
}
// NewBlockParser creates a new math BlockParser
-func NewBlockParser(parseDollarBlocks bool) parser.BlockParser {
+func NewBlockParser(parseDollars, parseSquare bool) parser.BlockParser {
return &blockParser{
- parseDollars: parseDollarBlocks,
+ parseDollars: parseDollars,
+ parseSquare: parseSquare,
endBytesDollars: []byte{'$', '$'},
- endBytesBracket: []byte{'\\', ']'},
+ endBytesSquare: []byte{'\\', ']'},
}
}
@@ -40,7 +42,7 @@ func (b *blockParser) Open(parent ast.Node, reader text.Reader, pc parser.Contex
var dollars bool
if b.parseDollars && line[pos] == '$' && line[pos+1] == '$' {
dollars = true
- } else if line[pos] == '\\' && line[pos+1] == '[' {
+ } else if b.parseSquare && line[pos] == '\\' && line[pos+1] == '[' {
if len(line[pos:]) >= 3 && line[pos+2] == '!' && bytes.Contains(line[pos:], []byte(`\]`)) {
// do not process escaped attention block: "> \[!NOTE\]"
return nil, parser.NoChildren
@@ -53,10 +55,10 @@ func (b *blockParser) Open(parent ast.Node, reader text.Reader, pc parser.Contex
node := NewBlock(dollars, pos)
// Now we need to check if the ending block is on the segment...
- endBytes := giteaUtil.Iif(dollars, b.endBytesDollars, b.endBytesBracket)
+ endBytes := giteaUtil.Iif(dollars, b.endBytesDollars, b.endBytesSquare)
idx := bytes.Index(line[pos+2:], endBytes)
if idx >= 0 {
- // for case $$ ... $$ any other text
+ // for case: "$$ ... $$ any other text" (this case will be handled by the inline parser)
for i := pos + 2 + idx + 2; i < len(line); i++ {
if line[i] != ' ' && line[i] != '\n' {
return nil, parser.NoChildren
@@ -70,6 +72,13 @@ func (b *blockParser) Open(parent ast.Node, reader text.Reader, pc parser.Contex
return node, parser.Close | parser.NoChildren
}
+ // for case "\[ ... ]" (no close marker on the same line)
+ for i := pos + 2 + idx + 2; i < len(line); i++ {
+ if line[i] != ' ' && line[i] != '\n' {
+ return nil, parser.NoChildren
+ }
+ }
+
segment.Start += pos + 2
node.Lines().Append(segment)
return node, parser.NoChildren
@@ -85,7 +94,7 @@ func (b *blockParser) Continue(node ast.Node, reader text.Reader, pc parser.Cont
line, segment := reader.PeekLine()
w, pos := util.IndentWidth(line, reader.LineOffset())
if w < 4 {
- endBytes := giteaUtil.Iif(block.Dollars, b.endBytesDollars, b.endBytesBracket)
+ endBytes := giteaUtil.Iif(block.Dollars, b.endBytesDollars, b.endBytesSquare)
if bytes.HasPrefix(line[pos:], endBytes) && util.IsBlank(line[pos+len(endBytes):]) {
if util.IsBlank(line[pos+len(endBytes):]) {
newline := giteaUtil.Iif(line[len(line)-1] != '\n', 0, 1)