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

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

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