mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 17:08:25 +00:00 
			
		
		
		
	Refactor HTMLFormat, update chroma render, fix js error (#33136)
A small refactor to improve HTMLFormat, to help to prevent low-level mistakes. And fix #33141, fix #33139
This commit is contained in:
		| @@ -76,7 +76,7 @@ func (r *RenderInternal) ProtectSafeAttrs(content template.HTML) template.HTML { | ||||
| 	return template.HTML(reAttrClass().ReplaceAllString(string(content), `$1 data-attr-class="`+r.secureIDPrefix+`$2"$3`)) | ||||
| } | ||||
|  | ||||
| func (r *RenderInternal) FormatWithSafeAttrs(w io.Writer, fmt string, a ...any) error { | ||||
| func (r *RenderInternal) FormatWithSafeAttrs(w io.Writer, fmt template.HTML, a ...any) error { | ||||
| 	_, err := w.Write([]byte(r.ProtectSafeAttrs(htmlutil.HTMLFormat(fmt, a...)))) | ||||
| 	return err | ||||
| } | ||||
|   | ||||
| @@ -4,6 +4,8 @@ | ||||
| package math | ||||
|  | ||||
| import ( | ||||
| 	"html/template" | ||||
|  | ||||
| 	"code.gitea.io/gitea/modules/markup/internal" | ||||
| 	giteaUtil "code.gitea.io/gitea/modules/util" | ||||
|  | ||||
| @@ -50,7 +52,7 @@ func (r *BlockRenderer) renderBlock(w util.BufWriter, source []byte, node gast.N | ||||
| 	n := node.(*Block) | ||||
| 	if entering { | ||||
| 		code := giteaUtil.Iif(n.Inline, "", `<pre class="code-block is-loading">`) + `<code class="language-math display">` | ||||
| 		_ = r.renderInternal.FormatWithSafeAttrs(w, code) | ||||
| 		_ = r.renderInternal.FormatWithSafeAttrs(w, template.HTML(code)) | ||||
| 		r.writeLines(w, source, n) | ||||
| 	} else { | ||||
| 		_, _ = w.WriteString(`</code>` + giteaUtil.Iif(n.Inline, "", `</pre>`) + "\n") | ||||
|   | ||||
| @@ -147,7 +147,7 @@ func (r *orgWriter) resolveLink(kind, link string) string { | ||||
| func (r *orgWriter) WriteRegularLink(l org.RegularLink) { | ||||
| 	link := r.resolveLink(l.Kind(), l.URL) | ||||
|  | ||||
| 	printHTML := func(html string, a ...any) { | ||||
| 	printHTML := func(html template.HTML, a ...any) { | ||||
| 		_, _ = fmt.Fprint(r, htmlutil.HTMLFormat(html, a...)) | ||||
| 	} | ||||
| 	// Inspired by https://github.com/niklasfasching/go-org/blob/6eb20dbda93cb88c3503f7508dc78cbbc639378f/org/html_writer.go#L406-L427 | ||||
|   | ||||
| @@ -103,8 +103,8 @@ func HelloWorld() { | ||||
| } | ||||
| #+end_src | ||||
| `, `<div class="src src-go"> | ||||
| <pre><code class="chroma language-go"><span class="c1">// HelloWorld prints "Hello World" | ||||
| </span><span class="c1"></span><span class="kd">func</span> <span class="nf">HelloWorld</span><span class="p">()</span> <span class="p">{</span> | ||||
| <pre><code class="chroma language-go"><span class="c1">// HelloWorld prints "Hello World"</span> | ||||
| <span class="kd">func</span> <span class="nf">HelloWorld</span><span class="p">()</span> <span class="p">{</span> | ||||
| 	<span class="nx">fmt</span><span class="p">.</span><span class="nf">Println</span><span class="p">(</span><span class="s">"Hello World"</span><span class="p">)</span> | ||||
| <span class="p">}</span></code></pre> | ||||
| </div>`) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user