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/link.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/link.go')
-rw-r--r-- | vendor/gitlab.com/golang-commonmark/markdown/link.go | 132 |
1 files changed, 132 insertions, 0 deletions
diff --git a/vendor/gitlab.com/golang-commonmark/markdown/link.go b/vendor/gitlab.com/golang-commonmark/markdown/link.go new file mode 100644 index 00000000..8ab2c04b --- /dev/null +++ b/vendor/gitlab.com/golang-commonmark/markdown/link.go @@ -0,0 +1,132 @@ +// 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 + +func ruleLink(s *StateInline, silent bool) bool { + pos := s.Pos + oldPos := s.Pos + max := s.PosMax + start := s.Pos + parseReference := true + src := s.Src + + if src[pos] != '[' { + return false + } + + labelStart := pos + 1 + labelEnd := parseLinkLabel(s, pos, true) + + if labelEnd < 0 { + return false + } + + pos = labelEnd + 1 + + var title, href, label string + if pos < max && src[pos] == '(' { + parseReference = false + + pos++ + for pos < max { + code := src[pos] + if !byteIsSpace(code) && code != '\n' { + break + } + pos++ + } + if pos >= max { + return false + } + + start = pos + url, _, endpos, ok := parseLinkDestination(src, pos, s.PosMax) + if ok { + url = normalizeLink(url) + if validateLink(url) { + pos = endpos + href = url + } + } + + start = pos + for pos < max { + code := src[pos] + if !byteIsSpace(code) && code != '\n' { + break + } + pos++ + } + + title, _, endpos, ok = parseLinkTitle(src, pos, s.PosMax) + if pos < max && start != pos && ok { + pos = endpos + for pos < max { + code := src[pos] + if !byteIsSpace(code) && code != '\n' { + break + } + pos++ + } + } + + if pos >= max || src[pos] != ')' { + parseReference = true + } + + pos++ + } + + if parseReference { + if s.Env.References == nil { + return false + } + + if pos < max && src[pos] == '[' { + start := pos + 1 + pos = parseLinkLabel(s, pos, false) + if pos >= 0 { + label = src[start:pos] + pos++ + } else { + pos = labelEnd + 1 + } + } else { + pos = labelEnd + 1 + } + + if label == "" { + label = src[labelStart:labelEnd] + } + + ref, ok := s.Env.References[normalizeReference(label)] + if !ok { + s.Pos = oldPos + return false + } + + href = ref["href"] + title = ref["title"] + } + + if !silent { + s.Pos = labelStart + s.PosMax = labelEnd + + s.PushOpeningToken(&LinkOpen{ + Href: href, + Title: title, + }) + + s.Md.Inline.Tokenize(s) + + s.PushClosingToken(&LinkClose{}) + } + + s.Pos = pos + s.PosMax = max + + return true +} |