File:  [LON-CAPA] / doc / build / generate_web_pages.pl
Revision 1.70: download - view: text, annotated - select for diffs
Wed Jan 1 20:35:51 2025 UTC (7 weeks, 2 days ago) by raeburn
Branches: MAIN
CVS tags: version_2_12_X, version_2_11_X, version_2_11_6_msu, HEAD
- Link to old version (Fedora 38) removed.
- Reverse change in rev. 1.69 and reinstate link to Fedora 39.

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

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