UNIX Power Tools

UNIX Power ToolsSearch this book
Previous: 50.10 Make Your Own Man Pages Without Learning troffChapter 50
Help--Online Documentation, etc.
Next: 50.12 Common UNIX Error Messages
 

50.11 Writing a Simple Man Page with the -man Macros

If you're not satisfied with the simple manual pages we discussed in article 50.10, here's how to go all the way and create a "real" manual page. As we said, the best way to create a manual page is to copy one that already exists. So here's a sample for you to copy. Rather than discuss it blow by blow, I'll include lots of comments (these start with .\" or \").

1 


apropos 




















































.\" Title: Program name, manual section, and date
.TH GRIND 1 
.\" Section heading: NAME, followed by command name and one line summary
.\" It's important to copy this exactly; the "whatis" database (used
.\"for apropos) looks for the summary line.
.SH NAME   
.\"grind \- create output from input
.\" Section heading: SYNOPSIS, followed by syntax summary
.SH SYNOPSIS 
.B grind              \" .B: bold font; use it for the command name.
[ -b ] [ -c ] [ -d ]  \" Put optional arguments in square brackets.
[ input [ output ]]   \" Arguments can be spread across several lines.
.br                   \" End the synopsis with an explicit line break (.br)
.\" A new section: DESCRIPTION, followed by what the command does
.SH DESCRIPTION
.I Grind       \" .I:  Italic font for the word "Grind"
performs lots of computations. Input to 
.IR grind ,    \" .IR: One word italic, next word roman, no space between.
is taken from the file
.IR input ,
and output is sent to the file
.IR output ,
which default to standard input and standard output if not specified.
.\" Another section: now we're going to discuss the -b, -c, and -d options
.SH OPTIONS
.\" The .TP macro precedes each option 
.TP 
.B \-b  \" print the -b option in bold.  
Print output in binary.
.TP
.B \-c  \" \- requests a minus sign, which is preferable to a hyphen (-) 
Eliminate ASCII characters from input before processing.
.TP
.B \-d 
Cause daemons to overrun your computer.
.\" OK, we're done with the description and the options; now mention
.\" other requirements (like environment and files needed) as well as
.\" what can go wrong. You can add any other sections you want.
.SH FILES
.PD 0
.TP 20
.B /dev/null
data file
.TP
.B /tmp/grind*
temporary file (typically 100 Megabytes)
.PD
.SH BUGS
In order to optimize computational speed, this program always produces
the same result, independent of the input.
.\" Use .LP between paragraphs
.LP
If the moon is full, 
.I grind
may destroy your input file. To say nothing of your sex life.
.\" Good manual pages end by stating who wrote the program.
.SH AUTHOR
I wouldn't admit to this hack if my life depended on it.

After all that, you should have noticed that there are four important macros, listed in Table 50.2, to know about.

Table 50.2: Important -man Macros
MacroMeaning
.THTitle of the manual page.
.SHSection heading; one for each section.
.TPFormats options correctly (sets up the "hanging indent").
.LPUsed between paragraphs in a section.

For some arcane reason, all manual pages use the silly .B, .BI, etc., macros to make font changes. I've adhered to this style in the example, but it's much easier to use "in line" font changes: \fI for italic, \fB for bold, and \fR for roman. There may be some systems on which this doesn't work properly, but I've never seen any.

- ML


Previous: 50.10 Make Your Own Man Pages Without Learning troffUNIX Power ToolsNext: 50.12 Common UNIX Error Messages
50.10 Make Your Own Man Pages Without Learning troffBook Index50.12 Common UNIX Error Messages

The UNIX CD Bookshelf NavigationThe UNIX CD BookshelfUNIX Power ToolsUNIX in a NutshellLearning the vi Editorsed & awkLearning the Korn ShellLearning the UNIX Operating System