Some checks failed
Build and Release / Create Release (push) Successful in 0s
Trigger Vault Plugin Rebuild / Trigger Vault Rebuild (push) Successful in 0s
Build and Release / Integration Tests (PostgreSQL) (push) Successful in 2m48s
Build and Release / Lint (push) Failing after 5m2s
Build and Release / Build Binaries (amd64, windows, windows-latest) (push) Has been skipped
Build and Release / Build Binaries (amd64, darwin, linux-latest) (push) Has been skipped
Build and Release / Build Binaries (amd64, linux, linux-latest) (push) Has been skipped
Build and Release / Build Binaries (arm64, darwin, linux-latest) (push) Has been skipped
Build and Release / Build Binaries (arm64, linux, linux-latest) (push) Has been skipped
Build and Release / Unit Tests (push) Successful in 5m37s
Go's semantic import versioning requires v2+ modules to include the major version in the module path. This enables using proper version tags (v3.x.x) instead of pseudo-versions. Updated module path: code.gitcaddy.com/server/v3
54 lines
1.5 KiB
Go
54 lines
1.5 KiB
Go
// Copyright 2022 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package math
|
|
|
|
import (
|
|
"bytes"
|
|
|
|
"code.gitcaddy.com/server/v3/modules/markup/internal"
|
|
|
|
"github.com/yuin/goldmark/ast"
|
|
"github.com/yuin/goldmark/renderer"
|
|
"github.com/yuin/goldmark/util"
|
|
)
|
|
|
|
// Inline render output:
|
|
// <code class="language-math">...</code>
|
|
|
|
// InlineRenderer is an inline renderer
|
|
type InlineRenderer struct {
|
|
renderInternal *internal.RenderInternal
|
|
}
|
|
|
|
// NewInlineRenderer returns a new renderer for inline math
|
|
func NewInlineRenderer(renderInternal *internal.RenderInternal) renderer.NodeRenderer {
|
|
return &InlineRenderer{renderInternal: renderInternal}
|
|
}
|
|
|
|
func (r *InlineRenderer) renderInline(w util.BufWriter, source []byte, n ast.Node, entering bool) (ast.WalkStatus, error) {
|
|
if entering {
|
|
_, _ = w.WriteString(string(r.renderInternal.ProtectSafeAttrs(`<code class="language-math">`)))
|
|
for c := n.FirstChild(); c != nil; c = c.NextSibling() {
|
|
segment := c.(*ast.Text).Segment
|
|
value := util.EscapeHTML(segment.Value(source))
|
|
if bytes.HasSuffix(value, []byte("\n")) {
|
|
_, _ = w.Write(value[:len(value)-1])
|
|
if c != n.LastChild() {
|
|
_, _ = w.Write([]byte(" "))
|
|
}
|
|
} else {
|
|
_, _ = w.Write(value)
|
|
}
|
|
}
|
|
return ast.WalkSkipChildren, nil
|
|
}
|
|
_, _ = w.WriteString(`</code>`)
|
|
return ast.WalkContinue, nil
|
|
}
|
|
|
|
// RegisterFuncs registers the renderer for inline math nodes
|
|
func (r *InlineRenderer) RegisterFuncs(reg renderer.NodeRendererFuncRegisterer) {
|
|
reg.Register(KindInline, r.renderInline)
|
|
}
|