ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/www/generate
Revision: 1.7
Committed: Sun Sep 16 07:57:19 2007 UTC (16 years, 10 months ago) by pippijn
Branch: MAIN
Changes since 1.6: +5 -0 lines
Log Message:
oops

File Contents

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