aboutsummaryrefslogtreecommitdiff
path: root/render_readme.go
diff options
context:
space:
mode:
authorRunxi Yu <me@runxiyu.org>2025-02-13 00:31:48 +0800
committerRunxi Yu <me@runxiyu.org>2025-02-13 00:32:01 +0800
commitd87f80d3e14990e5d9fc83990ff04e29affa3a94 (patch)
tree5df543f16b96388c1dc7c6456c24d8b0d66b9d5d /render_readme.go
parentREADME.md: Add a bit of detail (diff)
downloadforge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.tar.gz
forge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.tar.zst
forge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.zip
*.go: Mass rename files for clarity
Diffstat (limited to 'render_readme.go')
-rw-r--r--render_readme.go61
1 files changed, 0 insertions, 61 deletions
diff --git a/render_readme.go b/render_readme.go
deleted file mode 100644
index 497b3ec..0000000
--- a/render_readme.go
+++ /dev/null
@@ -1,61 +0,0 @@
-package main
-
-import (
- "bytes"
- "html"
- "html/template"
- "strings"
-
- "github.com/go-git/go-git/v5/plumbing/object"
- "github.com/microcosm-cc/bluemonday"
- "github.com/niklasfasching/go-org/org"
- "github.com/yuin/goldmark"
- "github.com/yuin/goldmark/extension"
-)
-
-var markdown_converter = goldmark.New(goldmark.WithExtensions(extension.GFM))
-
-func render_readme_at_tree(tree *object.Tree) (readme_filename string, readme_content template.HTML) {
- var readme_rendered_unsafe bytes.Buffer
-
- readme_file, err := tree.File("README")
- if err == nil {
- readme_file_contents, err := readme_file.Contents()
- if err != nil {
- return "Error fetching README", string_escape_html("Unable to fetch contents of README: " + err.Error())
- }
- return "README", template.HTML("<pre>" + html.EscapeString(readme_file_contents) + "</pre>")
- }
-
- readme_file, err = tree.File("README.md")
- if err == nil {
- readme_file_contents, err := readme_file.Contents()
- if err != nil {
- return "Error fetching README", string_escape_html("Unable to fetch contents of README: " + err.Error())
- }
- err = markdown_converter.Convert([]byte(readme_file_contents), &readme_rendered_unsafe)
- if err != nil {
- return "Error fetching README", string_escape_html("Unable to render README: " + err.Error())
- }
- return "README.md", template.HTML(bluemonday.UGCPolicy().SanitizeBytes(readme_rendered_unsafe.Bytes()))
- }
-
- readme_file, err = tree.File("README.org")
- if err == nil {
- readme_file_contents, err := readme_file.Contents()
- if err != nil {
- return "Error fetching README", string_escape_html("Unable to fetch contents of README: " + err.Error())
- }
- org_html, err := org.New().Parse(strings.NewReader(readme_file_contents), readme_filename).Write(org.NewHTMLWriter())
- if err != nil {
- return "Error fetching README", string_escape_html("Unable to render README: " + err.Error())
- }
- return "README.org", template.HTML(bluemonday.UGCPolicy().Sanitize(org_html))
- }
-
- return "", ""
-}
-
-func string_escape_html(s string) template.HTML {
- return template.HTML(html.EscapeString(s))
-}