| MojoMojo documentation | Contained in the MojoMojo distribution. |
MojoMojo::Formatter::WikipediaLink - Linked Wikipedia by writing {{wikipedia:<lang> <word>}}
Normally, to hyperlink to the Wikipedia, you'd write:
[wikipedia Hello](http://en.wikipedia.org/wiki/Hello)
This plugin lets you write just
{{wikipedia Hello}}
not just Link to Wikipedia in English page, you can use many languages
{{wikipedia:ja こんにちは}}
{{wikipedia:fr Salut}}
Actually, if you wrote this without a language ex.{{wikipedia Foo}}, select location of Wikipedia Link is getting default-language setting of MojoMojo.
The WikipediaLink formatter has no special requirements in terms of the order it gets run in, so it has a priority of 17.
Calls the formatter. Takes a ref to the content as well as the context object.
Here the actual formatting is done.
Dai Okabayashi, bayashi at cpan . org
This library is free software. You can redistribute it and/or modify it under the same terms as Perl itself.
| MojoMojo documentation | Contained in the MojoMojo distribution. |
package MojoMojo::Formatter::WikipediaLink; use strict; use warnings; use parent qw/MojoMojo::Formatter/;
sub format_content_order { 17 }
sub format_content { my ( $class, $content, $c ) = @_; my @lines = split /\n/, $$content; $$content = ''; my $re = $class->gen_re( qr/[wW]ikipedia(?::([^\s]+))?\s+(.+)/ ); my $lang = $c->sessionid ? $c->session->{lang} : $c->pref('default_lang') || 'en'; for my $line (@lines) { if ( $line =~ m/$re/ ) { $line = $class->process($c, $line, $re, $lang); } $$content .= $line . "\n"; } }
sub process { my $class = shift; my ($c, $line, $re, $lang) = @_; $line =~ m/$re/; my $wikipedia_lang = $1 || $c->pref('default_lang') || 'en'; my $keyword = $2; my $uri = URI->new("http://$wikipedia_lang.wikipedia.org/"); $uri->path("/wiki/$keyword"); $line =~ s!$re!<a href="$uri">$keyword</a>!; $c->stash->{precompile_off} = 1; return $line; }
1;