|
@ -21,15 +21,25 @@ var autolinker = new Autolinker({ |
|
|
} |
|
|
} |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
function isLinkOpen(str) { |
|
|
|
|
|
return /^<a[>\s]/i.test(str); |
|
|
|
|
|
} |
|
|
|
|
|
function isLinkClose(str) { |
|
|
|
|
|
return /^<\/a\s*>/i.test(str); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
module.exports = function linkify(t, state) { |
|
|
module.exports = function linkify(t, state) { |
|
|
var i, token, text, nodes, ln, pos, level, |
|
|
var i, token, text, nodes, ln, pos, level, |
|
|
|
|
|
htmlLinkLevel = 0, |
|
|
tokens = state.tokens; |
|
|
tokens = state.tokens; |
|
|
|
|
|
|
|
|
|
|
|
// We scan from the end, to keep position when new tags added.
|
|
|
|
|
|
// Use reversed logic in links start/end match
|
|
|
for (i = tokens.length - 1; i >= 0; i--) { |
|
|
for (i = tokens.length - 1; i >= 0; i--) { |
|
|
token = tokens[i]; |
|
|
token = tokens[i]; |
|
|
|
|
|
|
|
|
// Skip content of links
|
|
|
// Skip content of markdown links
|
|
|
if (token.type === 'link_close') { |
|
|
if (token.type === 'link_close') { |
|
|
i--; |
|
|
i--; |
|
|
while (tokens[i].type !== 'link_open' && tokens[i].level !== token.level) { |
|
|
while (tokens[i].type !== 'link_open' && tokens[i].level !== token.level) { |
|
@ -39,6 +49,17 @@ module.exports = function linkify(t, state) { |
|
|
continue; |
|
|
continue; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Skip content of html tag links
|
|
|
|
|
|
if (token.type === 'htmltag') { |
|
|
|
|
|
if (isLinkOpen(token.content) && htmlLinkLevel > 0) { |
|
|
|
|
|
htmlLinkLevel--; |
|
|
|
|
|
} |
|
|
|
|
|
if (isLinkClose(token.content)) { |
|
|
|
|
|
htmlLinkLevel++; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
if (htmlLinkLevel > 0) { continue; } |
|
|
|
|
|
|
|
|
if (token.type === 'text' && |
|
|
if (token.type === 'text' && |
|
|
(token.content.indexOf('://') || |
|
|
(token.content.indexOf('://') || |
|
|
token.content.indexOf('www'))) { |
|
|
token.content.indexOf('www'))) { |
|
|