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.hemp 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 @longlifecycle = (
25: ['CentOS Linux 5 Install','centos5_install'],
26: ['Scientific Linux 6 Install','scientific6_install'],
27: ['Scientific Linux 5 Install','scientific5_install'],
28: ['Red Hat Enterprise Linux 6 Install','RHEL6_install'],
29: ['Red Hat Enterprise Linux 5 Install','RHEL5_install'],
30: ['Red Hat Enterprise Linux 4 Install','RHEL4_install'],
31: ['SuSE Linux Enterprise Server 11 Install', 'sles11_install'],
32: ['SuSE Linux Enterprise Server 10 Install', 'sles10_install'],
33: ['SuSE Linux Enterprise Server 9 Install', 'sles9_install'],
34: );
35:
36: my @shortlifecycle = (
37: ['Fedora 15 Install', 'F15_install'],
38: ['Fedora 14 Install', 'F14_install'],
39: ['Fedora 13 Install', 'F13_install'],
40: ['Fedora 12 Install', 'F12_install'],
41: ['Fedora 11 Install', 'F11_install'],
42: ['Fedora 10 Install', 'F10_install'],
43: ['Fedora 9 Install', 'F9_install'],
44: ['SuSE Linux 11.4 Install', 'suse11.4_install'],
45: ['SuSE Linux 11.3 Install', 'suse11.3_install'],
46: ['SuSE Linux 11.2 Install', 'suse11.2_install'],
47: ['SuSE Linux 11.1 Install', 'suse11.1_install'],
48: );
49:
50: my @ancillary = (
51: ['Upgrading from Previous LON-CAPA install', 'upgrade'],
52: ['LON-CAPA License (Gnu Public License)', 'license']
53: );
54:
55: my @other_pages = (
56: ['Developer Information', 'dev'],
57: ['Configuration Information', 'config'],
58: );
59:
60: open SHELL, '<', "shell.html";
61: my $shell = join '', <SHELL>;
62: $shell =~ s/\r/\n/g;
63:
64: # Call with: The title, breadcrumb, and content
65: sub replaceText {
66: my ($title, $links, $breadcrumb, $content) = @_;
67:
68: my $page = $shell;
69: $page =~ s/\<!-- *title *--\>/$title/g;
70: $page =~ s/\<!-- *links *--\>/$links/g;
71: $page =~ s/\<!-- *breadcrumb *--\>/$breadcrumb/g;
72: $page =~ s/\<!-- *content *--\>/$content/g;
73:
74: return $page;
75: }
76:
77: # Do the index page
78:
79: open INDEX, '>', "index.html";
80: my $content = <<PRELUDE;
81:
82: <p>LON-CAPA is based upon a lot of Open Source modules, so it's
83: important to have the right environment on your computer. This is most
84: easily done by installing on a dedicated machine while installing the
85: operating system.</p>
86:
87: <p>The configuring of LON-CAPA is part of the install process of the
88: software. However, In case something needs to be altered, or isn't
89: working, here is some <a href="config.html">information on configuring
90: LON-CAPA</a>.</p>
91:
92: <hr />
93: <h3>Supported Linux Distros</h3>
94: PRELUDE
95:
96: $content .= '<p>LON-CAPA is supported on a variety of Linux distributions.</p>'."\n".
97: '<p>In the list below these are divided into distros with a long
98: life cycle, i.e., those for which a particular version is supported by the distributor for 5 years or more, and those with a short life cycle, i.e., those for which a particular versions is supported for up to 18 months.</p>'.
99: '<div style="float: left;">'.
100: '<b>'Long life cycle</b><br />'.
101: '<ul>'."\n";
102: for (@longlifecycle) {
103: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
104: }
105: $content .= '</ul></div>'.\n".
106: '<div style="float: left;">'.
107: '<b>Short life cycle</b><br />'.
108: '<ul>'."\n";
109: for (@shortlifecycle) {
110: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
111: }
112: $content .= '</ul></div><br clear="all" />'.\n".
113: '<b>Additional information</b><ul>'."\n";
114: for (@ancillary) {
115: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
116: }
117: $content .= '</ul><br />';
118:
119:
120: my $testing_content = '';
121: if (@testing_pages) {
122: $testing_content .= "<hr/><p>Installation on the following systems requires the use of a testing release of LON-CAPA.</p>\n";
123: $testing_content .= "<ul>\n";
124: for (@testing_pages) {
125: $testing_content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
126: }
127: $testing_content .= "</ul>\n";
128: }
129:
130:
131: $content .= <<"POSTLUDE";
132: <hr />
133: <a name="download" />
134: <h3>Downloading LON-CAPA</h3>
135:
136: <p>
137: <b>Current Production Release is Version LATESTVERSION.
138: This version was released on LATESTDATE.</b>
139: </p>
140: <p>
141: You can download the <b>most current production version of LON-CAPA</b> at
142: <a href="http://install.lon-capa.org/versions/loncapa-current.tar.gz">
143: http://install.lon-capa.org/versions/loncapa-current.tar.gz</a>
144: (version LATESTVERSION).
145: </p>
146: TESTINGRELEASE_START
147: <p>
148: <b>Current Testing Release is Version LATESTTESTINGVERSION.
149: This version was released on LATESTTESTINGDATE.</b>
150: </p>
151: <p>
152: You can download the <b>testing version of the upcoming LON-CAPA</b> at
153: <a href="http://install.lon-capa.org/versions/loncapa-testing.tar.gz">
154: http://install.lon-capa.org/versions/loncapa-testing.tar.gz</a>
155: (version LATESTTESTINGVERSION).
156: </p>
157: $testing_content
158: TESTINGRELEASE_END
159:
160: <hr />
161: POSTLUDE
162:
163: open(RELEASE, '<', "release.frag");
164: $content .= join('',<RELEASE>);
165: close(RELEASE);
166:
167: $content .= "<ul>\n";
168: my @testing_pages = (
169: );
170: for (@other_pages) {
171: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
172: }
173:
174: $content .= "</ul>\n";
175:
176: $links='<link rel="alternate" type="application/rss+xml" title="CVS RSS" href="loncapa.rss" />';
177:
178: my $index = replaceText("Install LON-CAPA", $links, "Install LON-CAPA",
179: $content);
180:
181: print INDEX $index;
182: close INDEX;
183:
184: # Build the pages
185: for (@pages,@other_pages,@testing_pages) {
186: my ($title, $source) = @$_;
187:
188: # read in content
189: open SOURCE, '<', $source.'.frag';
190: $content = join '', <SOURCE>;
191: close SOURCE;
192:
193: $content = replaceText($title, '', '<a href="/">Install LON-CAPA</a> > ' . $title,
194: $content);
195: open DEST, '>', $source.'.html';
196: print DEST $content;
197: close DEST;
198: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>