04567c765e
This uses our own gomatrix lib with the SendHTML function which adds HTML to formatted_body in matrix. golang-commonmark is used to convert markdown into valid HTML. |
||
---|---|---|
.. | ||
.gitlab-ci.yml | ||
AUTHORS | ||
LICENSE | ||
README.md | ||
align.go | ||
autolink.go | ||
backticks.go | ||
balance_pairs.go | ||
blockquote.go | ||
code.go | ||
emphasis.go | ||
entity.go | ||
escape.go | ||
fence.go | ||
fuzz.go | ||
heading.go | ||
helpers.go | ||
hr.go | ||
html_block.go | ||
html_inline.go | ||
image.go | ||
inline.go | ||
lheading.go | ||
link.go | ||
linkify.go | ||
list.go | ||
markdown.go | ||
newline.go | ||
options.go | ||
paragraph.go | ||
parser_block.go | ||
parser_inline.go | ||
plugins.go | ||
reference.go | ||
render.go | ||
replacements.go | ||
smartquotes.go | ||
state_block.go | ||
state_core.go | ||
state_inline.go | ||
strikethrough.go | ||
table.go | ||
table_fsm.go | ||
text.go | ||
text_collapse.go | ||
token.go | ||
urlschema.go | ||
util.go | ||
writer.go |
README.md
markdown
Package golang-commonmark/markdown provides a CommonMark-compliant markdown parser and renderer, written in Go.
Installation
go get -u gitlab.com/golang-commonmark/markdown
You can also go get mdtool, an example command-line tool:
go get -u gitlab.com/golang-commonmark/mdtool
Standards support
Currently supported CommonMark spec: v0.28.
Extensions
Besides the features required by CommonMark, golang-commonmark/markdown supports:
- Tables (GFM)
- Strikethrough (GFM)
- Autoconverting plain-text URLs to links
- Typographic replacements (smart quotes and other)
Usage
md := markdown.New(markdown.XHTMLOutput(true))
fmt.Println(md.RenderToString([]byte("Header\n===\nText")))
Check out the source of mdtool for a more complete example.
The following options are currently supported:
Name | Type | Description | Default |
---|---|---|---|
HTML | bool | whether to enable raw HTML | false |
Tables | bool | whether to enable GFM tables | true |
Linkify | bool | whether to autoconvert plain-text URLs to links | true |
Typographer | bool | whether to enable typographic replacements | true |
Quotes | string / []string | double + single quote replacement pairs for the typographer | “”‘’ |
MaxNesting | int | maximum nesting level | 20 |
LangPrefix | string | CSS language prefix for fenced blocks | language- |
Breaks | bool | whether to convert newlines inside paragraphs into <br> |
false |
XHTMLOutput | bool | whether to output XHTML instead of HTML | false |
Benchmarks
Rendering spec/spec-0.28.txt on a Intel(R) Core(TM) i5-2400 CPU @ 3.10GHz
BenchmarkRenderSpecNoHTML 100 10254720 ns/op 2998037 B/op 18225 allocs/op
BenchmarkRenderSpec 100 10180241 ns/op 2997307 B/op 18214 allocs/op
BenchmarkRenderSpecBlackFriday 200 7241749 ns/op 2834340 B/op 17101 allocs/op
BenchmarkRenderSpecBlackFriday2 200 7448256 ns/op 2991202 B/op 16705 allocs/op
See also
https://github.com/jgm/CommonMark — the reference CommonMark implementations in C and JavaScript, also contains the latest spec and an online demo.
http://talk.commonmark.org — the CommonMark forum, a good place to join together the efforts of the developers.