mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-22 23:00:57 +08:00
210 lines
10 KiB
Markdown
210 lines
10 KiB
Markdown
[#]: subject: "Old-school technical writing with groff"
|
||
[#]: via: "https://opensource.com/article/22/8/old-school-technical-writing-groff"
|
||
[#]: author: "Jim Hall https://opensource.com/users/jim-hall"
|
||
[#]: collector: "lkxed"
|
||
[#]: translator: " "
|
||
[#]: reviewer: " "
|
||
[#]: publisher: " "
|
||
[#]: url: " "
|
||
|
||
Old-school technical writing with groff
|
||
======
|
||
Take a trip back in time to experience text formatting from a bygone era.
|
||
|
||
![Compute like it's 1989][1]
|
||
|
||
Image by: LSE Library. Modified by Opensource.com. CC BY-SA 4.0
|
||
|
||
One of my favorite stories about Unix is how it turned into a text processing system. Brian Kernighan [tells the story in his book][2] Unix: A History and a Memoir (chapter 3) but to summarize: The Unix team at Bell Labs ran the original Unix on a PDP-7 computer, but it was a tiny system and didn't have sufficient resources to support new work. So Ken Thompson and others lobbied to purchase a new PDP-11 computer. Management denied the request. Around the same time, the Patents department planned to buy a new computer platform to produce patent applications using proprietary document formatting software. The Unix group proposed that the Patents department instead buy a new PDP-11 for the Unix team, and the Unix team would create formatting software for them.
|
||
|
||
That new formatting system was called `nroff`, short for "New Roff," an updated version of a text formatting program called Roff from a 1960s computer system. The name Roff came from the old expression, "I'll run off a document."
|
||
|
||
### Basic formatting with nroff
|
||
|
||
By default, `nroff` collects words and fills paragraphs. When `nroff` encounters a blank line, it starts a new paragraph. For example, start with this article's introduction, which is only a few paragraphs long:
|
||
|
||
```
|
||
$ cat intro
|
||
Old-school technical writing with groff
|
||
Jim Hall
|
||
|
||
One of my favorite stories about Unix is how it turned
|
||
into a text processing system. Brian Kernighan tells the
|
||
story in his book Unix: A History and a Memoir (chapter 3)
|
||
but to summarize:
|
||
The Unix team at Bell Labs ran the original Unix on
|
||
a PDP-7 computer, but it was a tiny system and didn't
|
||
have sufficient resources to support new work. So Ken
|
||
Thompson and others lobbied to purchase a new PDP-11
|
||
computer. Management denied the request. Around the same
|
||
time, the Patents department planned to buy a new computer
|
||
platform to produce patent applications using proprietary
|
||
document formatting software. The Unix group proposed
|
||
that the Patents department instead buy a new PDP-11 for
|
||
the Unix team, and the Unix team would create formatting
|
||
software for them.
|
||
|
||
That new formatting system was called nroff, short for
|
||
"New Roff," an updated version of a text formatting program
|
||
called Roff from a 1960s computer system. The name Roff
|
||
came from the old expression, "I'll run off a document."
|
||
```
|
||
|
||
If you process this file with `nroff`, lines are "glued" together so the output is paragraphs with full justification. Using `nroff` also hyphenates words, if that helps balance lines in the text:
|
||
|
||
```
|
||
$ nroff intro | head
|
||
Old‐school technical writing with groff Jim Hall
|
||
|
||
One of my favorite stories about Unix is how it turned into a
|
||
text processing system. Brian Kernighan tells the story in his
|
||
book Unix: A History and a Memoir (chapter 3) but to summarize:
|
||
The Unix team at Bell Labs ran the original Unix on a PDP‐7 com‐
|
||
puter, but it was a tiny system and didn’t have sufficient re‐
|
||
sources to support new work. So Ken Thompson and others lobbied
|
||
to purchase a new PDP‐11 computer. Management denied the request.
|
||
Around the same time, the Patents department planned to buy a new
|
||
```
|
||
|
||
Original Unix systems used a typewriter-style printer that used 66 lines of 80 columns on a US Letter page, and `nroff` makes the same assumptions. It also adds empty lines so each page of output is 66 lines per page, but I've used the `head` command to show just the first few lines of output because my sample text isn't very long.
|
||
|
||
### Breaking lines and centering text
|
||
|
||
The first two lines were meant to be separate lines of text. You can insert a formatting instruction to tell `nroff` to add a line break. All `nroff` instructions start with a dot, followed by a brief command. To add a line break, use the `.br` instruction between the first and second line:
|
||
|
||
```
|
||
Old-school technical writing with groff
|
||
.br
|
||
Jim Hall
|
||
```
|
||
|
||
When you process this new file, `nroff` prints the title and author on separate lines:
|
||
|
||
```
|
||
$ nroff intro | head
|
||
Old‐school technical writing with groff
|
||
Jim Hall
|
||
|
||
One of my favorite stories about Unix is how it turned into a
|
||
text processing system. Brian Kernighan tells the story in his
|
||
book Unix: A History and a Memoir (chapter 3) but to summarize:
|
||
The Unix team at Bell Labs ran the original Unix on a PDP‐7 com‐
|
||
puter, but it was a tiny system and didn’t have sufficient re‐
|
||
sources to support new work. So Ken Thompson and others lobbied
|
||
to purchase a new PDP‐11 computer. Management denied the request.
|
||
```
|
||
|
||
You can add other formatting to make this document look better. To center the top two lines, use the `.ce` formatting request. This takes a number argument, to indicate how many lines `nroff` should center. Here, you can center the top two output lines with the `.ce 2` request:
|
||
|
||
```
|
||
.ce 2
|
||
Old-school technical writing with groff
|
||
.br
|
||
Jim Hall
|
||
```
|
||
|
||
With this added instruction, `nroff` correctly centers the first two lines:
|
||
|
||
```
|
||
$ nroff intro | head
|
||
Old‐school technical writing with groff
|
||
Jim Hall
|
||
|
||
One of my favorite stories about Unix is how it turned into a
|
||
text processing system. Brian Kernighan tells the story in his
|
||
book Unix: A History and a Memoir (chapter 3) but to summarize:
|
||
The Unix team at Bell Labs ran the original Unix on a PDP‐7 com‐
|
||
puter, but it was a tiny system and didn’t have sufficient re‐
|
||
sources to support new work. So Ken Thompson and others lobbied
|
||
to purchase a new PDP‐11 computer. Management denied the request.
|
||
```
|
||
|
||
### Adding page margins
|
||
|
||
Printing this to a printer results in text starting on the first line of the page, and against the left edge. To add a few lines of extra space from the top of the page, use the `.sp` request, with the number of blank lines to add:
|
||
|
||
```
|
||
.sp 5
|
||
.ce 2
|
||
Old-school technical writing with groff
|
||
.br
|
||
Jim Hall
|
||
```
|
||
|
||
By default, `nroff` formats the output so each line is 65 columns wide. Printing to an 80 column US Letter page leaves 15 empty columns. Adding 7 spaces on the left side neatly balances the output with equal left and right page margins. You can create this page offset using the `.po 7` request:
|
||
|
||
```
|
||
.po 7
|
||
.sp 5
|
||
.ce 2
|
||
Old-school technical writing with groff
|
||
.br
|
||
Jim Hall
|
||
```
|
||
|
||
Processing the new file with `nroff` produces a plain text page that's ready to print:
|
||
|
||
```
|
||
$ nroff intro | head
|
||
|
||
|
||
|
||
|
||
|
||
Old‐school technical writing with groff
|
||
Jim Hall
|
||
|
||
One of my favorite stories about Unix is how it turned into a
|
||
text processing system. Brian Kernighan tells the story in his
|
||
```
|
||
|
||
### Printing to a laser printer
|
||
|
||
Later, the Unix team at Bell Labs acquired a phototypesetting machine, capable of producing printed text similar to a laser printer. To support the typesetter's new capabilities, the Unix team updated `nroff` to become the typesetter-specific `troff` program, and a few years later updated it again to become `ditroff`, the device-independent version of `troff`.
|
||
|
||
Linux systems provide modern versions of `nroff` and `troff` using the GNU `groff` program. You can still use the old `nroff` program name to generate plain text output, or `troff` to produce `ditroff` compatible output. Using the `groff` program, you can also prepare documents for other kinds of output files, such as Postscript.
|
||
|
||
You can process the same input file using `groff` to print on a Postscript-compatible laser printer by selecting a suitable output type using the `-T` option, such as `-Tps` to generate a Postscript file. For example, I can print to a printer with the [lpr command][3] and the `HP_LaserJet_CP1525nw` device, because that's how my Linux system [recognizes my laser printer][4]:
|
||
|
||
```
|
||
$ groff -Tps intro | lpr -P "HP_LaserJet_CP1525nw"
|
||
```
|
||
|
||
### Generating other kinds of output
|
||
|
||
If you instead want to save the output as a PDF file, you can convert the Postscript using the `ps2pdf` tool:
|
||
|
||
```
|
||
$ groff -Tps intro | ps2pdf - > intro.pdf
|
||
```
|
||
|
||
To generate a web page from the same file, use `-Thtml` to set the output type to HTML:
|
||
|
||
```
|
||
$ groff -Thtml intro > index.html
|
||
```
|
||
|
||
The `groff` command supports lots of other built-in formatting requests to provide other kinds of document formatting. If you want to learn the other default formatting requests available to you in the GNU `groff` implementations of `nroff` and `troff`, refer to chapter 5 in the [The GNU Troff Manual][5].
|
||
|
||
Formatting documents using these built-in commands takes a lot of effort to keep everything looking the same. Technical writers who use `groff` instead use a collection of formatting requests called *macros*, which provide their own commands to generate section headings, paragraphs, block quotes, footnotes, lists, and other useful document formatting. To learn more about one popular macro package, read [How to format academic papers on Linux with groff -me][6] on Opensource.com.
|
||
|
||
--------------------------------------------------------------------------------
|
||
|
||
via: https://opensource.com/article/22/8/old-school-technical-writing-groff
|
||
|
||
作者:[Jim Hall][a]
|
||
选题:[lkxed][b]
|
||
译者:[译者ID](https://github.com/译者ID)
|
||
校对:[校对者ID](https://github.com/校对者ID)
|
||
|
||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||
|
||
[a]: https://opensource.com/users/jim-hall
|
||
[b]: https://github.com/lkxed
|
||
[1]: https://opensource.com/sites/default/files/lead-images/1980s-computer-yearbook.png
|
||
[2]: https://opensource.com/article/20/8/unix-history
|
||
[3]: https://opensource.com/article/21/9/print-files-linux
|
||
[4]: https://opensource.com/article/18/3/print-server-raspberry-pi
|
||
[5]: https://www.gnu.org/software/groff/manual/groff.html#gtroff-Reference
|
||
[6]: https://opensource.com/article/18/2/writing-academic-papers-groff-me
|