Annotation of doc/build/generate_web_pages.pl, revision 1.59
1.1 bowersj2 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:
1.23 albertel 13: Basically, there's a few comments in shell.hemp that we replace with
1.1 bowersj2 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:
1.46 raeburn 24: my @longlifecycle = (
1.58 raeburn 25: ['CentOS Linux 7 Install','centos7_install'],
1.53 raeburn 26: ['CentOS Linux 6 Install','centos6_install'],
1.46 raeburn 27: ['CentOS Linux 5 Install','centos5_install'],
1.59 ! raeburn 28: ['Scientific Linux 7 Install','scientific7_install'],
1.46 raeburn 29: ['Scientific Linux 6 Install','scientific6_install'],
30: ['Scientific Linux 5 Install','scientific5_install'],
1.57 raeburn 31: ['Red Hat Enterprise Linux 7 Install','RHEL7_install'],
1.46 raeburn 32: ['Red Hat Enterprise Linux 6 Install','RHEL6_install'],
33: ['Red Hat Enterprise Linux 5 Install','RHEL5_install'],
34: ['Red Hat Enterprise Linux 4 Install','RHEL4_install'],
1.59 ! raeburn 35: ['SuSE Linux Enterprise Server 12 Install', 'sles12_install'],
1.46 raeburn 36: ['SuSE Linux Enterprise Server 11 Install', 'sles11_install'],
37: ['SuSE Linux Enterprise Server 10 Install', 'sles10_install'],
38: ['SuSE Linux Enterprise Server 9 Install', 'sles9_install'],
1.56 raeburn 39: ['Ubuntu 14.04 LTS Server', 'ubuntu14LTS_install'],
40: ['Ubuntu 12.04 LTS Server', 'ubuntu12LTS_install'],
1.52 raeburn 41: ['Ubuntu 10.04 LTS Server', 'ubuntu10LTS_install'],
42: ['Ubuntu 8.04 LTS Server', 'ubuntu8LTS_install'],
1.46 raeburn 43: );
44:
45: my @shortlifecycle = (
1.59 ! raeburn 46: ['Fedora 21 Install', 'F21_install'],
1.56 raeburn 47: ['Fedora 20 Install', 'F20_install'],
48: ['Fedora 19 Install', 'F19_install'],
49: ['Fedora 18 Install', 'F18_install'],
50: ['Fedora 17 Install', 'F17_install'],
1.53 raeburn 51: ['Fedora 16 Install', 'F16_install'],
1.43 raeburn 52: ['Fedora 15 Install', 'F15_install'],
53: ['Fedora 14 Install', 'F14_install'],
54: ['Fedora 13 Install', 'F13_install'],
1.59 ! raeburn 55: ['SuSE Linux 13.2 Install', 'suse13.2_install'],
1.56 raeburn 56: ['SuSE Linux 13.1 Install', 'suse13.1_install'],
57: ['SuSE Linux 12.3 Install', 'suse12.3_install'],
58: ['SuSE Linux 12.2 Install', 'suse12.2_install'],
1.53 raeburn 59: ['SuSE Linux 12.1 Install', 'suse12.1_install'],
1.43 raeburn 60: ['SuSE Linux 11.4 Install', 'suse11.4_install'],
1.46 raeburn 61: );
62:
63: my @ancillary = (
64: ['Upgrading from Previous LON-CAPA install', 'upgrade'],
65: ['LON-CAPA License (Gnu Public License)', 'license']
66: );
1.29 albertel 67:
1.22 albertel 68: my @other_pages = (
1.23 albertel 69: ['Developer Information', 'dev'],
70: ['Configuration Information', 'config'],
1.22 albertel 71: );
1.1 bowersj2 72:
73: open SHELL, '<', "shell.html";
74: my $shell = join '', <SHELL>;
75: $shell =~ s/\r/\n/g;
76:
77: # Call with: The title, breadcrumb, and content
78: sub replaceText {
1.27 albertel 79: my ($title, $links, $breadcrumb, $content) = @_;
1.1 bowersj2 80:
81: my $page = $shell;
82: $page =~ s/\<!-- *title *--\>/$title/g;
1.27 albertel 83: $page =~ s/\<!-- *links *--\>/$links/g;
1.1 bowersj2 84: $page =~ s/\<!-- *breadcrumb *--\>/$breadcrumb/g;
85: $page =~ s/\<!-- *content *--\>/$content/g;
86:
87: return $page;
88: }
89:
90: # Do the index page
91:
92: open INDEX, '>', "index.html";
1.23 albertel 93: my $content = <<PRELUDE;
94:
95: <p>LON-CAPA is based upon a lot of Open Source modules, so it's
96: important to have the right environment on your computer. This is most
97: easily done by installing on a dedicated machine while installing the
98: operating system.</p>
99:
100: <p>The configuring of LON-CAPA is part of the install process of the
1.52 raeburn 101: software. However, in case something needs to be altered, or isn't
1.24 albertel 102: working, here is some <a href="config.html">information on configuring
1.23 albertel 103: LON-CAPA</a>.</p>
1.1 bowersj2 104:
1.3 bowersj2 105: <hr />
1.47 raeburn 106: <h3>Supported Linux Distros</h3>
1.1 bowersj2 107: PRELUDE
108:
1.46 raeburn 109: $content .= '<p>LON-CAPA is supported on a variety of Linux distributions.</p>'."\n".
110: '<p>In the list below these are divided into distros with a long
1.52 raeburn 111: 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 version is supported for up to 18 months.</p>'.
1.46 raeburn 112: '<div style="float: left;">'.
1.48 raeburn 113: '<b>Long life cycle</b><br />'.
1.46 raeburn 114: '<ul>'."\n";
115: for (@longlifecycle) {
116: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
117: }
1.49 raeburn 118: $content .= '</ul></div>'."\n".
1.46 raeburn 119: '<div style="float: left;">'.
1.47 raeburn 120: '<b>Short life cycle</b><br />'.
1.46 raeburn 121: '<ul>'."\n";
122: for (@shortlifecycle) {
1.1 bowersj2 123: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
124: }
1.50 raeburn 125: $content .= '</ul></div><br clear="all" />'."\n".
1.47 raeburn 126: '<b>Additional information</b><ul>'."\n";
127: for (@ancillary) {
128: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
129: }
130: $content .= '</ul><br />';
131:
1.1 bowersj2 132:
1.30 albertel 133: my $testing_content = '';
1.29 albertel 134: if (@testing_pages) {
135: $testing_content .= "<hr/><p>Installation on the following systems requires the use of a testing release of LON-CAPA.</p>\n";
136: $testing_content .= "<ul>\n";
137: for (@testing_pages) {
138: $testing_content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
139: }
140: $testing_content .= "</ul>\n";
141: }
142:
143:
144: $content .= <<"POSTLUDE";
1.3 bowersj2 145: <hr />
146: <a name="download" />
147: <h3>Downloading LON-CAPA</h3>
148:
149: <p>
1.10 albertel 150: <b>Current Production Release is Version LATESTVERSION.
1.3 bowersj2 151: This version was released on LATESTDATE.</b>
152: </p>
153: <p>
1.10 albertel 154: You can download the <b>most current production version of LON-CAPA</b> at
1.3 bowersj2 155: <a href="http://install.lon-capa.org/versions/loncapa-current.tar.gz">
156: http://install.lon-capa.org/versions/loncapa-current.tar.gz</a>
157: (version LATESTVERSION).
158: </p>
1.8 albertel 159: TESTINGRELEASE_START
160: <p>
1.10 albertel 161: <b>Current Testing Release is Version LATESTTESTINGVERSION.
1.9 albertel 162: This version was released on LATESTTESTINGDATE.</b>
163: </p>
164: <p>
1.8 albertel 165: You can download the <b>testing version of the upcoming LON-CAPA</b> at
166: <a href="http://install.lon-capa.org/versions/loncapa-testing.tar.gz">
167: http://install.lon-capa.org/versions/loncapa-testing.tar.gz</a>
1.9 albertel 168: (version LATESTTESTINGVERSION).
1.8 albertel 169: </p>
1.29 albertel 170: $testing_content
1.8 albertel 171: TESTINGRELEASE_END
1.3 bowersj2 172:
1.22 albertel 173: <hr />
1.3 bowersj2 174: POSTLUDE
1.5 bowersj2 175:
1.30 albertel 176: open(RELEASE, '<', "release.frag");
177: $content .= join('',<RELEASE>);
178: close(RELEASE);
179:
1.22 albertel 180: $content .= "<ul>\n";
1.44 raeburn 181: my @testing_pages = (
182: );
1.22 albertel 183: for (@other_pages) {
184: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
185: }
186:
187: $content .= "</ul>\n";
188:
1.27 albertel 189: $links='<link rel="alternate" type="application/rss+xml" title="CVS RSS" href="loncapa.rss" />';
190:
1.54 raeburn 191: my $index = replaceText("Install LON-CAPA", $links, '<font color="#006600" face="Arial, Helvetica, sans-serif">Documentation/Download</font>',
1.27 albertel 192: $content);
1.3 bowersj2 193:
1.1 bowersj2 194: print INDEX $index;
195: close INDEX;
196:
197: # Build the pages
1.51 raeburn 198: for (@longlifecycle,@shortlifecycle,@ancillary,@other_pages,@testing_pages) {
1.1 bowersj2 199: my ($title, $source) = @$_;
200:
201: # read in content
202: open SOURCE, '<', $source.'.frag';
203: $content = join '', <SOURCE>;
204: close SOURCE;
205:
1.55 raeburn 206: $content = replaceText($title, '', '<font face="Arial, Helvetica, sans-serif"><a href="/">Documentation/Download</a> » '.
1.54 raeburn 207: '</font><font color="#006600" face="Arial, Helvetica, sans-serif">'.$title,
1.1 bowersj2 208: $content);
209: open DEST, '>', $source.'.html';
210: print DEST $content;
211: close DEST;
212: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>