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