summaryrefslogtreecommitdiffstats
path: root/helpers
diff options
context:
space:
mode:
authorNathan Youngman <git@nathany.com>2015-10-14 15:10:50 -0600
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>2015-10-15 17:59:28 +0200
commitec9c6912163f9ca3c10ad75aba939a76ec96e932 (patch)
treefc0499b6d57d51ceac1a3a336af1b326ce0b05f9 /helpers
parent6a3aced15a402183b7c92817a259c44d890cf7be (diff)
Insert code tag for server-side syntax highlighting
Inserts a code tag into Pygments output with the language-info that is present when using client-side highlighting (useful for CSS hooks) ```html <code class="language-go" data-lang="go"> ``` closes #1490
Diffstat (limited to 'helpers')
-rw-r--r--helpers/content_renderer_test.go2
-rw-r--r--helpers/pygments.go13
2 files changed, 12 insertions, 3 deletions
diff --git a/helpers/content_renderer_test.go b/helpers/content_renderer_test.go
index 90b4c4939..1c84818a2 100644
--- a/helpers/content_renderer_test.go
+++ b/helpers/content_renderer_test.go
@@ -38,7 +38,7 @@ func TestCodeFence(t *testing.T) {
input, expected string
}
data := []test{
- {true, "<html></html>", "<div class=\"highlight\"><pre><span class=\"nt\">&lt;html&gt;&lt;/html&gt;</span>\n</pre></div>\n"},
+ {true, "<html></html>", "<div class=\"highlight\"><pre><code class=\"language-html\" data-lang=\"html\"><span class=\"nt\">&lt;html&gt;&lt;/html&gt;</span>\n</code></pre></div>\n"},
{false, "<html></html>", "<pre><code class=\"language-html\">&lt;html&gt;&lt;/html&gt;</code></pre>\n"},
}
diff --git a/helpers/pygments.go b/helpers/pygments.go
index 29a5ec54f..17c30ee0a 100644
--- a/helpers/pygments.go
+++ b/helpers/pygments.go
@@ -111,14 +111,23 @@ func Highlight(code, lang, optsStr string) string {
return code
}
+ str := out.String()
+
+ // inject code tag into Pygments output
+ if lang != "" && strings.Contains(str, "<pre>") {
+ codeTag := fmt.Sprintf(`<pre><code class="language-%s" data-lang="%s">`, lang, lang)
+ str = strings.Replace(str, "<pre>", codeTag, 1)
+ str = strings.Replace(str, "</pre>", "</code></pre>", 1)
+ }
+
if cachefile != "" {
// Write cache file
- if err := WriteToDisk(cachefile, bytes.NewReader(out.Bytes()), fs); err != nil {
+ if err := WriteToDisk(cachefile, strings.NewReader(str), fs); err != nil {
jww.ERROR.Print(stderr.String())
}
}
- return out.String()
+ return str
}
var pygmentsKeywords = make(map[string]bool)