1 |
#!/usr/bin/env perl |
2 |
|
3 |
use strict; |
4 |
use warnings; |
5 |
use utf8; |
6 |
|
7 |
use Pod::POM; |
8 |
use Template; |
9 |
use YAML; |
10 |
|
11 |
my $parser = new Pod::POM meta => 1; |
12 |
|
13 |
my ($pom, $html); |
14 |
|
15 |
$pom = $parser->parse ("src/news-archive.pod") |
16 |
or die $parser->error; |
17 |
$html = $pom->present ("PodHTML"); |
18 |
$html =~ s/\[/</g; |
19 |
$html =~ s/\]/>/g; |
20 |
open FH, ">", "src/news-archive.html"; |
21 |
print FH "News Archive\n\n"; |
22 |
print FH $html; |
23 |
close FH; |
24 |
|
25 |
$pom = $parser->parse ("src/news.pod") |
26 |
or die $parser->error; |
27 |
$html = $pom->present ("PodHTML"); |
28 |
open FH, ">", "html/news.html"; |
29 |
print FH $html; |
30 |
close FH; |
31 |
|
32 |
%PodRSS::metadata = %{ $pom->metadata }; |
33 |
$html = $pom->present ("PodRSS"); |
34 |
open FH, ">", "html/news.rss"; |
35 |
print FH $html; |
36 |
close FH; |
37 |
|
38 |
# Static variables |
39 |
my $static = YAML::LoadFile "variables.yml"; |
40 |
|
41 |
my @files = <src/*.html>; |
42 |
my @monsters = <monsters/*.html>; |
43 |
|
44 |
# Directory listings |
45 |
my $list; |
46 |
|
47 |
sub list { |
48 |
my ($a, $b) = @_; |
49 |
my $tmp = "<ul>\n"; |
50 |
|
51 |
my @listing = <$a/$b/*.html>; |
52 |
for (@listing) { |
53 |
my ($file) = $_ =~ /\/([^\/]+)$/; |
54 |
$tmp .= " <li><a href=\"$a/$b/$file\">$file</a><br/>\n "; |
55 |
$tmp .= do { local $/; open my $fh, "<$_.desc" or die "$_.desc: $!\n"; <$fh> }; |
56 |
$tmp .= " </li>\n"; |
57 |
} |
58 |
$tmp .= "</ul>\n"; |
59 |
$list->{$a}->{$b} = $tmp; |
60 |
} |
61 |
|
62 |
# Directory listings |
63 |
list "doc", "user"; |
64 |
list "doc", "development"; |
65 |
|
66 |
sub generate { |
67 |
my ($indir, $outdir, @list) = @_; |
68 |
|
69 |
for my $file (@list) { |
70 |
my @contents = do { open my $fh, "<$file" or die "$file: $!\n"; <$fh> }; |
71 |
my $subtitle = shift @contents; |
72 |
chomp $subtitle; |
73 |
|
74 |
my $curfile = $file; |
75 |
$curfile =~ s/$indir\/(.+\.html)$/$1/; |
76 |
|
77 |
my $tt = new Template { |
78 |
INTERPOLATE => 1, |
79 |
POST_CHOMP => 1, |
80 |
EVAL_PERL => 1, |
81 |
} or die "$Template::ERROR\n"; |
82 |
|
83 |
my $vars = { list => $list }; |
84 |
|
85 |
my $contents = "@contents"; |
86 |
my $data = ''; # Variable to store processed templates |
87 |
$tt->process (\$contents, $vars, \$data) |
88 |
or die $tt->error; |
89 |
|
90 |
# Re-initialised with static variables from YAML |
91 |
$vars = $static; |
92 |
$vars->{subtitle} = $subtitle; |
93 |
$vars->{contents} = $data; |
94 |
$vars->{curfile} = $curfile; |
95 |
|
96 |
my $output = ''; # Variable to store the complete page |
97 |
$tt->process ('template.html', $vars, \$output) |
98 |
or die $tt->error; |
99 |
|
100 |
# Save the page to a html file |
101 |
$file =~ s/$indir\/(.+\.html)$/$outdir\/$1/; |
102 |
open HTML, ">$file"; |
103 |
print HTML $output; |
104 |
close HTML; |
105 |
} |
106 |
} |
107 |
|
108 |
my @rightbar; |
109 |
push @rightbar, "src/images/monsters/$_.png" |
110 |
for @{ $static->{rightbar} }; |
111 |
my @leftbar; |
112 |
push @leftbar, "src/images/runes/$_.png" |
113 |
for @{ $static->{leftbar} }; |
114 |
|
115 |
generate "src", "html", @files; |
116 |
generate "monsters", "html\/monsters", @monsters; |
117 |
|
118 |
system "montage", "-background", "none", "+frame", "+shadow", "+label", "-geometry", "+0+0", "-tile", "1x15", @rightbar, "html/images/monsters-trans.png"; |
119 |
system "montage", "-background", "none", "+frame", "+shadow", "+label", "-geometry", "+0+0", "-tile", "1x15", @leftbar, "html/images/runes-trans.png"; |
120 |
|
121 |
package PodHTML; |
122 |
|
123 |
use strict; |
124 |
use warnings; |
125 |
use utf8; |
126 |
|
127 |
my $rcsid = '$Id: generate,v 1.16 2007-09-18 20:25:34 pippijn Exp $'; |
128 |
|
129 |
use base "Pod::POM::View"; |
130 |
|
131 |
our $subdir; |
132 |
our $dir; |
133 |
our $menu; |
134 |
|
135 |
sub view_pod { |
136 |
my ($self, $item) = @_; |
137 |
$item->content->present ($self) |
138 |
} |
139 |
|
140 |
sub view_head1 { |
141 |
my ($self, $item) = @_; |
142 |
$item->content->present ($self) |
143 |
} |
144 |
|
145 |
sub view_head2 { |
146 |
my ($self, $item) = @_; |
147 |
"<p><em><span class=\"date\">", $item->title, "</span> ", $item->content->present ($self), "</em></p>" |
148 |
} |
149 |
|
150 |
sub view_textblock { |
151 |
my ($self, $item) = @_; |
152 |
$item, "<br />" |
153 |
} |
154 |
|
155 |
sub view_seq_bold { |
156 |
my ($self, $item) = @_; |
157 |
"<b>$item</b>" |
158 |
} |
159 |
|
160 |
sub view_seq_file { |
161 |
my ($self, $item) = @_; |
162 |
"<tt>$item</tt>" |
163 |
} |
164 |
|
165 |
sub view_seq_link { |
166 |
my ($self, $item) = @_; |
167 |
my ($name, $href) = split /\|/, $item, 2; |
168 |
"<a href=\"$href\">$name</a>" |
169 |
} |
170 |
|
171 |
=head1 AUTHOR |
172 |
|
173 |
Copyright © 2007 Pippijn van Steenhoven |
174 |
|
175 |
=head1 LICENSE |
176 |
|
177 |
This library is free software, you can redistribute it and/or modify |
178 |
it under the terms of the GNU General Public License. |
179 |
|
180 |
=cut |
181 |
|
182 |
1; |
183 |
|
184 |
|
185 |
package PodRSS; |
186 |
|
187 |
use strict; |
188 |
use warnings; |
189 |
use utf8; |
190 |
|
191 |
use base "Pod::POM::View"; |
192 |
|
193 |
our %metadata; |
194 |
|
195 |
sub view_pod { |
196 |
my ($self, $item) = @_; |
197 |
"<?xml version='1.0' encoding='utf-8'?>\n" |
198 |
. "<rss version='2.0'>\n" |
199 |
. $item->content->present ($self) |
200 |
. "</rss>\n" |
201 |
} |
202 |
|
203 |
sub view_head1 { |
204 |
my ($self, $item) = @_; |
205 |
my $title = $item->title->present ($self); |
206 |
" <channel>\n", |
207 |
" <link>$metadata{link}</link>\n", |
208 |
" <language>$metadata{language}</language>\n", |
209 |
" <title>$title</title>\n", |
210 |
$item->content->present ($self), |
211 |
" </channel>\n" |
212 |
} |
213 |
|
214 |
sub view_head2 { |
215 |
my ($self, $item) = @_; |
216 |
my $title = $item->title->present ($self); |
217 |
" <item>\n", |
218 |
" <title>$title</title>\n", |
219 |
$item->content->present ($self), |
220 |
" </item>\n" |
221 |
} |
222 |
|
223 |
sub view_textblock { |
224 |
my ($self, $item) = @_; |
225 |
" <description><![CDATA[$item]]></description>\n" |
226 |
} |