user/dev discussion of public-inbox itself
 help / color / mirror / code / Atom feed
* [PATCH] linkify: be stricter about matching RFC 3986
@ 2016-08-18  2:04 Eric Wong
  0 siblings, 0 replies; only message in thread
From: Eric Wong @ 2016-08-18  2:04 UTC (permalink / raw)
  To: meta

We're not to-the-letter about percent-encoding, but
we should allow all the characters.  This is mainly
so we can effectively use the link to some Wikipedia
pages with parentheses in them:

	https://en.wikipedia.org/wiki/Atom_(standard)
	https://en.wikipedia.org/wiki/Git_(software)
---
 lib/PublicInbox/Linkify.pm |  5 ++++-
 t/linkify.t                | 34 ++++++++++++++++++++++++++++++++++
 2 files changed, 38 insertions(+), 1 deletion(-)

diff --git a/lib/PublicInbox/Linkify.pm b/lib/PublicInbox/Linkify.pm
index d4df689..ea7fd71 100644
--- a/lib/PublicInbox/Linkify.pm
+++ b/lib/PublicInbox/Linkify.pm
@@ -17,7 +17,10 @@ use Digest::SHA qw/sha1_hex/;
 my $SALT = rand;
 my $LINK_RE = qr{\b((?:ftps?|https?|nntps?|gopher)://
 		 [\@:\w\.-]+/
-		 ?[!,:~\$\@\w\+\&\?\.\%\;/#=-]*)}x;
+		 (?:[a-z0-9\-\._~!\$\&\';\(\)\*\+,;=:@/%]*)
+		 (?:\?[a-z0-9\-\._~!\$\&\';\(\)\*\+,;=:@/%]+)?
+		 (?:\#[a-z0-9\-\._~!\$\&\';\(\)\*\+,;=:@/%\?]+)?
+		 )}xi;
 
 sub new { bless {}, shift }
 
diff --git a/t/linkify.t b/t/linkify.t
index 586691a..49cbbd6 100644
--- a/t/linkify.t
+++ b/t/linkify.t
@@ -23,4 +23,38 @@ use PublicInbox::Linkify;
 	is($s, qq(<a\nhref="$u">$u</a>;), 'trailing semicolon not in URL');
 }
 
+{
+	my $l = PublicInbox::Linkify->new;
+	my $u = 'http://example.com/url-with-(parens)';
+	my $s = "hello $u world";
+	$s = $l->linkify_1($s);
+	$s = $l->linkify_2($s);
+	is($s, qq(hello <a\nhref="$u">$u</a> world), 'URL preserved');
+
+	$u .= "?query=a";
+	$s = "hello $u world";
+	$s = $l->linkify_1($s);
+	$s = $l->linkify_2($s);
+	is($s, qq(hello <a\nhref="$u">$u</a> world), 'query preserved');
+
+	$u .= "#fragment";
+	$s = "hello $u world";
+	$s = $l->linkify_1($s);
+	$s = $l->linkify_2($s);
+	is($s, qq(hello <a\nhref="$u">$u</a> world),
+	  'query + fragment preserved');
+
+	$u = "http://example.com/";
+	$s = "hello $u world";
+	$s = $l->linkify_1($s);
+	$s = $l->linkify_2($s);
+	is($s, qq(hello <a\nhref="$u">$u</a> world), "root URL preserved");
+
+	$u = "http://example.com/#fragment";
+	$s = "hello $u world";
+	$s = $l->linkify_1($s);
+	$s = $l->linkify_2($s);
+	is($s, qq(hello <a\nhref="$u">$u</a> world), "root + fragment");
+}
+
 done_testing();
-- 
EW


^ permalink raw reply related	[flat|nested] only message in thread

only message in thread, other threads:[~2016-08-18  2:04 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-08-18  2:04 [PATCH] linkify: be stricter about matching RFC 3986 Eric Wong

Code repositories for project(s) associated with this public inbox

	https://80x24.org/public-inbox.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).