Have you used a WYSIWYG (What You See Is What You Get) desktop publishing program like FrameMaker, WordPerfect, Interleaf, and so on? Then you might not have much experience with the original UNIX formatters, nroff and troff .
Instead of showing a picture of the completed document on your screen as you type, these formatters read a source file full of text and special formatting commands. The formatted output goes into a file (text, PostScript, or some other format) or straight to a printer. You create and edit the source file with any text editor (like vi ). O'Reilly & Associates still uses troff to produce many of its books. For example, the start of the source file for this article looks like:
.Ah 2520 "The Text Formatters nroff, troff, ditroff, ..." Have you used a WYSIWYG (What You See Is What You Get) desktop publishing program like FrameMaker, WordPerfect, Interleaf and so on? Then you might not have much experience with the original UNIX formatters, \fInroff\fP and \fItroff\fP. .LP Instead of showing a picture of the completed document on your screen as you type, these formatters read a \fIsource file\fP full ...
You might wonder, "Why use these dinosaurs?"
All UNIX systems have them or can get them, so they're portable.
The source files are usually much smaller than WYSIWYG formatters' files.
The source files are plain text with no non-printable characters; they're easy to copy from one system to another. For instance, I work on books on my DOS laptop, then transfer the files to UNIX for formatting.
The formatting language that's used has a powerful set of features that gives professional typesetters (like O'Reilly & Associates) excellent control over the way the output page looks.
You can use UNIX utilities-
grep
, 
awk
, shell scripts, and many others - to process the text. This adds even more power to the formatting setup. For example, that 
2520
 following the 
.Ah
 in the example above is the filename. Each article in this book has an arbitrary four digit filename; this is mapped into the section number printed in the margin and in all the cross references throughout the book using a system of scripts I wrote. I also built a crude outline processor so that we could control the organization of the book by changing a single file. All this was possible only because 
troff
 wasn't forced to work alone - we could apply the full power of the UNIX environment.
Batch formatters like nroff and troff aren't the answer for all formatting jobs, but they're worth looking into - especially for small or very complex jobs.
-