1 | #! perl |
1 | #! perl |
2 | |
2 | |
|
|
3 | # convert given .pod files to wiki style |
|
|
4 | |
|
|
5 | # base path of arch tree, only used for new arch graphics |
|
|
6 | my $ARCH = "/root/devel/cvs/cf.schmorp.de/arch"; |
|
|
7 | |
|
|
8 | use strict; |
|
|
9 | |
3 | use Storable; |
10 | use Storable; |
4 | |
|
|
5 | # convert given .pod files to wiki style |
|
|
6 | |
|
|
7 | use strict; |
|
|
8 | |
|
|
9 | use Pod::POM; |
11 | use Pod::POM; |
10 | |
12 | |
11 | our @result; |
13 | our @result; |
12 | our $indent; |
14 | our $indent; |
13 | our $level; |
15 | our $level; |
… | |
… | |
33 | s/^\s+//; |
35 | s/^\s+//; |
34 | s/\s+$//; |
36 | s/\s+$//; |
35 | s/\s+/ /g; |
37 | s/\s+/ /g; |
36 | |
38 | |
37 | $_ |
39 | $_ |
|
|
40 | } |
|
|
41 | |
|
|
42 | sub special { |
|
|
43 | $MA_BEG . (join $MA_SEP, @_) . $MA_END |
38 | } |
44 | } |
39 | |
45 | |
40 | package AsParagraphs; |
46 | package AsParagraphs; |
41 | |
47 | |
42 | use strict; |
48 | use strict; |
… | |
… | |
58 | } |
64 | } |
59 | |
65 | |
60 | sub view_seq_link { |
66 | sub view_seq_link { |
61 | my (undef, $link) = @_; |
67 | my (undef, $link) = @_; |
62 | |
68 | |
|
|
69 | my $text = $link =~ s/^(.*)\|// ? $1 : $link; |
|
|
70 | |
63 | if ($link =~ /http:/) { |
71 | if ($link =~ /http:/) { |
64 | "<u>" . (::asxml $link) . "</u>" |
72 | "<u>" . (::asxml $link) . "</u>" |
|
|
73 | } elsif ($link =~ /^\$ARCH\/(.+)$/) { |
|
|
74 | my $path = $1; |
|
|
75 | (my $base = $path) =~ s/.*\///; |
|
|
76 | -f "$ARCH/$path" && system "rsync -av -c \Q$ARCH/$path\E \Qresources/arch/$base"; |
|
|
77 | ::special image => "arch/$base", 1; |
65 | } else { |
78 | } else { |
66 | "${MA_BEG}link${MA_SEP}$link$MA_END" |
79 | ::special link => $text, $link |
67 | } |
80 | } |
68 | } |
81 | } |
69 | |
82 | |
70 | sub view_item { |
83 | sub view_item { |
71 | push @result, { |
84 | push @result, { |
72 | indent => $indent * 8, |
85 | indent => $indent * 8, |
73 | level => $level, |
86 | level => $level, |
74 | }; |
87 | }; |
75 | my $title = $_[1]->title->present ($_[0]); |
88 | my $title = $_[1]->title->present ($_[0]); |
76 | $result[-1]{markup} = "$title\n\n" if length $title; |
89 | $result[-1]{markup} = "$title\n" if length $title; |
77 | $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title; |
90 | $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title; |
78 | local $level = $level + 1; |
91 | local $level = $level + 1; |
79 | $_[1]->content->present ($_[0]); |
92 | $_[1]->content->present ($_[0]); |
80 | () |
93 | () |
81 | } |
94 | } |
… | |
… | |
147 | sub view_for { |
160 | sub view_for { |
148 | if ($_[1]->format eq "image") { |
161 | if ($_[1]->format eq "image") { |
149 | push @result, { |
162 | push @result, { |
150 | indent => $indent * 16, |
163 | indent => $indent * 16, |
151 | level => $level, |
164 | level => $level, |
152 | markup => "${MA_BEG}image${MA_SEP}pod/" . $_->text . $MA_END, |
165 | markup => (::special image => "pod/" . $_->text), |
153 | }; |
166 | }; |
154 | } |
167 | } |
155 | () |
168 | () |
156 | } |
169 | } |
157 | |
170 | |
… | |
… | |
181 | |
194 | |
182 | sub add_node($) { |
195 | sub add_node($) { |
183 | my ($node) = @_; |
196 | my ($node) = @_; |
184 | |
197 | |
185 | for (@{ $node->{kw} || {} }) { |
198 | for (@{ $node->{kw} || {} }) { |
186 | push @{$wiki{$_}}, $node; |
199 | push @{$wiki{lc $_}}, $node; |
187 | } |
200 | } |
188 | } |
201 | } |
189 | |
202 | |
190 | my $root = { |
203 | my $root = { |
191 | kw => ["pod"], |
204 | kw => ["pod"], |