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/backticks.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/backticks.go')
-rw-r--r-- | vendor/gitlab.com/golang-commonmark/markdown/backticks.go | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/vendor/gitlab.com/golang-commonmark/markdown/backticks.go b/vendor/gitlab.com/golang-commonmark/markdown/backticks.go new file mode 100644 index 00000000..07f268dc --- /dev/null +++ b/vendor/gitlab.com/golang-commonmark/markdown/backticks.go @@ -0,0 +1,60 @@ +// 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 ruleBackticks(s *StateInline, silent bool) bool { + pos := s.Pos + src := s.Src + + if src[pos] != '`' { + return false + } + + start := pos + pos++ + max := s.PosMax + + for pos < max && src[pos] == '`' { + pos++ + } + + marker := src[start:pos] + + matchStart := pos + matchEnd := pos + for { + matchStart = strings.IndexByte(src[matchEnd:], '`') + if matchStart == -1 { + break + } + matchStart += matchEnd + + matchEnd = matchStart + 1 + + for matchEnd < max && src[matchEnd] == '`' { + matchEnd++ + } + + if matchEnd-matchStart == len(marker) { + if !silent { + s.PushToken(&CodeInline{ + Content: normalizeInlineCode(src[pos:matchStart]), + }) + } + s.Pos = matchEnd + return true + } + } + + if !silent { + s.Pending.WriteString(marker) + } + + s.Pos += len(marker) + + return true +} |