2006-05-04 06:33:56 +02:00
|
|
|
#!/usr/bin/perl
|
|
|
|
package IkiWiki::Plugin::smiley;
|
|
|
|
|
|
|
|
use warnings;
|
|
|
|
use strict;
|
2007-04-27 04:55:52 +02:00
|
|
|
use IkiWiki 2.00;
|
2006-05-04 06:33:56 +02:00
|
|
|
|
|
|
|
my %smileys;
|
|
|
|
my $smiley_regexp;
|
|
|
|
|
|
|
|
sub import { #{{{
|
2007-08-28 03:59:01 +02:00
|
|
|
add_underlay("smiley");
|
2007-04-06 22:36:29 +02:00
|
|
|
hook(type => "filter", id => "smiley", call => \&filter);
|
2006-05-04 06:33:56 +02:00
|
|
|
} # }}}
|
|
|
|
|
2007-04-06 22:36:29 +02:00
|
|
|
sub build_regexp () { #{{{
|
2006-09-10 00:50:27 +02:00
|
|
|
my $list=readfile(srcfile("smileys.mdwn"));
|
2006-05-04 06:33:56 +02:00
|
|
|
while ($list =~ m/^\s*\*\s+\\([^\s]+)\s+\[\[([^]]+)\]\]/mg) {
|
|
|
|
$smileys{$1}=$2;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! %smileys) {
|
2007-04-06 22:36:29 +02:00
|
|
|
debug(gettext("failed to parse any smileys"));
|
|
|
|
$smiley_regexp='';
|
2006-05-04 06:33:56 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
# sort and reverse so that substrings come after longer strings
|
|
|
|
# that contain them, in most cases.
|
|
|
|
$smiley_regexp='('.join('|', map { quotemeta }
|
|
|
|
reverse sort keys %smileys).')';
|
2006-09-10 00:50:27 +02:00
|
|
|
#debug($smiley_regexp);
|
2006-05-04 06:33:56 +02:00
|
|
|
} #}}}
|
|
|
|
|
|
|
|
sub filter (@) { #{{{
|
|
|
|
my %params=@_;
|
|
|
|
|
2007-04-06 22:36:29 +02:00
|
|
|
build_regexp() unless defined $smiley_regexp;
|
2007-02-14 01:11:19 +01:00
|
|
|
$params{content} =~ s{(?:^|(?<=\s))(\\?)$smiley_regexp(?:(?=\s)|$)}{
|
2007-05-17 21:55:11 +02:00
|
|
|
$1 ? $2 : htmllink($params{page}, $params{destpage}, $smileys{$2}, linktext => $2)
|
2007-04-06 22:36:29 +02:00
|
|
|
}egs if length $smiley_regexp;
|
2007-02-14 01:11:19 +01:00
|
|
|
|
2006-05-04 06:33:56 +02:00
|
|
|
return $params{content};
|
|
|
|
} # }}}
|
|
|
|
|
|
|
|
1
|