gno/usr.bin/man
gdr-ftp b1128f4c89 Makefile:
- fix a problem with the 'install' and 'release' targets
README:
	- added some comments on possible optimizations
1998-03-29 20:52:16 +00:00
..
apropos2.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
apropos.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
apropos.rez - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
catman.8 - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
catman.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
catman.rez - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
common.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
common.rez - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
fillbuffer.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
globals.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
Makefile Makefile: 1998-03-29 20:52:16 +00:00
makewhatis.8 - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
makewhatis.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
makewhatis.rez - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
man2.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
man.1 - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
man.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
man.h - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
man.rez - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
manpack.desc - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
mkso.data - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
process.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
README Makefile: 1998-03-29 20:52:16 +00:00
util.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
utilgs.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
whatis.1 - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
whatis.c - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00
whatis.rez - modifications for compilation under GNO v2.0.6 base build. See 1998-03-29 07:16:25 +00:00

--------------------------------------------
Name:     manpack
Version:  3.1
Author:   Devin Reade <gdr@trenco.gno.org>
Computer: Apple IIgs
Requires: GNO v2.x
--------------------------------------------

===========
Description:
===========

Various programs for working with manual pages.  This archive includes
the following utilities.  All utilities have their versions lockstepped:

        apropos		locate commands by keyword
	catman		format cat pages from man pages
	makewhatis	create the whatis database
	man		display reference manual pages
	whatis		locate commands by name

============
Installation:
============

Type at the command line `dmake install`.  You may wish to first
verify the destination directories in "Makefile.mk".  By default
these are:

	BINDIR  = /usr/bin	(apropos, man, and whatis)
	SBINDIR = /usr/sbin	(catman, and makewhatis)
	MANDIR  = /usr/man	(all manual pages)

Ensure that all older versions of these programs are deleted.
They may or may not be in the above directories.

If you're building a GNO release in the base builds, then use the
command `dmake release`.

==========
Legalities:
==========

These utilities are copyright 1995-1998 by Devin Reade <gdr@trenco.gno.org>.

They are provided as freeware, and may be distributed by Internet
archive sites, online services such as Delphi, or BBSes provided that
the archive remains intact.  Permission is granted for distribution
with GNO and ORCA provided credit for this work is given along
with any other attributions.

Inclusion of these utilities in collections on disk, CD-ROM, or
other portable media is permitted provided that only a nominal
fee (not much more than the media cost) is charged.  Contact the
author regarding other commercial distributions.

Updates to these utilities may be distributed provided that the source
and this README file are included.  Please follow the coding style
already in use and document your changes in this file.  Better yet,
email me with your suggested changes and I'll consider incorporating
them into the base distribution.

=======
CHANGES:
=======

apropos, whatis
	v3.1 (28 Mar 98)
		Incorporated all utilities into the GNO base build.  All
		versions are now lockstepped.

		Searches are no longer case sensitive.

	v3.0 (24 Jul 95)
		Complete rewrite from scratch by Devin Reade.

		This version makes use of MANPATH in the same way
		as man(1) v3.0.  Similarily, it will also search
		the 17/syscmnd ORCA database.

		In the previous version, the behavior of apropos was
		identical to that of whatis.  This version has been
		fixed so that whatis is case sensitive and searches
		only the manual page names.  The apropos search is
		case insensitive and searches the entire database
		entry.

	v2.1 (1 Jul 92 ?)
		This version is by Mike Horwath and shipped with GNO v1.1.
		Although no version flags or resource forks where provided
		with this release, this release is designated as v2.1
		because it shipped with man(1) v2.1.
                         
catman
	v3.1 (28 Mar 98)
		Incorporated all utilities into the GNO base build.  All
		versions are now lockstepped.

	v1.0 (24 Jul 95)
		Initial release.  Written from scratch by Devin Reade.

