ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/bin/pod2wiki
(Generate patch)

Comparing deliantra/Deliantra-Client/bin/pod2wiki (file contents):
Revision 1.3 by root, Sun Aug 13 18:48:57 2006 UTC vs.
Revision 1.14 by root, Sun Mar 30 10:18:16 2008 UTC

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
6my $ARCH = "/root/devel/cvs/cf.schmorp.de/arch";
7
8use strict;
9
3use Storable; 10use Storable;
4
5# convert given .pod files to wiki style
6
7use strict;
8
9use Pod::POM; 11use Pod::POM;
10 12
11our @result; 13our @result;
12our $indent; 14our $indent;
13our $level; 15our $level;
35 s/\s+/ /g; 37 s/\s+/ /g;
36 38
37 $_ 39 $_
38} 40}
39 41
42sub special {
43 $MA_BEG . (join $MA_SEP, @_) . $MA_END
44}
45
40package AsParagraphs; 46package AsParagraphs;
41 47
42use strict; 48use strict;
43 49
44use base "Pod::POM::View"; 50use base "Pod::POM::View";
51
52# nodes (order must stay as it is)
53sub N_PARENT (){ 0 }
54sub N_PAR (){ 1 }
55sub N_LEVEL (){ 2 }
56sub N_KW (){ 3 }
57sub N_DOC (){ 4 }
58
59# paragraphs (order must stay as it is)
60sub P_INDENT (){ 0 }
61sub P_LEVEL (){ 1 }
62sub P_MARKUP (){ 2 }
63sub P_INDEX (){ 3 }
45 64
46*view_seq_file = 65*view_seq_file =
47*view_seq_code = 66*view_seq_code =
48*view_seq_bold = sub { "<b>$_[1]</b>" }; 67*view_seq_bold = sub { "<b>$_[1]</b>" };
49*view_seq_italic = sub { "<i>$_[1]</i>" }; 68*view_seq_italic = sub { "<i>$_[1]</i>" };
50*view_seq_zero = sub { }; 69*view_seq_zero = sub { };
51*view_seq_space = sub { my $text = $_[1]; $text =~ s/ /&#160;/g; $text }; 70*view_seq_space = sub { my $text = $_[1]; $text =~ s/ /&#160;/g; $text };
52*view_seq_index = sub { push @{ $result[-1]{index} }, $_[1]; "" }; 71*view_seq_index = sub { push @{ $result[-1][P_INDEX] }, $_[1]; "" };
53 72
54sub view_seq_text { 73sub view_seq_text {
55 my $text = $_[1]; 74 my $text = $_[1];
56 $text =~ s/\s+/ /g; 75 $text =~ s/\s+/ /g;
57 ::asxml $text 76 ::asxml $text
58} 77}
59 78
60sub view_seq_link { 79sub view_seq_link {
61 my (undef, $link) = @_; 80 my (undef, $link) = @_;
62 81
82 my $text = $link =~ s/^(.*)\|// ? $1 : $link;
83
63 if ($link =~ /http:/) { 84 if ($link =~ /http:/) {
64 "<u>" . (::asxml $link) . "</u>" 85 "<u>" . (::asxml $link) . "</u>"
86 } elsif ($link =~ /^\$ARCH\/(.+)$/) {
87 my $path = $1;
88 (my $base = $path) =~ s/.*\///;
89 -f "$ARCH/$path" && system "rsync -av -c \Q$ARCH/$path\E \Qresources/arch/$base";
90 ::special image => "arch/$base", 1;
65 } else { 91 } else {
66 "${MA_BEG}link${MA_SEP}$link$MA_END" 92 ::special link => $text, $link
67 }
68}
69
70sub view_item {
71 push @result, {
72 indent => $indent * 8,
73 level => $level,
74 }; 93 }
75 my $title = $_[1]->title->present ($_[0]);
76 $result[-1]{markup} = "$title\n\n" if length $title;
77 $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title;
78 local $level = $level + 1;
79 $_[1]->content->present ($_[0]);
80 ()
81} 94}
82 95
83sub view_verbatim { 96sub view_verbatim {
84 push @result, { 97 push @result, [ $indent * 16, $level, "<tt>" . (::asxml $_[1]) . "</tt>\n" ];
85 indent => $indent * 16,
86 level => $level,
87 markup => "<tt>" . (::asxml $_[1]) . "</tt>\n",
88 };
89 () 98 ()
90} 99}
91 100
92sub view_textblock { 101sub view_textblock {
93 push @result, { 102 push @result, [ $indent * 16, $level, "$_[1]\n" ];
94 indent => $indent * 16,
95 level => $level,
96 markup => "$_[1]\n",
97 };
98 () 103 ()
99} 104}
100 105
101sub view_head1 { 106sub view_head1 {
102 push @result, { 107 push @result, [ $indent * 16, $level ];
103 indent => $indent * 16,
104 level => $level,
105 };
106 my $title = $_[1]->title->present ($_[0]); 108 my $title = $_[1]->title->present ($_[0]);
107 $result[-1]{markup} = "\n\n<span foreground='#ffff00' size='x-large'>$title</span>\n" if length $title; 109 $result[-1][P_MARKUP] = "\n\n<span foreground='#ffff00' size='x-large'>$title</span>\n" if length $title;
108 $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title; 110 $title = ::flatten $title; unshift @{ $result[-1][P_INDEX] }, $title if length $title;
109 local $level = $level + 1; 111 local $level = $level + 1;
110 $_[1]->content->present ($_[0]); 112 $_[1]->content->present ($_[0]);
111 () 113 ()
112}; 114};
113 115
114sub view_head2 { 116sub view_head2 {
115 push @result, { 117 push @result, [ $indent * 16, $level ];
116 indent => $indent * 16,
117 level => $level,
118 };
119 my $title = $_[1]->title->present ($_[0]); 118 my $title = $_[1]->title->present ($_[0]);
120 $result[-1]{markup} = "\n\n<span foreground='#ccccff' size='large'>$title</span>\n" if length $title; 119 $result[-1][P_MARKUP] = "\n\n<span foreground='#ccccff' size='large'>$title</span>\n" if length $title;
121 $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title; 120 $title = ::flatten $title; unshift @{ $result[-1][P_INDEX] }, $title if length $title;
122 local $level = $level + 1; 121 local $level = $level + 1;
123 $_[1]->content->present ($_[0]); 122 $_[1]->content->present ($_[0]);
124 () 123 ()
125}; 124};
126 125
127sub view_head3 { 126sub view_head3 {
128 push @result, { 127 push @result, [ $indent * 16, $level ];
129 indent => $indent * 16,
130 level => $level,
131 };
132 my $title = $_[1]->title->present ($_[0]); 128 my $title = $_[1]->title->present ($_[0]);
133 $result[-1]{markup} = "\n\n<span size='large'>$title</span>\n" if length $title; 129 $result[-1][P_MARKUP] = "\n\n<span size='large'>$title</span>\n" if length $title;
134 $title = ::flatten $title; unshift @{ $result[-1]{index} }, $title if length $title; 130 $title = ::flatten $title; unshift @{ $result[-1][P_INDEX] }, $title if length $title;
135 local $level = $level + 1; 131 local $level = $level + 1;
136 $_[1]->content->present ($_[0]); 132 $_[1]->content->present ($_[0]);
137 () 133 ()
138}; 134};
139 135
140sub view_over { 136sub view_over {
141 local $indent = $indent + $_[1]->indent; 137 local $indent = $indent + $_[1]->indent;
142 push @result, { indent => $indent }; 138 push @result, [ $indent, $level ];
139 $_[1]->content->present ($_[0]);
140 ()
141}
142
143sub view_item {
144 push @result, [ $indent * 8, $level ];
145 my $title = $_[1]->title->present ($_[0]);
146 $result[-1][P_MARKUP] = "$title\n" if length $title;
147 $title = ::flatten $title; unshift @{ $result[-1][P_INDEX] }, $title if length $title;
148 local $level = $level + 1;
143 $_[1]->content->present ($_[0]); 149 $_[1]->content->present ($_[0]);
144 () 150 ()
145} 151}
146 152
147sub view_for { 153sub view_for {
148 if ($_[1]->format eq "image") { 154 if ($_[1]->format eq "image") {
149 push @result, { 155 push @result, [
150 indent => $indent * 16, 156 $indent * 16,
151 level => $level, 157 $level,
152 markup => "${MA_BEG}image${MA_SEP}pod/" . $_->text . $MA_END, 158 (::special image => "pod/" . $_->text),
153 }; 159 ];
154 } 160 }
161 ()
162}
163
164sub view_begin {
155 () 165 ()
156} 166}
157 167
158sub view { 168sub view {
159 my ($self, $type, $item) = @_; 169 my ($self, $type, $item) = @_;
165 175
166sub as_paragraphs($) { 176sub as_paragraphs($) {
167 my ($pom) = @_; 177 my ($pom) = @_;
168 178
169 local $indent = 0; 179 local $indent = 0;
170 local $level = 1; 180 local $level = 2;
171 local @result = ( { } ); 181 local @result = ( [] );
172 182
173 $pom->present ("AsParagraphs"); 183 $pom->present ("AsParagraphs");
174 184
175 [grep $_->{index} || exists $_->{markup}, @result] 185 [grep $_->[P_INDEX] || defined $_->[P_MARKUP], @result]
176} 186}
177 187
178############################################################################# 188#############################################################################
179 189
180my %wiki; 190my %wiki;
181 191
182sub add_node($) { 192sub add_node($) {
183 my ($node) = @_; 193 my ($node) = @_;
184 194
185 for (@{ $node->{kw} || {} }) { 195 for (@{ $node->[N_KW] || {} }) {
186 push @{$wiki{$_}}, $node; 196 push @{$wiki{lc $_}}, $node;
187 } 197 }
188} 198}
189 199
190my $root = { 200my $root;
191 kw => ["pod"], 201$root->[N_KW] = ["pod"];
192};
193 202
194for my $path (@ARGV) { 203for my $path (@ARGV) {
195 $path =~ /([^\/\\]+)\.pod$/ or die "$path: illegal pathname"; 204 $path =~ /([^\/\\]+)\.pod$/ or die "$path: illegal pathname";
196 my $base = $1; 205 my $base = $1;
197 my $pom = Pod::POM->new->parse_text (do { 206 my $pom = Pod::POM->new->parse_text (do {
201 <$pod> 210 <$pod>
202 }); 211 });
203 212
204 my $para = as_paragraphs $pom; 213 my $para = as_paragraphs $pom;
205 214
215 my $pod;
216 $pod->[N_PARENT] = $root;
217 $pod->[N_PAR] = 0;
218 $pod->[N_LEVEL] = 1;
219 $pod->[N_KW] = [$base];
220 $pod->[N_DOC] = $para;
221
206 my @parent = ( 222 my @parent = ($pod);
207 { parent => $root, kw => [$base], doc => $para, par => 0, level => 0 },
208 );
209 add_node $parent[-1];
210 223
211 for my $idx (0 .. $#$para) { 224 for my $idx (0 .. $#$para) {
212 my $par = $para->[$idx]; 225 my $par = $para->[$idx];
213 226
214 while ($parent[-1]{level} >= $par->{level}) { 227 while ($parent[-1][N_LEVEL] >= $par->[P_LEVEL]) {
215 pop @parent; 228 pop @parent;
216 } 229 }
217 230
218 if ($par->{index}) { 231 if ($par->[P_INDEX]) {
219 my $node = { 232 my $node;
220 kw => $par->{index}, 233 $node->[N_PARENT] = $parent[-1];
221 parent => $parent[-1], 234 $node->[N_PAR] = $idx;
222 doc => $para, 235 $node->[N_LEVEL] = $par->[P_LEVEL];
223 par => $idx, 236 $node->[N_KW] = $par->[P_INDEX];
224 level => $par->{level}, 237 $node->[N_DOC] = $para;
225 };
226 push @parent, $node; 238 push @parent, $node;
227 add_node $node; 239 add_node $node;
228 } 240 }
229 } 241 }
242
243 add_node $pod;
230} 244}
245
246add_node $root;
231 247
232Storable::nstore \%wiki, "docwiki.pst"; 248Storable::nstore \%wiki, "docwiki.pst";
233 249

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines