mirror of
https://github.com/danog/blackfriday.git
synced 2024-12-02 09:27:49 +01:00
add target blank attr
This commit is contained in:
parent
e078bb8ec3
commit
ecf59d4a55
35
html.go
35
html.go
@ -31,6 +31,7 @@ const (
|
|||||||
HTML_SKIP_SCRIPT // skip embedded <script> elements
|
HTML_SKIP_SCRIPT // skip embedded <script> elements
|
||||||
HTML_SAFELINK // only link to trusted protocols
|
HTML_SAFELINK // only link to trusted protocols
|
||||||
HTML_NOFOLLOW_LINKS // only link with rel="nofollow"
|
HTML_NOFOLLOW_LINKS // only link with rel="nofollow"
|
||||||
|
HTML_HREF_TARGET_BLANK // add a blank target
|
||||||
HTML_TOC // generate a table of contents
|
HTML_TOC // generate a table of contents
|
||||||
HTML_OMIT_CONTENTS // skip the main contents (for a standalone table of contents)
|
HTML_OMIT_CONTENTS // skip the main contents (for a standalone table of contents)
|
||||||
HTML_COMPLETE_PAGE // generate a complete HTML page
|
HTML_COMPLETE_PAGE // generate a complete HTML page
|
||||||
@ -413,6 +414,15 @@ func (options *Html) AutoLink(out *bytes.Buffer, link []byte, kind int) {
|
|||||||
out.WriteString("mailto:")
|
out.WriteString("mailto:")
|
||||||
}
|
}
|
||||||
attrEscape(out, link)
|
attrEscape(out, link)
|
||||||
|
|
||||||
|
if options.flags&HTML_NOFOLLOW_LINKS != 0 {
|
||||||
|
out.WriteString("\" rel=\"nofollow")
|
||||||
|
}
|
||||||
|
// blank target only add to external link
|
||||||
|
if options.flags&HTML_HREF_TARGET_BLANK != 0 && !isRelativeLink(link) {
|
||||||
|
out.WriteString("\" target=\"_blank")
|
||||||
|
}
|
||||||
|
|
||||||
out.WriteString("\">")
|
out.WriteString("\">")
|
||||||
|
|
||||||
// Pretty print: if we get an email address as
|
// Pretty print: if we get an email address as
|
||||||
@ -503,6 +513,11 @@ func (options *Html) Link(out *bytes.Buffer, link []byte, title []byte, content
|
|||||||
if options.flags&HTML_NOFOLLOW_LINKS != 0 {
|
if options.flags&HTML_NOFOLLOW_LINKS != 0 {
|
||||||
out.WriteString("\" rel=\"nofollow")
|
out.WriteString("\" rel=\"nofollow")
|
||||||
}
|
}
|
||||||
|
// blank target only add to external link
|
||||||
|
if options.flags&HTML_HREF_TARGET_BLANK != 0 && !isRelativeLink(link) {
|
||||||
|
out.WriteString("\" target=\"_blank")
|
||||||
|
}
|
||||||
|
|
||||||
out.WriteString("\">")
|
out.WriteString("\">")
|
||||||
out.Write(content)
|
out.Write(content)
|
||||||
out.WriteString("</a>")
|
out.WriteString("</a>")
|
||||||
@ -788,3 +803,23 @@ func doubleSpace(out *bytes.Buffer) {
|
|||||||
out.WriteByte('\n')
|
out.WriteByte('\n')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func isRelativeLink(link []byte) (yes bool) {
|
||||||
|
yes = false
|
||||||
|
|
||||||
|
// a tag begin with '#'
|
||||||
|
if link[0] == '#' {
|
||||||
|
yes = true
|
||||||
|
}
|
||||||
|
|
||||||
|
// link begin with '/' but not '//', the second maybe a protocol relative link
|
||||||
|
if len(link) >= 2 && link[0] == '/' && link[1] != '/' {
|
||||||
|
yes = true
|
||||||
|
}
|
||||||
|
|
||||||
|
// only the root '/'
|
||||||
|
if len(link) == 1 && link[0] == '/' {
|
||||||
|
yes = true
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
@ -429,6 +429,18 @@ func TestNofollowLink(t *testing.T) {
|
|||||||
doTestsInlineParam(t, tests, 0, HTML_SAFELINK|HTML_NOFOLLOW_LINKS)
|
doTestsInlineParam(t, tests, 0, HTML_SAFELINK|HTML_NOFOLLOW_LINKS)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestHrefTargetBlank(t *testing.T) {
|
||||||
|
var tests = []string{
|
||||||
|
// internal link
|
||||||
|
"[foo](/bar/)\n",
|
||||||
|
"<p><a href=\"/bar/\">foo</a></p>\n",
|
||||||
|
|
||||||
|
"[foo](http://example.com)\n",
|
||||||
|
"<p><a href=\"http://example.com\" target=\"_blank\">foo</a></p>\n",
|
||||||
|
}
|
||||||
|
doTestsInlineParam(t, tests, 0, HTML_SAFELINK|HTML_HREF_TARGET_BLANK)
|
||||||
|
}
|
||||||
|
|
||||||
func TestSafeInlineLink(t *testing.T) {
|
func TestSafeInlineLink(t *testing.T) {
|
||||||
var tests = []string{
|
var tests = []string{
|
||||||
"[foo](/bar/)\n",
|
"[foo](/bar/)\n",
|
||||||
|
Loading…
Reference in New Issue
Block a user