Annotation of doc/build/generate_web_pages.pl, revision 1.57

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

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>