From a1293f820a733978f1da8ebd13e676f46634f60d Mon Sep 17 00:00:00 2001
From: Aiden Bai <aiden.bai05@gmail.com>
Date: Mon, 30 May 2022 03:40:44 +0000
Subject: [PATCH] Prerender latex

---
 layouts/partials/textprocessing.html |   65 ++++++++++++++++++++++----------
 1 files changed, 45 insertions(+), 20 deletions(-)

diff --git a/layouts/partials/textprocessing.html b/layouts/partials/textprocessing.html
index 008d163..8e8c999 100644
--- a/layouts/partials/textprocessing.html
+++ b/layouts/partials/textprocessing.html
@@ -1,9 +1,7 @@
 {{ $content := .Content }}
+{{ $raw := .RawContent }}
 {{ $page := .Page }}
 
-{{/* Replace right arrow */}}
-{{ $content = replace $content "-&gt;" "→" }}
-
 {{/* Escape slashes for Latex to fix line breaks */}}
 {{$latex := findRE "\\$\\$([^\\$]+)\\$\\$" $content}}
 {{range $latex}}
@@ -12,24 +10,51 @@
 {{end}}
 
 {{/* Wikilinks */}}
-{{$wikilinks := $content | findRE "\\[\\[[^\\[\\]\\|]*(?:\\|[^\\[\\]]*)?\\]\\]" }}
+{{$wikilinks := $content | findRE "!?\\[\\[\\S[^\\[\\]\\|]*(?:\\|[^\\[\\]]*)?\\S\\]\\]" }}
+{{$codefences := $raw | findRE "\\x60[^\\x60\\n]+\\x60"}}
+{{$codeblocks := $raw | findRE "\\x60{3}[^\\x60]+\\x60{3}"}}
+{{$code := union $codefences $codeblocks}}
 {{range $wikilinks}}
-  {{$inner := . | strings.TrimPrefix "[[" | strings.TrimSuffix "]]" }}
-  {{$split := split $inner "|"}}
-  {{$path := index $split 0}}
-  {{$reference := split $path "#"}}
-  {{$title := index $reference 0}}
-  {{$block := default "" (index $reference 1)}}
-  {{$block = strings.TrimRight "/" (cond (eq $block "") $block (printf "#%s" $block))}}
-  {{$href := strings.TrimRight "/" ($page.GetPage $title).RelPermalink}}
-  {{$display := default $title (index $split 1)}}
-  {{if not $href}}
-    {{$link := printf "<a class=\"internal-link broken\">%s</a>" $display}}
-    {{ $content = replace $content . $link }}
-  {{else}}
-    {{$fullhref := printf "%s%s" $href $block }}
-    {{$link := printf "<a href=\"%s\" rel=\"noopener\" class=\"internal-link\" data-src=\"%s\">%s</a>" $fullhref $href $display}}
-    {{ $content = replace $content . $link }}
+  {{$cur := .}}
+  {{$incode := false}}
+  {{range $code}}
+    {{if (in . $cur)}}
+      {{$incode = true}}
+    {{end}}
+  {{end}}
+  {{if not $incode}}
+    {{if (hasPrefix . "!")}}
+      {{$inner := . | strings.TrimPrefix "![[" | strings.TrimSuffix "]]" }}
+      {{$split := split $inner "|"}}
+      {{$path := index $split 0 | relURL}}
+      {{$reference := split $path "#"}}
+      {{$title := index $reference 0}}
+      {{$display := default $title (index $split 1)}}
+      {{$img := printf "<img src=\"%s\" title=\"%s\">" $path $display}}
+      {{$content = replace $content . $img}}
+    {{else}}
+      {{$inner := . | strings.TrimPrefix "[[" | strings.TrimSuffix "]]" }}
+      {{$split := split $inner "|"}}
+      {{$path := index $split 0}}
+      {{$reference := split $path "#"}}
+      {{$title := index $reference 0}}
+      {{$block := default "" (index $reference 1)}}
+      {{$block = strings.TrimRight "/" (cond (eq $block "") $block (printf "#%s" $block))}}
+      {{$href := strings.TrimRight "/" ($page.GetPage $title).RelPermalink}}
+      {{$display := default $title (index $split 1)}}
+      {{if not $href}}
+        {{$link := printf "<a class=\"internal-link broken\">%s</a>" $display}}
+        {{$content = replace $content . $link}}
+      {{else}}
+        {{$fullhref := printf "%s%s" $href $block }}
+        {{$link := printf "<a href=\"%s\" rel=\"noopener\" class=\"internal-link\" data-src=\"%s\">%s</a>" $fullhref $href $display}}
+        {{$content = replace $content . $link}}
+      {{end}}
+    {{end}}
   {{end}}
 {{end}}
+
+{{/* Add copyable anchors */}}
+{{ $content = $content | replaceRE "(<h[1-9] id=\"([^\"]+)\">)(.+)(</h[1-9]>)" `<a href="#${2}">${1}<span class="hanchor" ariaLabel="Anchor"># </span>${3}${4}</a>` }}
+
 {{ $content | safeHTML }}

--
Gitblit v1.10.0