From 7716d940a0a916f59a3d64a5e606b26856e66806 Mon Sep 17 00:00:00 2001 From: Robin Ward Date: Thu, 20 Feb 2014 15:23:10 -0500 Subject: [PATCH] BUGFIX: Allow links to images with absolute URLs as well as parens --- test/javascripts/lib/markdown_test.js | 8 +++++++- vendor/assets/javascripts/better_markdown.js | 9 ++++++--- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/test/javascripts/lib/markdown_test.js b/test/javascripts/lib/markdown_test.js index 64f826c4aa4..74f1237b7d9 100644 --- a/test/javascripts/lib/markdown_test.js +++ b/test/javascripts/lib/markdown_test.js @@ -379,5 +379,11 @@ test("urlAllowed", function() { allowed("http://eviltrout.com/evil/trout", "allows full urls"); allowed("https://eviltrout.com/evil/trout", "allows https 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/)", + "

\"folksy

", + "It allows images with links around them"); }); diff --git a/vendor/assets/javascripts/better_markdown.js b/vendor/assets/javascripts/better_markdown.js index e9c02ef5bf0..fc1a9170123 100644 --- a/vendor/assets/javascripts/better_markdown.js +++ b/vendor/assets/javascripts/better_markdown.js @@ -682,7 +682,7 @@ inline_until_char = DialectHelpers.inline_until_char; // 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 @@ -1226,8 +1226,11 @@ // // First attempt to use a strong URL regexp to catch things like parentheses. If it misses, use the // old one. - var m = text.match(new RegExp("^!\\[(.*?)][ \\t]*\\((" + urlRegexp + ")\\)([ \\t])*([\"'].*[\"'])?")) || - text.match( /^!\[(.*?)\][ \t]*\([ \t]*([^")]*?)(?:[ \t]+(["'])(.*?)\3)?[ \t]*\)/ ); + var origMatcher = /^!\[(.*?)\][ \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[2] && m[2][0] === "<" && m[2][m[2].length-1] === ">" )