1: #!/usr/bin/perl -w
2:
3: =pod
4:
5: =NAME
6:
7: generate_web_pages.pl - generate the web pages for the install site
8:
9: =SYNOPSIS
10:
11: Yeah, it does that.
12:
13: Basically, there's a few comments in shell.html that we replace with
14: what we really want in the files. Pretty simple.
15:
16: The point of this is to look like the main site.
17:
18: =cut
19:
20: # This is the list of pages to generate: Change this to
21: # add/subtract/etc. pages. Index is done seperately.
22: # Title, source
23:
24: my @pages = (
25: # ['Red Hat 7.3 Install', 'rh73'],
26: # ['Fedora Install', 'fedora_install'],
27: ['Fedora Core 3 Install', 'FC3_install'],
28: ['Fedora Core 4 Install', 'FC4_install'],
29: ['Red Hat Enterprise Linux 4 Install','RHEL4_install'],
30: ['SuSE Linux Professional 9.2 Install', 'suse9.2_install'],
31: # ['Manual Install from Tarballs', 'manual_install'],
32: ['Upgrading from Previous LON-CAPA install', 'upgrade'],
33: ['Post-installation Configuration', 'config'],
34: ['LON-CAPA License (Gnu Public License)', 'license']
35: );
36: my @other_pages = (
37: ['Developer Infomation', 'dev']
38: );
39:
40: open SHELL, '<', "shell.html";
41: my $shell = join '', <SHELL>;
42: $shell =~ s/\r/\n/g;
43:
44: # Call with: The title, breadcrumb, and content
45: sub replaceText {
46: my ($title, $breadcrumb, $content) = @_;
47:
48: my $page = $shell;
49: $page =~ s/\<!-- *title *--\>/$title/g;
50: $page =~ s/\<!-- *breadcrumb *--\>/$breadcrumb/g;
51: $page =~ s/\<!-- *content *--\>/$content/g;
52:
53: return $page;
54: }
55:
56: # Do the index page
57:
58: open INDEX, '>', "index.html";
59: my $content = <<PRELUDE;
60: <p>LON-CAPA is based upon a lot of Open Source modules, so it's important
61: to have the right environment on your computer. Since it will frequently
62: be the case that LON-CAPA will be going onto a dedicated machine, we've
63: included instructions for installing LON-CAPA concurrently with new
64: installations of some of the popular Linux distributions.</p>
65:
66: <p>A tarball installation is also available for those who wish to
67: install on other distributions. Currently, Apache 1.x is required;
68: LON-CAPA does not yet run on 2.0.</p>
69:
70: <p>For all distributions, please see how to
71: <a href="config.html">configure the server after installation</a>.</p>
72: <hr />
73: PRELUDE
74:
75: $content .= "<ul>\n";
76: for (@pages) {
77: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
78: }
79:
80: $content .= "</ul>\n";
81:
82: $content .= <<'POSTLUDE';
83: <hr />
84: <a name="download" />
85: <h3>Downloading LON-CAPA</h3>
86:
87: <p>
88: <b>Current Production Release is Version LATESTVERSION.
89: This version was released on LATESTDATE.</b>
90: </p>
91: <p>
92: You can download the <b>most current production version of LON-CAPA</b> at
93: <a href="http://install.lon-capa.org/versions/loncapa-current.tar.gz">
94: http://install.lon-capa.org/versions/loncapa-current.tar.gz</a>
95: (version LATESTVERSION).
96: </p>
97: TESTINGRELEASE_START
98: <p>
99: <b>Current Testing Release is Version LATESTTESTINGVERSION.
100: This version was released on LATESTTESTINGDATE.</b>
101: </p>
102: <p>
103: You can download the <b>testing version of the upcoming LON-CAPA</b> at
104: <a href="http://install.lon-capa.org/versions/loncapa-testing.tar.gz">
105: http://install.lon-capa.org/versions/loncapa-testing.tar.gz</a>
106: (version LATESTTESTINGVERSION).
107: </p>
108: TESTINGRELEASE_END
109:
110: <hr />
111: POSTLUDE
112:
113: $content .= "<ul>\n";
114: for (@other_pages) {
115: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
116: }
117:
118: $content .= "</ul>\n";
119:
120: my $index = replaceText("Install LON-CAPA", "Install LON-CAPA",
121: $content);
122:
123: print INDEX $index;
124: close INDEX;
125:
126: # Build the pages
127: for (@pages,@other_pages) {
128: my ($title, $source) = @$_;
129:
130: # read in content
131: open SOURCE, '<', $source.'.frag';
132: $content = join '', <SOURCE>;
133: close SOURCE;
134:
135: $content = replaceText($title, '<a href="/">Install LON-CAPA</a> > ' . $title,
136: $content);
137: open DEST, '>', $source.'.html';
138: print DEST $content;
139: close DEST;
140: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>