aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorTulir Asokan <tulir@maunium.net>2018-04-21 20:19:43 +0300
committerTulir Asokan <tulir@maunium.net>2018-04-21 21:24:07 +0300
commit7da1555c847edfc5a1d75b1ed26362901d3f9609 (patch)
treeb21543c9c3e93ee607e7702a7c5b8fba32efbb1b /lib
parentd147fc7579bf77bf6f3ace669c8ade68be89d1ca (diff)
Improve Markdown rendering
* Remove paragraphs from output HTML * Remove mention link wrapper from text (leaving only mention name)
Diffstat (limited to 'lib')
-rw-r--r--lib/bfhtml/doc.go2
-rw-r--r--lib/bfhtml/html.go34
2 files changed, 36 insertions, 0 deletions
diff --git a/lib/bfhtml/doc.go b/lib/bfhtml/doc.go
new file mode 100644
index 0000000..4881087
--- /dev/null
+++ b/lib/bfhtml/doc.go
@@ -0,0 +1,2 @@
+// Package bfhtml contains an extension to the Blackfriday HTML renderer to disable paragraph tags.
+package bfhtml
diff --git a/lib/bfhtml/html.go b/lib/bfhtml/html.go
new file mode 100644
index 0000000..14076ee
--- /dev/null
+++ b/lib/bfhtml/html.go
@@ -0,0 +1,34 @@
+// gomuks - A terminal Matrix client written in Go.
+// Copyright (C) 2018 Tulir Asokan
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+package bfhtml
+
+import (
+ "io"
+
+ bf "gopkg.in/russross/blackfriday.v2"
+)
+
+type HTMLRenderer struct {
+ *bf.HTMLRenderer
+}
+
+func (r *HTMLRenderer) RenderNode(w io.Writer, node *bf.Node, entering bool) bf.WalkStatus {
+ if node.Type == bf.Paragraph {
+ return bf.GoToNext
+ }
+ return r.HTMLRenderer.RenderNode(w, node, entering)
+}