diff options
author | Runxi Yu <me@runxiyu.org> | 2025-02-12 02:10:41 +0800 |
---|---|---|
committer | Runxi Yu <me@runxiyu.org> | 2025-02-12 02:10:41 +0800 |
commit | a0cd6d7d582a76b75922008497960b35a012da00 (patch) | |
tree | 580ec272b0839846ac68f0d1edfb76254df63036 /render_readme.go | |
parent | render_readme.go: Render plain READMEs too (diff) | |
download | forge-a0cd6d7d582a76b75922008497960b35a012da00.tar.gz forge-a0cd6d7d582a76b75922008497960b35a012da00.tar.zst forge-a0cd6d7d582a76b75922008497960b35a012da00.zip |
render_readme.go: Add org-mode support
Diffstat (limited to '')
-rw-r--r-- | render_readme.go | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/render_readme.go b/render_readme.go index 32a3a7d..497b3ec 100644 --- a/render_readme.go +++ b/render_readme.go @@ -4,9 +4,11 @@ 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" ) @@ -38,6 +40,19 @@ func render_readme_at_tree(tree *object.Tree) (readme_filename string, readme_co 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 "", "" } |