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: PRELUDE
94:
95: $content .= '<p>LON-CAPA is supported on a variety of Linux distributions.</p>'."\n".
96: '<p>In the list below these are divided into distros with a long
97: 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>'.
98: '<div style="float: left;">'.
99: '<b>'Long life cycle</b><br />';
100: '<ul>'."\n";
101: for (@longlifecycle) {
102: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
103: }
104: $content .= '</ul></div>'.\n".
105: '<div style="float: left;">'.
106: '<b>Short life cycle</b><br />';
107: '<ul>'."\n";
108: for (@shortlifecycle) {
109: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
110: }
111: $content .= '</ul></div><br clear="all" />'.\n";
112:
113: my $testing_content = '';
114: if (@testing_pages) {
115: $testing_content .= "<hr/><p>Installation on the following systems requires the use of a testing release of LON-CAPA.</p>\n";
116: $testing_content .= "<ul>\n";
117: for (@testing_pages) {
118: $testing_content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
119: }
120: $testing_content .= "</ul>\n";
121: }
122:
123:
124: $content .= <<"POSTLUDE";
125: <hr />
126: <a name="download" />
127: <h3>Downloading LON-CAPA</h3>
128:
129: <p>
130: <b>Current Production Release is Version LATESTVERSION.
131: This version was released on LATESTDATE.</b>
132: </p>
133: <p>
134: You can download the <b>most current production version of LON-CAPA</b> at
135: <a href="http://install.lon-capa.org/versions/loncapa-current.tar.gz">
136: http://install.lon-capa.org/versions/loncapa-current.tar.gz</a>
137: (version LATESTVERSION).
138: </p>
139: TESTINGRELEASE_START
140: <p>
141: <b>Current Testing Release is Version LATESTTESTINGVERSION.
142: This version was released on LATESTTESTINGDATE.</b>
143: </p>
144: <p>
145: You can download the <b>testing version of the upcoming LON-CAPA</b> at
146: <a href="http://install.lon-capa.org/versions/loncapa-testing.tar.gz">
147: http://install.lon-capa.org/versions/loncapa-testing.tar.gz</a>
148: (version LATESTTESTINGVERSION).
149: </p>
150: $testing_content
151: TESTINGRELEASE_END
152:
153: <hr />
154: POSTLUDE
155:
156: open(RELEASE, '<', "release.frag");
157: $content .= join('',<RELEASE>);
158: close(RELEASE);
159:
160: $content .= "<ul>\n";
161: my @testing_pages = (
162: );
163: for (@other_pages) {
164: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
165: }
166:
167: $content .= "</ul>\n";
168:
169: $links='<link rel="alternate" type="application/rss+xml" title="CVS RSS" href="loncapa.rss" />';
170:
171: my $index = replaceText("Install LON-CAPA", $links, "Install LON-CAPA",
172: $content);
173:
174: print INDEX $index;
175: close INDEX;
176:
177: # Build the pages
178: for (@pages,@other_pages,@testing_pages) {
179: my ($title, $source) = @$_;
180:
181: # read in content
182: open SOURCE, '<', $source.'.frag';
183: $content = join '', <SOURCE>;
184: close SOURCE;
185:
186: $content = replaceText($title, '', '<a href="/">Install LON-CAPA</a> > ' . $title,
187: $content);
188: open DEST, '>', $source.'.html';
189: print DEST $content;
190: close DEST;
191: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>