go-org-orgwiki/main.go
Niklas Fasching 2947d7632d Support basic #+INCLUDE (src/example/export block only)
including org files is more complex - e.g. footnotes need to be namespaced to
their source file. org does this by prefixing each included files footnotes
with a number - but even that is not enough as it doesn't guarantee
uniqueness.

As I don't have a usecase for it, I'll avoid the additional complexity for
now.
2018-12-14 17:09:00 +01:00

59 lines
1.3 KiB
Go

package main
import (
"bytes"
"io/ioutil"
"log"
"os"
"strings"
"github.com/alecthomas/chroma"
"github.com/alecthomas/chroma/formatters/html"
"github.com/alecthomas/chroma/lexers"
"github.com/alecthomas/chroma/styles"
"github.com/niklasfasching/go-org/org"
)
func main() {
log.SetFlags(0)
log.SetOutput(os.Stdout)
if len(os.Args) < 3 {
log.Println("USAGE: org FILE OUTPUT_FORMAT")
log.Fatal("supported output formats: org, html, html-chroma")
}
path := os.Args[1]
bs, err := ioutil.ReadFile(path)
if err != nil {
log.Fatal(err)
}
out, err := "", nil
d := org.NewDocument().SetPath(path).Parse(bytes.NewReader(bs))
switch strings.ToLower(os.Args[2]) {
case "org":
out, err = d.Write(org.NewOrgWriter())
case "html":
out, err = d.Write(org.NewHTMLWriter())
case "html-chroma":
writer := org.NewHTMLWriter()
writer.HighlightCodeBlock = highlightCodeBlock
out, err = d.Write(writer)
default:
log.Fatal("Unsupported output format")
}
if err != nil {
log.Fatal(err)
}
log.Print(out)
}
func highlightCodeBlock(source, lang string) string {
var w strings.Builder
l := lexers.Get(lang)
if l == nil {
l = lexers.Fallback
}
l = chroma.Coalesce(l)
it, _ := l.Tokenise(nil, source)
_ = html.New().Format(&w, styles.Get("friendly"), it)
return `<div class="highlight">` + "\n" + w.String() + "\n" + `</div>`
}