/goldmark-meta

A TOML metadata extension for the goldmark markdown parser.

Primary LanguageGoMIT LicenseMIT

goldmark-meta

GoDev

goldmark-meta is an extension for the goldmark that allows you to define document metadata in TOML format.

Usage

Installation

go get github.com/jolheiser/goldmark-meta

Markdown syntax

TOML metadata block is a leaf block that can not have any markdown element as a child.

TOML metadata must start with a TOML metadata separator. This separator must be at first line of the document.

A TOML metadata separator is a line that only + is repeated.

TOML metadata must end with a TOML metadata separator.

You can define objects as a 1st level item. At deeper level, you can define any kind of TOML element.

Example:

+++
Title = "goldmark-meta"
Summary = "Add TOML metadata to the document"
Tags = ["markdown", "goldmark"]
+++

# Heading 1

Access the metadata

import (
    "bytes"
    "fmt"
    "github.com/yuin/goldmark"
    "github.com/yuin/goldmark/extension"
    "github.com/yuin/goldmark/parser"
    "github.com/jolheiser/goldmark-meta"
)

func main() {
    markdown := goldmark.New(
        goldmark.WithExtensions(
            meta.Meta,
        ),
    )
    source := `+++
Title = "goldmark-meta"
Summary = "Add TOML metadata to the document"
Tags = ["markdown", "goldmark"]
+++

# Hello goldmark-meta
`

    var buf bytes.Buffer
    context := parser.NewContext()
    if err := markdown.Convert([]byte(source), &buf, parser.WithContext(context)); err != nil {
        panic(err)
    }
    metaData := meta.Get(context)
    title := metaData["Title"]
    fmt.Print(title)
}

Or WithStoresInDocument option:

import (
    "bytes"
    "fmt"
    "github.com/yuin/goldmark"
    "github.com/yuin/goldmark/extension"
    "github.com/yuin/goldmark/parser"
    "github.com/yuin/goldmark/text"
    "github.com/jolheiser/goldmark-meta"
)

func main() {
	markdown := goldmark.New(
		goldmark.WithExtensions(
			meta.New(
				meta.WithStoresInDocument(),
			),
		),
	)
	source := `+++
Title = "goldmark-meta"
Summary = "Add TOML metadata to the document"
Tags = ["markdown", "goldmark"]
+++
`

	document := markdown.Parser().Parse(text.NewReader([]byte(source)))
	metaData := document.OwnerDocument().Meta()
	title := metaData["Title"]
	fmt.Print(title)
}

Render the metadata as a table

You need to add extension.TableHTMLRenderer or the Table extension to render metadata as a table.

import (
    "bytes"
    "fmt"
    "github.com/yuin/goldmark"
    "github.com/yuin/goldmark/extension"
    "github.com/yuin/goldmark/parser"
    "github.com/yuin/goldmark/renderer"
    "github.com/yuin/goldmark/util"
    "github.com/jolheiser/goldmark-meta"
)

func main() {
    markdown := goldmark.New(
        goldmark.WithExtensions(
            meta.New(meta.WithTable()),
        ),
        goldmark.WithRendererOptions(
            renderer.WithNodeRenderers(
                util.Prioritized(extension.NewTableHTMLRenderer(), 500),
            ),
        ),
    )
    // OR
    // markdown := goldmark.New(
    //     goldmark.WithExtensions(
    //         meta.New(meta.WithTable()),
    //         extension.Table,
    //     ),
    // )
    source := `+++
Title = "goldmark-meta"
Summary = "Add TOML metadata to the document"
Tags = ["markdown", "goldmark"]
+++

# Hello goldmark-meta
`

    var buf bytes.Buffer
    if err := markdown.Convert([]byte(source), &buf); err != nil {
        panic(err)
    }
    fmt.Print(buf.String())
}

License

MIT

Author

Yusuke Inuzuka