File:  [LON-CAPA] / doc / build / generate_web_pages.pl
Revision 1.62: download - view: text, annotated - select for diffs
Thu Mar 18 01:25:31 2021 UTC (3 years, 1 month ago) by raeburn
Branches: MAIN
CVS tags: HEAD
- Links to files for Fedora 26-33 contain FC instead of just F.

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

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