markup/highlight: Fix chroma highlight
authorsatotake <doublequotation@gmail.com>
Mon, 17 Feb 2020 13:59:26 +0000 (22:59 +0900)
committerGitHub <noreply@github.com>
Mon, 17 Feb 2020 13:59:26 +0000 (14:59 +0100)
* Use chroma.Coalesce
* Escape code strings if lexer is nil

Fixes #6877
Fixes #6856

markup/highlight/highlight.go
markup/highlight/highlight_test.go

index 9e26aaf844e05a72e209a6fd839471e550695729..2bd77af0b2aaeb963f80046b6e970e25ae22058c 100644 (file)
@@ -15,6 +15,7 @@ package highlight
 
 import (
        "fmt"
+       gohtml "html"
        "io"
        "strings"
 
@@ -63,7 +64,7 @@ func highlight(code, lang string, cfg Config) (string, error) {
        if lexer == nil {
                wrapper := getPreWrapper(lang)
                fmt.Fprint(w, wrapper.Start(true, ""))
-               fmt.Fprint(w, code)
+               fmt.Fprint(w, gohtml.EscapeString(code))
                fmt.Fprint(w, wrapper.End(true))
                return w.String(), nil
        }
@@ -72,6 +73,7 @@ func highlight(code, lang string, cfg Config) (string, error) {
        if style == nil {
                style = styles.Fallback
        }
+       lexer = chroma.Coalesce(lexer)
 
        iterator, err := lexer.Tokenise(nil, code)
        if err != nil {
index 6da2924896db334f46044eda36f7f5cc3c2e2594..3086792639db1a334c17a7b317407af523801e8b 100644 (file)
@@ -29,6 +29,13 @@ LINE3
 LINE4
 LINE5
 `
+       coalesceNeeded := `GET /foo HTTP/1.1
+Content-Type: application/json
+User-Agent: foo
+
+{
+  "hello": "world"
+}`
 
        c.Run("Basic", func(c *qt.C) {
                cfg := DefaultConfig
@@ -38,7 +45,7 @@ LINE5
                result, _ := h.Highlight(`echo "Hugo Rocks!"`, "bash", "")
                c.Assert(result, qt.Equals, `<div class="highlight"><pre class="chroma"><code class="language-bash" data-lang="bash"><span class="nb">echo</span> <span class="s2">&#34;Hugo Rocks!&#34;</span></code></pre></div>`)
                result, _ = h.Highlight(`echo "Hugo Rocks!"`, "unknown", "")
-               c.Assert(result, qt.Equals, `<pre><code class="language-unknown" data-lang="unknown">echo "Hugo Rocks!"</code></pre>`)
+               c.Assert(result, qt.Equals, `<pre><code class="language-unknown" data-lang="unknown">echo &#34;Hugo Rocks!&#34;</code></pre>`)
 
        })
 
@@ -106,4 +113,24 @@ LINE5
                result, _ := h.Highlight(lines, "", "")
                c.Assert(result, qt.Contains, "<span class=\"ln\">2</span>LINE2\n<")
        })
+
+       c.Run("No language, Escape HTML string", func(c *qt.C) {
+               cfg := DefaultConfig
+               cfg.NoClasses = false
+               h := New(cfg)
+
+               result, _ := h.Highlight("Escaping less-than in code block? <fail>", "", "")
+               c.Assert(result, qt.Contains, "&lt;fail&gt;")
+       })
+
+       c.Run("Highlight lines, default config", func(c *qt.C) {
+               cfg := DefaultConfig
+               cfg.NoClasses = false
+               h := New(cfg)
+
+               result, _ := h.Highlight(coalesceNeeded, "http", "linenos=true,hl_lines=2")
+               c.Assert(result, qt.Contains, "hello")
+               c.Assert(result, qt.Contains, "}")
+       })
+
 }