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 @pages = (
25: # ['Red Hat 7.3 Install', 'rh73'],
26: # ['Fedora Install', 'fedora_install'],
27: ['Fedora Core 3 Install', 'FC3_install'],
28: ['Fedora Core 4 Install', 'FC4_install'],
29: ['Red Hat Enterprise Linux 4 Install','RHEL4_install'],
30: ['SuSE Linux Professional 9.2 Install', 'suse9.2_install'],
31: ['SuSE Linux Professional 9.3 Install', 'suse9.3_install'],
32: ['SuSE Linux Enterprise Server 9 Install', 'sles9_install'],
33: # ['Manual Install from Tarballs', 'manual_install'],
34: ['Upgrading from Previous LON-CAPA install', 'upgrade'],
35: ['LON-CAPA License (Gnu Public License)', 'license']
36: );
37: my @other_pages = (
38: ['Developer Information', 'dev'],
39: ['Configuration Information', 'config'],
40: );
41:
42: open SHELL, '<', "shell.html";
43: my $shell = join '', <SHELL>;
44: $shell =~ s/\r/\n/g;
45:
46: # Call with: The title, breadcrumb, and content
47: sub replaceText {
48: my ($title, $breadcrumb, $content) = @_;
49:
50: my $page = $shell;
51: $page =~ s/\<!-- *title *--\>/$title/g;
52: $page =~ s/\<!-- *breadcrumb *--\>/$breadcrumb/g;
53: $page =~ s/\<!-- *content *--\>/$content/g;
54:
55: return $page;
56: }
57:
58: # Do the index page
59:
60: open INDEX, '>', "index.html";
61: my $content = <<PRELUDE;
62:
63: <p>LON-CAPA is based upon a lot of Open Source modules, so it's
64: important to have the right environment on your computer. This is most
65: easily done by installing on a dedicated machine while installing the
66: operating system.</p>
67:
68: <p>The configuring of LON-CAPA is part of the install process of the
69: software. However, In case something needs to be altered, or isn't
70: working, here is some <a href="config.html">information on configuring
71: LON-CAPA</a>.</p>
72:
73: <hr />
74: PRELUDE
75:
76: $content .= "<ul>\n";
77: for (@pages) {
78: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
79: }
80:
81: $content .= "</ul>\n";
82:
83: $content .= <<'POSTLUDE';
84: <hr />
85: <a name="download" />
86: <h3>Downloading LON-CAPA</h3>
87:
88: <p>
89: <b>Current Production Release is Version LATESTVERSION.
90: This version was released on LATESTDATE.</b>
91: </p>
92: <p>
93: You can download the <b>most current production version of LON-CAPA</b> at
94: <a href="http://install.lon-capa.org/versions/loncapa-current.tar.gz">
95: http://install.lon-capa.org/versions/loncapa-current.tar.gz</a>
96: (version LATESTVERSION).
97: </p>
98: TESTINGRELEASE_START
99: <p>
100: <b>Current Testing Release is Version LATESTTESTINGVERSION.
101: This version was released on LATESTTESTINGDATE.</b>
102: </p>
103: <p>
104: You can download the <b>testing version of the upcoming LON-CAPA</b> at
105: <a href="http://install.lon-capa.org/versions/loncapa-testing.tar.gz">
106: http://install.lon-capa.org/versions/loncapa-testing.tar.gz</a>
107: (version LATESTTESTINGVERSION).
108: </p>
109: TESTINGRELEASE_END
110:
111: <hr />
112: POSTLUDE
113:
114: $content .= "<ul>\n";
115: for (@other_pages) {
116: $content .= "<li><a href='$_->[1].html'>$_->[0]</a></li>\n";
117: }
118:
119: $content .= "</ul>\n";
120:
121: my $index = replaceText("Install LON-CAPA", "Install LON-CAPA",
122: $content);
123:
124: print INDEX $index;
125: close INDEX;
126:
127: # Build the pages
128: for (@pages,@other_pages) {
129: my ($title, $source) = @$_;
130:
131: # read in content
132: open SOURCE, '<', $source.'.frag';
133: $content = join '', <SOURCE>;
134: close SOURCE;
135:
136: $content = replaceText($title, '<a href="/">Install LON-CAPA</a> > ' . $title,
137: $content);
138: open DEST, '>', $source.'.html';
139: print DEST $content;
140: close DEST;
141: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>