mirror of
https://git.hardenedbsd.org/hardenedbsd/HardenedBSD.git
synced 2024-12-29 15:10:57 +01:00
The program that turns sgml files (tagged according to the linuxdoc
DTD) into HTML, LaTeX or ascii. (the latter is still pretty rough) Reviewed by: rgrimes
This commit is contained in:
parent
f26b6240ac
commit
317be71920
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/cvs2svn/branches/jfieber/; revision=8397
9
usr.bin/sgmlfmt/Makefile
Normal file
9
usr.bin/sgmlfmt/Makefile
Normal file
@ -0,0 +1,9 @@
|
||||
# $Id:$
|
||||
|
||||
MAN1= sgmlfmt.1
|
||||
|
||||
afterinstall:
|
||||
install -c -o ${BINOWN} -g ${BINGRP} -m ${BINMODE} \
|
||||
${.CURDIR}/sgmlfmt.pl ${DESTDIR}${BINDIR}/sgmlfmt
|
||||
|
||||
.include <bsd.prog.mk>
|
105
usr.bin/sgmlfmt/sgmlfmt.1
Normal file
105
usr.bin/sgmlfmt/sgmlfmt.1
Normal file
@ -0,0 +1,105 @@
|
||||
.Dd May 6, 1995
|
||||
.Os FreeBSD 2.0.5
|
||||
.Dt SGMLFMT 1
|
||||
.Sh NAME
|
||||
.Nm sgmlfmt
|
||||
.Nd Formats SGML files tagged according to the linuxdoc DTD.
|
||||
.Sh SYNOPSIS
|
||||
.Nm
|
||||
.Fl Ar format Op Fl Ar format...
|
||||
.Ar
|
||||
.Sh DESCRIPTION
|
||||
The
|
||||
.Nm
|
||||
command reads SGML files tagged according to the linuxdoc DTD,
|
||||
validates them using the
|
||||
.Xr sgmls 1
|
||||
parser and then converts them to the specified output format.
|
||||
The input file must include the following document type
|
||||
declaration before any uncommented text:
|
||||
.Bd -literal -offset indent
|
||||
<!DOCTYPE linuxdoc PUBLIC "-//FreeBSD//DTD linuxdoc//EN">
|
||||
.Ed
|
||||
.Pp
|
||||
The
|
||||
.Fl Ar format
|
||||
options for output include the following:
|
||||
.Bl -tag -width Ds
|
||||
.It Fl html
|
||||
Generates a set of linked HTML files suitable for use with an
|
||||
HTML browser. A top level file,
|
||||
.Pa file.html ,
|
||||
contains the title, author, date, abstract and brief table of
|
||||
contents for the document. A file
|
||||
.Pa file_toc.html
|
||||
contains a complete table of contents. A series of files named
|
||||
.Pa file-1.html ,
|
||||
.Pa file-2.html ...
|
||||
.Pa file-n.html
|
||||
contain the actual text of the document.
|
||||
.It Fl latex
|
||||
Generates a single output file with the extension
|
||||
.Pa .tex
|
||||
suitable for processing with LaTeX. Note that the LaTeX style
|
||||
file
|
||||
.Pa /usr/share/sgml/FreeBSD/lib/linuxdoc.sty
|
||||
must be accessible to LaTeX for correct processing.
|
||||
.It Fl ascii
|
||||
Generates a single output file with the extension
|
||||
.Pa .txt
|
||||
suitable for viewing on an ASCII terminal.
|
||||
.It Fl nroff
|
||||
Generates a single output file with the extension
|
||||
.Pa .nroff
|
||||
suitable processing with
|
||||
.Xr nroff 1
|
||||
or
|
||||
.Xr groff 1 .
|
||||
This is actually an intermediate conversion used by the
|
||||
.Fl ascii
|
||||
format option.
|
||||
.El
|
||||
.Pp
|
||||
If the input file name ends with
|
||||
.Pa .sgml ,
|
||||
the extension may be omitted on the command line.
|
||||
In all cases, the output files are created in the current working
|
||||
directory.
|
||||
.Sh FILES
|
||||
.Pa /usr/share/sgml/FreeBSD/dtd/linuxdoc
|
||||
- the linuxdoc DTD.
|
||||
.Pp
|
||||
.Pa /usr/share/sgml/FreeBSD/rep/
|
||||
- directory containing replacement files for
|
||||
.Xr sgmlsasp 1 .
|
||||
.Pp
|
||||
.Pa /usr/share/sgml/FreeBSD/lib/linuxdoc.sty
|
||||
- the LaTeX style used in documents produced with the
|
||||
.Fl latex
|
||||
format option.
|
||||
.Sh SEE ALSO
|
||||
.Xr sgmls 1 ,
|
||||
.Xr sgmlsasp 1 ,
|
||||
.Xr groff 1
|
||||
.Sh HISTORY
|
||||
The
|
||||
.Nm
|
||||
command appeared in Version 2.0.5 FreeBSD UNIX.
|
||||
.Sh AUTHORS
|
||||
The
|
||||
.Nm
|
||||
command was written by John Fieber
|
||||
.Aq jfieber@FreeBSD.org .
|
||||
The linuxdoc DTD was written by Matt Welsh
|
||||
.Aq mdw@cs.cornell.edu
|
||||
and based on the Qwertz DTD written by Tom Gordon
|
||||
.Aq thomas.gordon@gmd.de .
|
||||
.Sh BUGS
|
||||
A line in the SGML source file beginning with a period (.) will
|
||||
confuse
|
||||
.Xr groff 1
|
||||
which is used to generate ASCII output. In general, the ASCII
|
||||
output leaves much to be desired.
|
||||
.Pp
|
||||
The divison of the sources file into separate HTML files is
|
||||
currently fixed.
|
570
usr.bin/sgmlfmt/sgmlfmt.pl
Executable file
570
usr.bin/sgmlfmt/sgmlfmt.pl
Executable file
@ -0,0 +1,570 @@
|
||||
#!/usr/bin/perl
|
||||
# $Id:$
|
||||
|
||||
# Format an sgml document tagged according to the linuxdoc DTD.
|
||||
# by John Fieber <jfieber@freebsd.org> for the FreeBSD documentation
|
||||
# project.
|
||||
#
|
||||
# Usage: sgmlformat -format [-format ...] inputfile [inputfile ...]
|
||||
#
|
||||
# -format outputfile format
|
||||
# -------------------------------------------------------------
|
||||
# -html inputfile.html HTML
|
||||
# -txt | -ascii inputfile.txt ascii text
|
||||
# -tex | -latex inputfile.tex LaTeX
|
||||
# -nroff inputfile.nroff groff for ms macros
|
||||
# -ps inputfile.txt postscript
|
||||
#
|
||||
# Bugs:
|
||||
#
|
||||
# Text lines that start with a period (.) confuse the conversions that
|
||||
# use groff. The workaround is to make sure the SGML source doesn't
|
||||
# have any periods at the beginning of a line.
|
||||
|
||||
#######################################################################
|
||||
|
||||
# Look in a couple places for the SGML DTD and replacement files
|
||||
#
|
||||
|
||||
if (-d "$ENV{'HOME'}/lib/sgml/FreeBSD") {
|
||||
$sgmldir = "$ENV{'HOME'}/lib/sgml";
|
||||
}
|
||||
elsif (-d "$ENV{'HOME'}/sgml/FreeBSD") {
|
||||
$sgmldir = "$ENV{'HOME'}/sgml";
|
||||
}
|
||||
elsif (-d "/usr/share/sgml/FreeBSD" ) {
|
||||
$sgmldir = "/usr/share/sgml";
|
||||
}
|
||||
else {
|
||||
die "Cannot locate sgml files!\n";
|
||||
}
|
||||
|
||||
#
|
||||
# Locate the DTD, an SGML declaration, and the replacement files
|
||||
#
|
||||
|
||||
$dtdbase = "$sgmldir/FreeBSD";
|
||||
$dtd = "$dtdbase/dtd/linuxdoc";
|
||||
if (-f "$dtd.dec") {
|
||||
$decl = "$dtd.dec";
|
||||
}
|
||||
else {
|
||||
$decl = "";
|
||||
}
|
||||
$replbase = "$dtdbase/rep";
|
||||
|
||||
if (! $ENV{"SGML_PATH"}) {
|
||||
$ENV{"SGML_PATH"} = "$sgmldir/%O/%C/%T";
|
||||
}
|
||||
|
||||
#
|
||||
# Look for the file specified on the command line
|
||||
#
|
||||
|
||||
sub getfile {
|
||||
local($filearg) = @_;
|
||||
if (-f "$filearg.sgml") {
|
||||
$file = "$filearg.sgml";
|
||||
}
|
||||
elsif (-f $filearg) {
|
||||
$file = $filearg;
|
||||
}
|
||||
else {
|
||||
return 0;
|
||||
}
|
||||
$fileroot = $file;
|
||||
$fileroot =~ s/.*\///; # drop the path
|
||||
$fileroot =~ s/\.sgml$//; # drop the .sgml
|
||||
$filepath = $file;
|
||||
$filepath =~ s/\/*[^\/]*$//;
|
||||
if ($filepath eq "") {
|
||||
$ENV{"SGML_PATH"} .= ":.";
|
||||
}
|
||||
else {
|
||||
$ENV{"SGML_PATH"} .= ":$filepath/%S:.";
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
#
|
||||
# A function to run sgmls and sgmlsasp on the input file.
|
||||
#
|
||||
# Arguments:
|
||||
# 1. A file handle for the output
|
||||
# 2. A replacement file (directory actually)
|
||||
#
|
||||
|
||||
sub sgmlparse {
|
||||
local($fhandle, $replacement) = @_;
|
||||
$ENV{'SGML_PATH'} = "$replbase/$replacement.%N:$ENV{'SGML_PATH'}";
|
||||
open($fhandle, "sgmls $decl $file | sgmlsasp $replbase/$replacement.mapping |");
|
||||
}
|
||||
|
||||
#
|
||||
# Generate nroff output
|
||||
#
|
||||
|
||||
sub gen_nroff {
|
||||
open (outfile, ">$fileroot.nroff");
|
||||
&sgmlparse(infile, "nroff");
|
||||
$\ = "\n"; # automatically add newline on print
|
||||
while (<infile>) {
|
||||
chop;
|
||||
# This is supposed to ensure that no text line starts
|
||||
# with a dot (.), thus confusing groff, but it doesn't
|
||||
# appear to work.
|
||||
unless (/^\.DS/.../^\.DE/) {
|
||||
s/^[ \t]{1,}(.*)/$1/g;
|
||||
}
|
||||
s/^\.[ \t].*/\\\&$&/g;
|
||||
print outfile;
|
||||
}
|
||||
$\ = "";
|
||||
close(infile);
|
||||
close(outfile);
|
||||
}
|
||||
|
||||
#
|
||||
# Generate ASCII output using groff
|
||||
#
|
||||
|
||||
sub gen_ascii {
|
||||
&sgmlparse(infile, "nroff");
|
||||
open(outfile, "| groff -T ascii -t -ms | col -b > $fileroot.txt");
|
||||
while (<infile>) {
|
||||
print outfile;
|
||||
}
|
||||
close(infile);
|
||||
close(outfile);
|
||||
}
|
||||
|
||||
#
|
||||
# Generate Postscript output using groff (this is suboptimal
|
||||
# for printed output!)
|
||||
#
|
||||
|
||||
sub gen_ps {
|
||||
&sgmlparse(infile, "grops");
|
||||
open(outfile, "| groff -T ps -t -ms > $fileroot.ps");
|
||||
while (<infile>) {
|
||||
print outfile;
|
||||
}
|
||||
close(infile);
|
||||
close(outfile);
|
||||
}
|
||||
|
||||
#
|
||||
# Generate LaTeX output
|
||||
#
|
||||
|
||||
sub gen_latex {
|
||||
open(outfile, ">$fileroot.tex");
|
||||
&sgmlparse(infile, "latex");
|
||||
while (<infile>) {
|
||||
print outfile;
|
||||
}
|
||||
close(infile);
|
||||
close(outfile);
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# Generate HTML output.
|
||||
#
|
||||
# HTML is generated in two passes.
|
||||
#
|
||||
# The first pass takes the output from sgmlsasp and gathers information
|
||||
# about the structure of the document that is used in the sceond pass
|
||||
# for splitting the file into separate files. Targets for cross
|
||||
# references are also stored in this pass.
|
||||
#
|
||||
# Based on the information from the first pass, the second pass
|
||||
# generates a numbered series of HTML files, a "toplevel" file
|
||||
# containing the title, author, abstract and a brief table of
|
||||
# contents. A detailed table of contents is also generated. The
|
||||
# second pass generates links for cross references and URLs.
|
||||
|
||||
#
|
||||
# Tunable parameters
|
||||
#
|
||||
$maxlevel = 3; # max section depth
|
||||
$num_depth = 4; # depth of numbering
|
||||
$m_depth = 2; # depth of menus
|
||||
|
||||
|
||||
$sc = 0; # number of sections
|
||||
$filecount = 0; # number of files
|
||||
|
||||
sub gen_html {
|
||||
local($i, $sl);
|
||||
$tmpfile = "/tmp/sgmlf.$$";
|
||||
|
||||
open(bar, ">$tmpfile");
|
||||
# print STDERR "(Pass 1...";
|
||||
&sgmlparse(foo, "html");
|
||||
while (<foo>) {
|
||||
print bar;
|
||||
# count up the number of files to be generated
|
||||
if (/^<@@sect>/) {
|
||||
$sl++;
|
||||
$sc++;
|
||||
$st_sl[$sc] = $sl;
|
||||
|
||||
# Per level counters
|
||||
$counter[$sl]++;
|
||||
$counter[$sl + 1] = 0;
|
||||
|
||||
# calculate the section number in the form x.y.z.
|
||||
$st_num[$sc] = "";
|
||||
if ($sl <= $num_depth) {
|
||||
for ($i = 1; $i <= $sl; $i++) {
|
||||
$st_num[$sc] .= "$counter[$i].";
|
||||
}
|
||||
$st_num[$sc] .= " ";
|
||||
}
|
||||
|
||||
# calculate the file number and output level
|
||||
if ($sl <= $maxlevel) {
|
||||
$filecount++;
|
||||
$st_ol[$sc] = $sl;
|
||||
}
|
||||
else {
|
||||
$st_ol[$sc] = $maxlevel;
|
||||
}
|
||||
|
||||
$st_file[$sc] = $filecount;
|
||||
|
||||
# Calculate the highest level node in which this
|
||||
# node should appear as a menu item.
|
||||
$st_pl[$sc] = $sl - $m_depth;
|
||||
if ($st_pl[$sc] < 0) {
|
||||
$st_pl[$sc] = 0;
|
||||
}
|
||||
if ($st_pl[$sc] > $maxlevel) {
|
||||
$st_pl[$sc] = $maxlevel;
|
||||
}
|
||||
}
|
||||
if (/^<@@endsect>/) {
|
||||
$sl--;
|
||||
}
|
||||
|
||||
# record the section number that a label occurs in
|
||||
if (/^<@@label>/) {
|
||||
chop;
|
||||
s/^<@@label>//;
|
||||
if ($references{$_} eq "") {
|
||||
$references{$_} = "$filecount";
|
||||
}
|
||||
else {
|
||||
print STDERR "Warning: the label `$_' is multiply-defined.\n";
|
||||
}
|
||||
}
|
||||
}
|
||||
close(bar);
|
||||
|
||||
# print STDERR " Pass 2...";
|
||||
open(foofile, $tmpfile);
|
||||
&html2html(foofile, "boo");
|
||||
# print STDERR ")\n";
|
||||
|
||||
unlink($tmpfile);
|
||||
}
|
||||
|
||||
#
|
||||
# HTML conversion, pass number 2
|
||||
#
|
||||
|
||||
sub html2html {
|
||||
local($infile, $outfile) = @_;
|
||||
local($i);
|
||||
|
||||
$sc = 0;
|
||||
push(@scs, $sc);
|
||||
|
||||
open(tocfile, ">${fileroot}_toc.html");
|
||||
print tocfile "<HTML>\n";
|
||||
|
||||
while (<$infile>) {
|
||||
# change `<' and `>' to `<' and `>' in <pre></pre>
|
||||
if (/<pre>/.../<\/pre>/) {
|
||||
s/</\</g;
|
||||
s/\<([\/]*)pre>/<\1pre>/g;
|
||||
s/>/\>/g;
|
||||
s/<([\/]*)pre\>/<\1pre>/g;
|
||||
}
|
||||
|
||||
tagsw: {
|
||||
# titles and headings
|
||||
if (s/^<@@title>//) {
|
||||
chop;
|
||||
print tocfile "<HEAD>\n<TITLE>$_</TITLE>\n</HEAD>\n";
|
||||
print tocfile "<H1>$_</H1>\n";
|
||||
$header[$st_ol[$sc]] =
|
||||
"<HTML>\n<HEAD>\n<TITLE>$_</TITLE>\n" .
|
||||
"</HEAD>\n<BODY>\n<H1>$_</H1>\n";
|
||||
$footer[$st_ol[$sc]] = "</BODY>\n</HTML>\n";
|
||||
last tagsw;
|
||||
}
|
||||
|
||||
#
|
||||
# HEADER begin
|
||||
#
|
||||
if (s/^<@@head>//) {
|
||||
chop;
|
||||
|
||||
if ($part == 1) {
|
||||
$text[0] .= "<H1>Part $partnum:<BR>$_";
|
||||
last tagsw;
|
||||
}
|
||||
|
||||
$href = "\"$fileroot-$st_file[$sc].html#$sc\"";
|
||||
|
||||
# set up headers and footers
|
||||
if ($st_sl[$sc] > 0 && $st_sl[$sc] <= $maxlevel) {
|
||||
$header[$st_ol[$sc]] =
|
||||
"<HTML>\n<HEAD>\n<TITLE>$_</TITLE>\n</HEAD>\n" .
|
||||
"<BODY>\n$navbar[$st_ol[$sc]]\n<HR>\n";
|
||||
$footer[$st_ol[$sc]] =
|
||||
"<HR>\n$navbar[$st_ol[$sc]]\n</BODY>\n</HTML>";
|
||||
}
|
||||
|
||||
# Add this to the master table of contents
|
||||
print tocfile "<DD>$st_num[$sc]" .
|
||||
"<A HREF=$href>$_";
|
||||
|
||||
# Calculate the <H?> level to use in the HTML file
|
||||
$hlevel = $st_sl[$sc] - $st_ol[$sc] + 2;
|
||||
$shlevel = $st_sl[$sc] - $st_ol[$sc] + 3;
|
||||
|
||||
$i = $st_ol[$sc];
|
||||
|
||||
# Add the section header
|
||||
$text[$i] .= "<H$hlevel><A NAME=\"$sc\"></A>$st_num[$sc]$_";
|
||||
$i--;
|
||||
|
||||
# And also to the parent
|
||||
if ($st_sl[$sc] == $st_ol[$sc] && $i >= 0) {
|
||||
$text[$i] .= "<H$shlevel>$st_num[$sc]" .
|
||||
"<A HREF=$href>$_";
|
||||
$i--;
|
||||
}
|
||||
|
||||
# and to the grandparents
|
||||
for (; $i >= $st_pl[$sc]; $i--) {
|
||||
$text[$i] .= "<DD>$st_num[$sc] " .
|
||||
"<A HREF=$href>$_";
|
||||
}
|
||||
|
||||
last tagsw;
|
||||
}
|
||||
|
||||
#
|
||||
# HEADER end
|
||||
#
|
||||
if (s/^<@@endhead>//) {
|
||||
if ($part == 1) {
|
||||
$text[0] .= "</H1>\n";
|
||||
$part = 0;
|
||||
last tagsw;
|
||||
}
|
||||
print tocfile "</A></DD>\n";
|
||||
|
||||
$i = $st_ol[$sc];
|
||||
|
||||
# Close the section header
|
||||
$text[$i] .= "</H$hlevel>\n";
|
||||
$i--;
|
||||
|
||||
# in the parent...
|
||||
if ($st_sl[$sc] == $st_ol[$sc] && $i >= 0) {
|
||||
$text[$i] .= "</A></H$shlevel>\n";
|
||||
$i--;
|
||||
}
|
||||
|
||||
# in the grandparent...
|
||||
for (; $i >= $st_pl[$sc]; $i--) {
|
||||
$text[$i] .= "</A></DD>\n";
|
||||
}
|
||||
last tagsw;
|
||||
}
|
||||
|
||||
# sectioning
|
||||
if (s/^<@@part>//) {
|
||||
$part = 1;
|
||||
$partnum++;
|
||||
# not yet implemented in the DTD
|
||||
last tagsw;
|
||||
}
|
||||
|
||||
#
|
||||
# BEGINNING of a section
|
||||
#
|
||||
if (s/^<@@sect>//) {
|
||||
# Increment the section counter and save it on a stack
|
||||
# for future reference.
|
||||
$sc++;
|
||||
push(@scs, $sc);
|
||||
|
||||
# Set up the navigation bar
|
||||
if ($st_file[$sc] > $st_file[$sc - 1]) {
|
||||
&navbar($st_file[$sc], $filecount, $sc);
|
||||
}
|
||||
|
||||
# Prepare for menu entries in the table of contents and
|
||||
# parent file(s).
|
||||
if ($st_sl[$sc - 1] < $st_sl[$sc]) {
|
||||
print tocfile "<DL>\n";
|
||||
$i = $st_ol[$sc] - 1 - ($st_sl[$sc] == $st_ol[$sc]);
|
||||
for (; $i >= $st_pl[$sc]; $i--) {
|
||||
$text[$i] .= "<DL>\n";
|
||||
}
|
||||
}
|
||||
last tagsw;
|
||||
}
|
||||
|
||||
#
|
||||
# END of a section
|
||||
#
|
||||
if (s/^<@@endsect>//) {
|
||||
|
||||
# Remember the section number! Subsections may have
|
||||
# altered the global $sc variable.
|
||||
local ($lsc) = pop(@scs);
|
||||
|
||||
# Close off subsection menus we may have created in
|
||||
# parent file(s).
|
||||
if ($st_sl[$lsc] > $st_sl[$sc + 1]) {
|
||||
print tocfile "</DL>\n";
|
||||
$i = $st_ol[$lsc] - 1 - ($st_sl[$lsc] == $st_ol[$lsc]);
|
||||
for (; $i >= $st_pl[$lsc]; $i--) {
|
||||
$text[$i] .= "</DL>\n";
|
||||
}
|
||||
}
|
||||
|
||||
# If this section is below $maxlevel, write it now.
|
||||
if ($st_sl[$lsc] <= $maxlevel) {
|
||||
open(SECOUT, ">${fileroot}-$st_file[$lsc].html");
|
||||
print SECOUT "$header[$st_ol[$lsc]] $text[$st_ol[$lsc]] " .
|
||||
"$footer[$st_ol[$lsc]]";
|
||||
$text[$st_ol[$lsc]] = "";
|
||||
close(SECOUT);
|
||||
}
|
||||
last tagsw;
|
||||
}
|
||||
|
||||
# cross references
|
||||
if (s/^<@@label>//) {
|
||||
chop;
|
||||
$text[$st_ol[$sc]] .= "<A NAME=\"$_\"></A>";
|
||||
last tagsw;
|
||||
}
|
||||
if (s/^<@@ref>//) {
|
||||
chop;
|
||||
$refname = $_;
|
||||
$text[$st_ol[$sc]] .=
|
||||
"<A HREF=\"${fileroot}-$references{$_}.html#$refname\">";
|
||||
last tagsw;
|
||||
}
|
||||
if (s/^<@@endref>//) {
|
||||
# $text[$st_ol[$sc]] .= "</A>";
|
||||
last tagsw;
|
||||
}
|
||||
if (s/^<@@refnam>//) {
|
||||
$text[$st_ol[$sc]] .= "$refname</A>";
|
||||
last tagsw;
|
||||
}
|
||||
# URLs
|
||||
if (s/^<@@url>//) {
|
||||
chop;
|
||||
$urlname = $_;
|
||||
$text[$st_ol[$sc]] .= "<A HREF=\"$urlname\">";
|
||||
last tagsw;
|
||||
}
|
||||
if (s/^<@@urlnam>//) {
|
||||
$text[$st_ol[$sc]] .= "$urlname</A>";
|
||||
last tagsw;
|
||||
}
|
||||
if (s/^<@@endurl>//) {
|
||||
# $text[$st_ol[$sc]] .= "</A>";
|
||||
last tagsw;
|
||||
}
|
||||
|
||||
|
||||
# If nothing else did anything with this line, just print it.
|
||||
$text[$st_ol[$sc]] .= "$_";
|
||||
}
|
||||
}
|
||||
|
||||
print tocfile "</HTML>";
|
||||
open(SECOUT, ">$fileroot.html");
|
||||
print SECOUT "$header[0] $text[0] $footer[0]";
|
||||
close(SECOUT);
|
||||
close tocfile;
|
||||
}
|
||||
|
||||
sub navbar {
|
||||
local ($fnum, $fmax, $sc) = @_;
|
||||
|
||||
$prevf = $fnum - 1;
|
||||
$nextf = $fnum + 1;
|
||||
|
||||
$navbar[$st_ol[$sc]] = "<B>\n";
|
||||
$navbar[$st_ol[$sc]] .=
|
||||
"<A HREF=\"${fileroot}.html\">Table of Contents</A>\n";
|
||||
if ($prevf <= 0) {
|
||||
$navbar[$st_ol[$sc]] .=
|
||||
"| <A HREF=\"${fileroot}.html\">Previous</A>\n";
|
||||
}
|
||||
else {
|
||||
$navbar[$st_ol[$sc]] .=
|
||||
"| <A HREF=\"${fileroot}-${prevf}.html\">Previous</A>\n";
|
||||
}
|
||||
if ($nextf <= $fmax) {
|
||||
$navbar[$st_ol[$sc]] .=
|
||||
"| <A HREF=\"${fileroot}-${nextf}.html\">Next</A>\n";
|
||||
}
|
||||
else {
|
||||
$navbar[$st_ol[$sc]] .=
|
||||
"| <A HREF=\"${fileroot}.html\">Next</A>\n";
|
||||
}
|
||||
$navbar[$st_ol[$sc]] .= "</B>\n";
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
# Now, read the command line and take appropriate action
|
||||
|
||||
$fcount = 0;
|
||||
for (@ARGV) {
|
||||
if (/^-.*/) {
|
||||
s/^-//;
|
||||
$gen{$_} = 1;
|
||||
}
|
||||
else {
|
||||
@infiles[$fcount] = $_;
|
||||
$fcount++;
|
||||
}
|
||||
}
|
||||
|
||||
for ($i = 0; $i < $fcount; $i++) {
|
||||
if (&getfile($infiles[$i])) {
|
||||
if ($gen{'html'}) {
|
||||
print "generating $fileroot.html...\n"; &gen_html(); }
|
||||
if ($gen{'tex'} || $gen{'latex'}) {
|
||||
print "generating $fileroot.tex...\n"; &gen_latex(); }
|
||||
if ($gen{'nroff'}) {
|
||||
print "generating $fileroot.nroff...\n"; &gen_nroff(); }
|
||||
if ($gen{'txt'} || $gen{'ascii'}) {
|
||||
print "generating $fileroot.txt...\n"; &gen_ascii(); }
|
||||
if ($gen{'ps'}) {
|
||||
print "generating $fileroot.ps...\n"; &gen_ps(); }
|
||||
}
|
||||
else {
|
||||
print "Input file $infiles[$i] not found\n";
|
||||
}
|
||||
}
|
||||
|
||||
exit 0;
|
||||
|
Loading…
Reference in New Issue
Block a user