X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/ed4b6afc9b3b43e1f7e70ff01a77472c7983a549..a7d329c17312348d7511b48523fb54c18f8d4736:/IkiWiki/Plugin/camelcase.pm

diff --git a/IkiWiki/Plugin/camelcase.pm b/IkiWiki/Plugin/camelcase.pm
index 845a516ee..7881becd5 100644
--- a/IkiWiki/Plugin/camelcase.pm
+++ b/IkiWiki/Plugin/camelcase.pm
@@ -6,32 +6,56 @@ use warnings;
 use strict;
 use IkiWiki 2.00;
 
+# This regexp is based on the one in Text::WikiFormat.
+my $link_regexp=qr{
+	(?<![^A-Za-z0-9\s])	# try to avoid expanding non-links with a
+				# zero width negative lookbehind for
+				# characters that suggest it's not a link
+	\b			# word boundry
+	(
+		(?:
+			[A-Z]		# Uppercase start
+			[a-z0-9]	# followed by lowercase
+			\w*		# and rest of word
+		)
+		{2,}			# repeated twice
+	)
+}x;
+
 sub import { #{{{
-	hook(type => "filter", id => "camelcase", call => \&filter);
+	hook(type => "getsetup", id => "camelcase", call => \&getsetup);
+	hook(type => "linkify", id => "camelcase", call => \&linkify);
+	hook(type => "scan", id => "camelcase", call => \&scan);
 } # }}}
 
-sub filter (@) { #{{{
+sub getsetup () { #{{{
+	return
+		plugin => {
+			safe => 1,
+			rebuild => undef,
+		};
+} #}}}
+
+sub linkify (@) { #{{{
 	my %params=@_;
+	my $page=$params{page};
+	my $destpage=$params{destpage};
 
-	# Make CamelCase links work by promoting them to fullfledged
-	# WikiLinks. This regexp is based on the one in Text::WikiFormat.
-	$params{content}=~s{
-		(?<![^A-Za-z0-9\s])	# try to avoid expanding non-links
-					# with a zero width negative
-					# lookbehind for characters that
-					# suggest it's not a link
-		\b			# word boundry
-		(
-			(?:
-				[A-Z]		# Uppercase start
-				[a-z0-9]	# followed by lowercase
-				\w*		# and rest of word
-			)
-			{2,}			# repeated twice
-		)
-	}{[[$1]]}gx;
+	$params{content}=~s{$link_regexp}{
+		htmllink($page, $destpage, linkpage($1))
+	}eg;
 
 	return $params{content};
 } #}}}
 
+sub scan (@) { #{{{
+        my %params=@_;
+        my $page=$params{page};
+        my $content=$params{content};
+
+	while ($content =~ /$link_regexp/g) {
+		push @{$links{$page}}, linkpage($1);
+	}
+}
+
 1