BUGFIX: Allow links to images with absolute URLs as well as parens
This commit is contained in:
parent
b8448b6e39
commit
7716d940a0
|
@ -379,5 +379,11 @@ test("urlAllowed", function() {
|
||||||
allowed("http://eviltrout.com/evil/trout", "allows full urls");
|
allowed("http://eviltrout.com/evil/trout", "allows full urls");
|
||||||
allowed("https://eviltrout.com/evil/trout", "allows https urls");
|
allowed("https://eviltrout.com/evil/trout", "allows https urls");
|
||||||
allowed("//eviltrout.com/evil/trout", "allows protocol relative urls");
|
allowed("//eviltrout.com/evil/trout", "allows protocol relative urls");
|
||||||
|
});
|
||||||
|
|
||||||
|
test("images", function() {
|
||||||
|
|
||||||
|
cooked("[![folksy logo](http://folksy.com/images/folksy-colour.png)](http://folksy.com/)",
|
||||||
|
"<p><a href=\"http://folksy.com/\"><img src=\"http://folksy.com/images/folksy-colour.png\" alt=\"folksy logo\"/></a></p>",
|
||||||
|
"It allows images with links around them");
|
||||||
});
|
});
|
||||||
|
|
|
@ -682,7 +682,7 @@
|
||||||
inline_until_char = DialectHelpers.inline_until_char;
|
inline_until_char = DialectHelpers.inline_until_char;
|
||||||
|
|
||||||
// A robust regexp for matching URLs. Thakns: https://gist.github.com/dperini/729294
|
// A robust regexp for matching URLs. Thakns: https://gist.github.com/dperini/729294
|
||||||
var urlRegexp = /(?:(?:https?|ftp):\/\/)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?/i.source;
|
var urlRegexp = /(?:(?:https?|ftp):\/\/)(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?/i.source;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gruber dialect
|
* Gruber dialect
|
||||||
|
@ -1226,8 +1226,11 @@
|
||||||
//
|
//
|
||||||
// First attempt to use a strong URL regexp to catch things like parentheses. If it misses, use the
|
// First attempt to use a strong URL regexp to catch things like parentheses. If it misses, use the
|
||||||
// old one.
|
// old one.
|
||||||
var m = text.match(new RegExp("^!\\[(.*?)][ \\t]*\\((" + urlRegexp + ")\\)([ \\t])*([\"'].*[\"'])?")) ||
|
var origMatcher = /^!\[(.*?)\][ \t]*\([ \t]*([^")]*?)(?:[ \t]+(["'])(.*?)\3)?[ \t]*\)/;
|
||||||
text.match( /^!\[(.*?)\][ \t]*\([ \t]*([^")]*?)(?:[ \t]+(["'])(.*?)\3)?[ \t]*\)/ );
|
m = text.match(new RegExp("^!\\[(.*?)][ \\t]*\\((" + urlRegexp + ")\\)([ \\t])*([\"'].*[\"'])?")) ||
|
||||||
|
text.match(origMatcher);
|
||||||
|
|
||||||
|
if (m && m[2].indexOf(")]") !== -1) { m = text.match(origMatcher); }
|
||||||
|
|
||||||
if ( m ) {
|
if ( m ) {
|
||||||
if ( m[2] && m[2][0] === "<" && m[2][m[2].length-1] === ">" )
|
if ( m[2] && m[2][0] === "<" && m[2][m[2].length-1] === ">" )
|
||||||
|
|
Loading…
Reference in New Issue