makewhatis
	v3.1 (28 Mar 98)
		Incorporated all utilities into the GNO base build.  All
		versions are now lockstepped.

		Don't use binary mode to read the files; this doesn't
		give the right results with the GNO v2.0.6 stdio package
		since we're doing calls to fgets() at times.

	v1.2 (24 Jul 95)
		Fixed bug where pages in "manl" ending in ".l" (that's
		"ell" in both cases) would be ignored.

		Added recognition of files compressed with gzip.

		File compression suffixes are now case sensitive.

		If none of MANPATH, USRMAN, or MANDIR are defined,
		"/usr/man" will now be used.

		Fixed a bug where the word SYNOPSIS appearing in the
		description would mangle the database entry.

		Added a verbose-level-three flag (-v3), which is basically
		the old -v2 flag.  The new -v2 is somewhat less verbose
		than it was.

	v1.1 (29 May 94)
		Makewhatis will now ignore any man page starting with
		".so", in order to eliminate multiple files.  The resultant
		blank lines in the whatis database have therefore been
		eliminated.

   		Changed -v flag to {-v1|-v2} for differing stages of verbosity.
		Only error output will be logged with the -l flag.

		Manual page was updated, to include a correction to the -o
		flag usage and the modification to the -v flag.  Descriptions
		of bugs unlikely to be fixed were added.  Date and version
		were changed.

		Fixed bug where input buffer wasn't properly terminated, and
		added checks for buffer overflows.

		Makewhatis will now display all commands about which the
		manual page is written.  For example, if foo.1 described
		both foo(1) and bar(1), and bar.1 was an .so (or .l) link
		to foo.1, then the database entry will have changed from

		    foo (1)		- extract and add thingys
		    foo, bar (1)	- extract and add thingys

		Makewhatis used to pick up the first NAME string in the file
		as a reference point.  Now, any NAME is ignored in any line
		starting with .\" or .TH

		Filename chapter numbers will now be correctly extracted
		regardless of the existence of .Z, .z, .F, or .f suffixes,
		or of the existence of '.' within the base file name.

		Makewhatis is now linked with Soenke's gnulib for the
		getopt() function, rather than using the libc version.

		Stack usage was reduced to 1k.  Be aware, though, that a
		fair amount of global storage is used, including three 1k
		buffers.

	v1.0 (15 May 94)
		Initial release.  Written from scratch by Devin Reade.

man
	v3.1 (28 Mar 98)
		Incorporated all utilities into the GNO base build.  All
		versions are now lockstepped.

		Searches are no longer case sensitive.

	v3.0 (24 Jul 95)
		Complete rewrite from scratch by Devin Reade.

                The -k, -t, -, -f, -M, and -T flags were added.

		Man now supports the MANPATH environment variable which
		can be a list of paths delimited by either colons or
		spaces.

		Added sections 3f, l, n, o, and p to searched subdirectories.

		Added gzip(1) to compress(1) and freeze(1) as allowable
		source compressors.

		Fixed bug with the .so source command;  .so references
		should now (properly) appear as ".so man<section>/<filename>"
		instead of using the full pathname.

		Updates to apropos v3.0 apply to man when invoked with
		the -k flag.

		Preprocessing by eqn(1), refer(1), tbl(1), and vgrind(1)
		is not yet supported.

	v2.1 (1 Jul 92 ?)
		Recognised environment variable USRMAN as well as MANDIR.
		
		This version was also by Mike Horwath.

	v2.0 (Date Unknown)
		This version is by Mike Horwath and shipped with GNO v1.1.

		It made use of the environment variable MANDIR which had
		to be a single directory.
		

=====
TO DO:
=====

Here's a possible optimization option:
	Create a database in the user's home directory that contains a
	list of all man pages and their locations, based on MANPATH.
	Keep a magic number (a checksum or hash?) in the file to see if
	MANPATH has changed.  *maybe* check the date of the file against
	the modification date of the respective directories and generate a
	warning if the db is out-of-date.

Makewhatis is not very well integrated with the rest of the package;
there is still duplication of definitions and functions in some files.

Man, catman, and makewhatis need to support preformatting for eqn(1),
vgrind(1), et al.

Makewhatis' "verbose" output could be cleaner.

Performance analysis has not been done.  No doubt some things could
improve, including some string matching in util.c

If the stock getenv(3) function is used (as is done here), then the
return value should be duplicated (via strdup) rather than just used.
If the getenv function from the lenviron library is used, this is not
a concern.

Perhaps an "X" version should be done for the Second Sight card.  This
will have to wait a while.