… | |
… | |
13 | use base "Pod::POM::View"; |
13 | use base "Pod::POM::View"; |
14 | |
14 | |
15 | sub asxml($) { |
15 | sub asxml($) { |
16 | local $_ = $_[0]; |
16 | local $_ = $_[0]; |
17 | |
17 | |
18 | s/&/&/g; |
|
|
19 | s/>/>/g; |
|
|
20 | s/</</g; |
18 | s/</E<lt>/g; |
|
|
19 | s/>/E<gt>/g; |
21 | |
20 | |
22 | $_ |
21 | $_ |
23 | } |
22 | } |
24 | |
23 | |
25 | sub flatten($) { |
24 | sub flatten($) { |
… | |
… | |
33 | $_ |
32 | $_ |
34 | } |
33 | } |
35 | |
34 | |
36 | *view_seq_file = |
35 | *view_seq_file = |
37 | *view_seq_code = |
36 | *view_seq_code = |
38 | *view_seq_bold = sub { "<b>$_[1]</b>" }; |
37 | *view_seq_bold = sub { "B<$_[1]>" }; |
39 | *view_seq_italic = sub { "<i>$_[1]</i>" }; |
38 | *view_seq_italic = sub { "I<$_[1]>" }; |
40 | *view_seq_zero = sub { }; |
39 | *view_seq_zero = sub { }; |
41 | *view_seq_space = sub { my $text = $_[1]; $text =~ s/ /\xa0/g; $text }; |
40 | *view_seq_space = sub { my $text = $_[1]; $text =~ s/ /\xa0/g; $text }; |
42 | *view_seq_index = sub { push @{ $result[-1]{index} }, $_[1]; "" }; |
41 | *view_seq_index = sub { push @{ $result[-1]{index} }, $_[1]; "" }; |
43 | |
42 | |
44 | sub view_seq_text { |
43 | sub view_seq_text { |
… | |
… | |
51 | my (undef, $link) = @_; |
50 | my (undef, $link) = @_; |
52 | |
51 | |
53 | my $text = $link =~ s/^(.*)\|// ? $1 : $link; |
52 | my $text = $link =~ s/^(.*)\|// ? $1 : $link; |
54 | |
53 | |
55 | if ($link =~ /http:/) { |
54 | if ($link =~ /http:/) { |
56 | "<u>" . (asxml $link) . "</u>" |
55 | "U<" . (asxml $link) . ">" |
57 | } else { |
56 | } else { |
58 | () |
57 | () |
59 | } |
58 | } |
60 | } |
59 | } |
61 | |
60 | |
… | |
… | |
76 | sub view_verbatim { |
75 | sub view_verbatim { |
77 | push @result, { |
76 | push @result, { |
78 | type => "verbatim", |
77 | type => "verbatim", |
79 | indent => $indent * 16, |
78 | indent => $indent * 16, |
80 | level => $level, |
79 | level => $level, |
81 | markup => asxml $_[1], |
80 | markup => $_[1], |
82 | }; |
81 | }; |
83 | () |
82 | () |
84 | } |
83 | } |
85 | |
84 | |
86 | sub view_textblock { |
85 | sub view_textblock { |
87 | push @result, { |
86 | push @result, { |
88 | indent => $indent * 16, |
87 | indent => $indent * 16, |
89 | level => $level, |
88 | level => $level, |
90 | markup => "$_[1]\n", |
89 | markup => flatten $_[1], |
91 | }; |
90 | }; |
92 | () |
91 | () |
93 | } |
92 | } |
94 | |
93 | |
95 | sub view_head1 { |
94 | sub view_head1 { |
… | |
… | |
183 | |
182 | |
184 | sub load_pod($) { |
183 | sub load_pod($) { |
185 | my ($path) = @_; |
184 | my ($path) = @_; |
186 | |
185 | |
187 | Coro::Storable::thaw cf::cache "cf::pod::as_paragraphs/$path" => [$path], |
186 | Coro::Storable::thaw cf::cache "cf::pod::as_paragraphs/$path" => [$path], |
188 | 1 => sub { |
187 | 3 => sub { |
189 | my ($src) = @_; |
188 | my ($src) = @_; |
|
|
189 | |
190 | cf::fork_call { |
190 | cf::fork_call { |
191 | my $pod = $src->[0]; |
191 | my $pod = $src->[0]; |
192 | utf8::decode $pod; |
192 | utf8::decode $pod; |
193 | Coro::Storable::freeze pom_as_paragraphs +(Pod::POM->new->parse_text ($pod)) |
193 | Coro::Storable::blocking_nfreeze pom_as_paragraphs +(Pod::POM->new->parse_text ($pod)) |
194 | } |
194 | } |
195 | }; |
195 | }; |
196 | } |
196 | } |
197 | |
197 | |
|
|
198 | # format as cfpod-style text |
|
|
199 | sub as_cfpod($) { |
|
|
200 | my ($pars) = @_; |
|
|
201 | |
|
|
202 | my $res; |
|
|
203 | |
|
|
204 | for my $par (@$pars) { |
|
|
205 | if ($par->{type} =~ /^head\d+$/) { |
|
|
206 | $res .= "B<$par->{markup}>\n\n"; |
|
|
207 | } elsif ($par->{type} eq "verbatim") { |
|
|
208 | $res .= "\n$par->{markup}\n\n"; |
|
|
209 | } elsif ($par->{type} eq "item") { |
|
|
210 | $res .= "\n* I<$par->{markup}>\n\n"; |
|
|
211 | } else { |
|
|
212 | $res .= "$par->{markup}\n\n"; |
|
|
213 | } |
|
|
214 | } |
|
|
215 | |
|
|
216 | $res |
|
|
217 | } |
|
|
218 | |
198 | 1; |
219 | 1; |
199 | |
220 | |