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)
	}
}