Mercurial > repos > public > wdown
view wdown.go @ 12:bfffb69f55aa
Add forgotten abcjs file
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Mon, 22 Jun 2020 07:50:43 +0200 |
parents | 1ffe6e4f933c |
children | ebecd141e9d3 |
line wrap: on
line source
package main import ( "bytes" "flag" "fmt" "io/ioutil" "log" "os" "github.com/cbroglie/mustache" mathjax "github.com/litao91/goldmark-mathjax" "github.com/yuin/goldmark" highlighting "github.com/yuin/goldmark-highlighting" meta "github.com/yuin/goldmark-meta" "github.com/yuin/goldmark/extension" "github.com/yuin/goldmark/parser" ) func main() { var templateFilename string flag.StringVar(&templateFilename, "tmpl", "", "Template file to render the html inside. The content of the markdown file will replace the placeholder {{content}}.") flag.Parse() if flag.NArg() < 1 { fmt.Println("Please provide a markdown file for parsing.") os.Exit(1) } var useTemplate = false if templateFilename != "" { useTemplate = true } tmpl, err := mustache.ParseFile(templateFilename) if err != nil { log.Fatal(err) } source, err := ioutil.ReadFile(flag.Arg(0)) if err != nil { log.Fatal(err) } md := goldmark.New( goldmark.WithExtensions( extension.GFM, highlighting.Highlighting, meta.Meta, mathjax.MathJax, ), goldmark.WithParserOptions( parser.WithAutoHeadingID(), ), ) var htmlContent bytes.Buffer parserContext := parser.NewContext() err = md.Convert(source, &htmlContent, parser.WithContext(parserContext)) if err != nil { log.Fatal(err) } if useTemplate { templateVars := meta.Get(parserContext) templateVars["content"] = htmlContent.String() err := tmpl.FRender(os.Stdout, templateVars) if err != nil { log.Fatal(err) } } else { fmt.Print(htmlContent) } }