diff options
author | Wim <wim@42.be> | 2019-01-06 22:25:19 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-01-06 22:25:19 +0100 |
commit | 04567c765e92ad60c685c1b2fe7e77c46e065645 (patch) | |
tree | 34a587a6545c8e71e991e2a1551885faa0075738 /vendor/gitlab.com/golang-commonmark/markdown/heading.go | |
parent | 048158ad6db08cd714f39467fc0066ce41cfe6c5 (diff) | |
download | matterbridge-msglm-04567c765e92ad60c685c1b2fe7e77c46e065645.tar.gz matterbridge-msglm-04567c765e92ad60c685c1b2fe7e77c46e065645.tar.bz2 matterbridge-msglm-04567c765e92ad60c685c1b2fe7e77c46e065645.zip |
Add support for markdown to HTML conversion (matrix). Closes #663 (#670)
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.
Diffstat (limited to 'vendor/gitlab.com/golang-commonmark/markdown/heading.go')
-rw-r--r-- | vendor/gitlab.com/golang-commonmark/markdown/heading.go | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/vendor/gitlab.com/golang-commonmark/markdown/heading.go b/vendor/gitlab.com/golang-commonmark/markdown/heading.go new file mode 100644 index 00000000..a09c4f72 --- /dev/null +++ b/vendor/gitlab.com/golang-commonmark/markdown/heading.go @@ -0,0 +1,59 @@ +// Copyright 2015 The Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +package markdown + +import "strings" + +func ruleHeading(s *StateBlock, startLine, _ int, silent bool) bool { + pos := s.BMarks[startLine] + s.TShift[startLine] + max := s.EMarks[startLine] + src := s.Src + + if s.SCount[startLine]-s.BlkIndent >= 4 { + return false + } + + if pos >= max || src[pos] != '#' { + return false + } + + level := 1 + pos++ + for pos < max && src[pos] == '#' && level <= 6 { + level++ + pos++ + } + + if level > 6 || (pos < max && !byteIsSpace(src[pos])) { + return false + } + + if silent { + return true + } + + max = s.SkipSpacesBack(max, pos) + tmp := s.SkipBytesBack(max, '#', pos) + if tmp > pos && byteIsSpace(src[tmp-1]) { + max = tmp + } + + s.Line = startLine + 1 + + s.PushOpeningToken(&HeadingOpen{ + HLevel: level, + Map: [2]int{startLine, s.Line}, + }) + + if pos < max { + s.PushToken(&Inline{ + Content: strings.TrimSpace(src[pos:max]), + Map: [2]int{startLine, s.Line}, + }) + } + s.PushClosingToken(&HeadingClose{HLevel: level}) + + return true +} |