force list context
[ikiwiki] / IkiWiki / Plugin / txt.pm
1 #!/usr/bin/perl
2 # .txt as a wiki page type - links WikiLinks and URIs.
3 #
4 # Copyright (C) 2008 Gabriel McManus <gmcmanus@gmail.com>
5 # Licensed under the GNU General Public License, version 2 or later
6
7 package IkiWiki::Plugin::txt;
8
9 use warnings;
10 use strict;
11 use IkiWiki 3.00;
12 use HTML::Entities;
13
14 my $findurl=0;
15
16 sub import {
17         hook(type => "getsetup", id => "txt", call => \&getsetup);
18         hook(type => "filter", id => "txt", call => \&filter);
19         hook(type => "htmlize", id => "txt", call => \&htmlize);
20
21         eval q{use URI::Find};
22         if (! $@) {
23                 $findurl=1;
24         }
25 }
26
27 sub getsetup () {
28         return
29                 plugin => {
30                         safe => 1,
31                         rebuild => 1, # format plugin
32                         section => "format",
33                 },
34 }
35
36 # We use filter to convert raw text to HTML
37 # (htmlize is called after other plugins insert HTML)
38 sub filter (@) {
39         my %params = @_;
40         my $content = $params{content};
41
42         if (defined $pagesources{$params{page}} &&
43             $pagesources{$params{page}} =~ /\.txt$/) {
44                 if ($pagesources{$params{page}} eq 'robots.txt' &&
45                     $params{page} eq $params{destpage}) {
46                         will_render($params{page}, 'robots.txt');
47                         writefile('robots.txt', $config{destdir}, $content);
48                 }
49
50                 encode_entities($content, "<>&");
51                 if ($findurl) {
52                         my $finder = URI::Find->new(sub {
53                                 my ($uri, $orig_uri) = @_;
54                                 return qq|<a href="$uri">$orig_uri</a>|;
55                         });
56                         $finder->find(\$content);
57                 }
58                 $content = "<pre>" . $content . "</pre>";
59         }
60
61         return $content;
62 }
63
64 # We need this to register the .txt file extension
65 sub htmlize (@) {
66         my %params=@_;
67         return $params{content};
68 }
69
70 1