]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blob - IkiWiki/Plugin/mdwn.pm
workaround a bug in the discount perl binding
[git.ikiwiki.info.git] / IkiWiki / Plugin / mdwn.pm
1 #!/usr/bin/perl
2 # Markdown markup language
3 package IkiWiki::Plugin::mdwn;
5 use warnings;
6 use strict;
7 use IkiWiki 3.00;
9 sub import {
10         hook(type => "getsetup", id => "mdwn", call => \&getsetup);
11         hook(type => "htmlize", id => "mdwn", call => \&htmlize, longname => "Markdown");
12 }
14 sub getsetup () {
15         return
16                 plugin => {
17                         safe => 1,
18                         rebuild => 1, # format plugin
19                         section => "format",
20                 },
21                 multimarkdown => {
22                         type => "boolean",
23                         example => 0,
24                         description => "enable multimarkdown features?",
25                         safe => 1,
26                         rebuild => 1,
27                 },
28 }
30 my $markdown_sub;
31 sub htmlize (@) {
32         my %params=@_;
33         my $content = $params{content};
35         if (! defined $markdown_sub) {
36                 # Markdown is forked and splintered upstream and can be
37                 # available in a variety of forms. Support them all.
38                 no warnings 'once';
39                 $blosxom::version="is a proper perl module too much to ask?";
40                 use warnings 'all';
42                 if (exists $config{multimarkdown} && $config{multimarkdown}) {
43                         eval q{use Text::MultiMarkdown};
44                         if ($@) {
45                                 debug(gettext("multimarkdown is enabled, but Text::MultiMarkdown is not installed"));
46                         }
47                         else {
48                                 $markdown_sub=sub {
49                                         Text::MultiMarkdown::markdown(shift, {use_metadata => 0});
50                                 }
51                         }
52                 }
53                 if (! defined $markdown_sub) {
54                         eval q{use Text::Markdown::Discount};
55                         if (! $@) {
56                                 $markdown_sub=sub {
57                                         # Workaround for discount binding bug
58                                         # https://rt.cpan.org/Ticket/Display.html?id=73657
59                                         return "" if $_[0]=~/^\s*$/;
60                                         Text::Markdown::Discount::markdown(@_);
61                                 }
62                         }
63                 }
64                 if (! defined $markdown_sub) {
65                         eval q{use Text::Markdown};
66                         if (! $@) {
67                                 if (Text::Markdown->can('markdown')) {
68                                         $markdown_sub=\&Text::Markdown::markdown;
69                                 }
70                                 else {
71                                         $markdown_sub=\&Text::Markdown::Markdown;
72                                 }
73                         }
74                         else {
75                                 eval q{use Markdown};
76                                 if (! $@) {
77                                         $markdown_sub=\&Markdown::Markdown;
78                                 }
79                                 else {
80                                         do "/usr/bin/markdown" ||
81                                                 error(sprintf(gettext("failed to load Markdown.pm perl module (%s) or /usr/bin/markdown (%s)"), $@, $!));
82                                         $markdown_sub=\&Markdown::Markdown;
83                                 }
84                         }
85                 }
86                 
87                 require Encode;
88         }
89         
90         # Workaround for perl bug (#376329)
91         $content=Encode::encode_utf8($content);
92         eval {$content=&$markdown_sub($content)};
93         if ($@) {
94                 eval {$content=&$markdown_sub($content)};
95                 print STDERR $@ if $@;
96         }
97         $content=Encode::decode_utf8($content);
99         return $content;