4 Last update: 22 Apr 2002
6 This file is part of groff, the GNU roff type-setting system.
8 Copyright (C) 2000, 2001, 2002 Free Software Foundation, Inc.
9 written by Bernd Warken <bwarken@mayn.de>
10 maintained by Werner Lemberg <wl@gnu.org>
12 Permission is granted to copy, distribute and/or modify this document
13 under the terms of the GNU Free Documentation License, Version 1.1 or
14 any later version published by the Free Software Foundation; with the
15 Invariant Sections being this .ig-section and AUTHORS, with no
16 Front-Cover Texts, and with no Back-Cover Texts.
18 A copy of the Free Documentation License is included as a file called
19 FDL in the main directory of the groff source package.
22 .\" --------------------------------------------------------------------
24 .\" --------------------------------------------------------------------
40 .\" --------------------------------------------------------------------
41 .\" String definitions
43 .\" Final `\""' comments are used to make Emacs happy, sic \""
45 .\" The `-' sign for options.
55 .ds Comment \.\[rs]\[dq]\"
56 .ds Ellipsis \.\|.\|.\&\"
59 .\" --------------------------------------------------------------------
60 .\" Begin of macro definitions
63 .\" this is like a comment request when escape mechanism is off
68 .c ---------------------------------------------------------------------
84 . Text \f[B]\[rs]\*[@1]\f[]\$*
91 . nop `\f[B]\*[@1]\f[]'\$*
95 .c --------------------------------------------------------------------
97 .c a shell command line
102 . Text \f[I]sh#\h'1m'\f[]\f[CR]\$*\f[]\&\"
109 .c --------------------------------------------------------------------
111 .c ShortOpt ([c [punct]])
113 .c `-c' somewhere in the text.
114 .c The second argument is some trailing punctuation.
120 . Text \f[CB]\*[@-]\f[]\f[B]\*[@1]\f[]\/\$*
131 .c --------------------------------------------------------------------
141 .\" End of macro definitions
144 .\" --------------------------------------------------------------------
146 .\" --------------------------------------------------------------------
148 .TH ROFF 7 "23 April 2002" "Groff Version 1.18.1"
150 roff \- roff 排版系统的概念和历史
153 .\" --------------------------------------------------------------------
155 .\" --------------------------------------------------------------------
165 一个 roff 排版系统包含一个可扩展的文本格式化语言和一系列程序用以打印和转换为其他文本格式。
167 传统的,它是 Unix 的主要文本处理系统;现在,每个 类Unix 操作系统仍然附带一个 roff 系统作为核心软件包。
170 当今最普遍的 roff 系统是自由软件的实现
179 实现了它的传统的前辈的用法和功能,并且加入了更多扩展。
183 是唯一可以在 (几乎是) 任何计算机系统上都可用的 roff 系统,因此它是事实上的 roff 标准。
186 在一些古老的 Unix 系统中,有一个叫做
195 它的功能非常有限,即使与古老的 troff 相比;它不再被支持了。
204 尽管历史悠久,roff 当前还在广泛使用中,例如,UNIX 系统的手册页
206 ,很多软件书籍,系统文档,标准和团体组织的文档都是用 roff 来写的。
208 roff 在文本设备上的输出效果仍然是无可比拟的,
209 并且,与其他自由的排版系统相比,它的图形输出也不差,
223 所有 roff 版本在用法方面的一些共同点,
224 roff 管道的细节--它经常被掩盖在类似
232 .\" --------------------------------------------------------------------
234 .\" --------------------------------------------------------------------
237 文本处理系统有很长的一段历史,可以回溯到60 年代。
239 roff 系统自身与 Unix 操作系统关系密切,
240 但是它的起源要从更早的操作系统 CTSS 和 Multics 开始。
243 .\" --------------------------------------------------------------------
244 .SS "祖先 The Predecessor runoff"
245 .\" --------------------------------------------------------------------
258 .RI ( "Compatible Time Sharing System"
263 .URL http://\:www.multicians.org "Multics" ,
264 Unix 的一个著名的来源,出现于 1963,同时
268 当时,这两种操作系统只能运行在非常昂贵的计算机之上,
269 因此它们大部分用于研究和官方及军队的任务之中
278 这可以用一个长度为\~2 的命令 (request) 的集合实现,
279 这些命令的绝大部分都保持不变地被 roff 采用。
281 这种语言的模型是根据 “前计算机时代” 的排版习惯而建立的,
282 那时,以点 (dot, `.') 开头的行被写在手稿中,
283 向之后进行手工排版工作的工人指示格式化的要求
294 在 Multics 操作系统中,帮助系统由 runoff 来处理,
295 与 roff 管理 Unix 手册页的作用类似。
298 例如可以到 Saltzer 的主页看看。参见
303 .\" --------------------------------------------------------------------
304 .SS "传统的 nroff/troff 系统 The Classical nroff/troff System"
305 .\" --------------------------------------------------------------------
307 在 70 年代,Multics 的后裔 (offspring)
309 变得越来越普遍,因为它可以运行在廉价的计算机上,
312 在 MIT (麻省理工,the Massachusetts Institute of Technology),
313 有人想在一台运行 Unix 的 PDP-11 计算机上驱动 Wang (王安公司?) 的
314 .I Graphic Systems CAT
317 由于 runoff 在这种任务上能力有限,它被
318 .IR "Josef F. Osanna" ,
319 (Multics 操作系统的主要开发者之一,几个 runoff 移植系统的作者)
326 Ocsanna 所设想的,极大扩展了的语言已经包含了一个完整的
330 所有现代的 roff 系统都试图实现同这个系统兼容。
332 因此 Joe Osanna 是当之无愧的所有 roff 系统之父
341 .RI ( "typesetter roff\/" )
352 对最初的 runoff 程序的有限功能进行重新实现;
357 这个名字只用来指代一个 troff/\:nroff 系统的整体
360 Osanna 的第一版用 PDP-11 的汇编语言实现,发布于 1973.
365 的开发中,使用 C\~编程语言将它进行了重写。
372 .IR "Troff User's Manual [CSTR\~#54]"
373 中,出版于 1976, Brian Kernighan 对它不断修订,直到 1992 年。
376 .IR "classical troff"
382 1977 年,Osanna 在他\~50 岁时,由于一次突发的心脏病而去世。
383 Kernighan 继续开发 troff。
385 下一个开发目标是赋予 troff 一个更一般的接口,以支持更多设备,
396 这个新的 troff 版本是所有现存的较新的 troff 系统的基础,包括
406 程序都已经自动提供了对 distroff 完整的兼容性
409 .\" --------------------------------------------------------------------
410 .SS "商业化 Commercialization"
411 .\" --------------------------------------------------------------------
413 免费的 Unix\~7 操作系统商业化之后,出现了严重的退步。
415 一大批不同的操作系统浮出水面,为他们所作的扩展间的互不兼容而争斗。
417 幸好,这种不兼容没有影响到原始的 troff。
419 所有不同的商业版本的 roff 系统都大量使用了
420 Osanna/\:Kernighan 的开放的源代码和文档,但是却将其作为
422 系统 (\[lq]their\[rq] system) 出售\[em] 只有很少的修改
425 古老的 Unix 和传统的 troff 的源代码在长达 20 年时间里不再可以自由获得。
428 幸运的是,Caldera 收购了 SCO UNIX (2001).
430 随后,Caldera 使得源代码可以在网上获得,允许用于非商业用途。参见
435 (译注:谁能想到,现在,2003 年,SCO会成为自由软件和开源软件界共同的敌人呢?
439 .\" --------------------------------------------------------------------
441 .\" --------------------------------------------------------------------
443 任何商业的 roff 系统都无法成为 roff 开发中的后继者。
445 商业社会中的每个人都只对他们自己的事情感兴趣。
447 这使得曾经如此优秀的 Unix 操作系统在 80 年代一蹶不振
451 (As a counter-measure to the galopping commercialization,还请重新翻译),
452 AT&T Bell Labs 贝尔实验室试图发起一个恢复性的项目 (?,a rescue project) ,使用他们的
456 它可以免费用于非商业用途,甚至包含了源代码。
457 但是它有一个专利许可证,that empedes the free development ( 还请解释词义)。
459 这种想法早已过时,因此 Plan\~9 没有被主流开发者接受为自己的平台
462 真正的补救措施 (?, remedy) 是不断出现的自由操作系统
463 (386BSD, GNU/\:Linux, 等等.) 和 80 年代到 90 年代的自由软件工程。
465 他们实现了传统的 Unix 的特性和很多扩展,因此旧的 “XP体验” 不会丢掉
466 (such that the old experience is not lost)。
468 进入 21 世纪,类 Unix 系统重新成为计算机工业中的主导因素 \[em] 这要感谢自由软件
471 最重要的自由 roff 计划是 GNU 移植版本的 troff,
473 .URL http://\:www.gnu.org/\:copyleft "GNU Public License" .
485 它与传统 troff 兼容,但是还添加了很多扩展。
487 它是第一个可以在几乎所有操作系统上运行的 roff 系统并且 \[em] 它是自由开放的。
489 这使得 groff 成为现在 roff 的事实标准
492 .\" --------------------------------------------------------------------
494 .\" --------------------------------------------------------------------
498 当你阅读一份手册页 (man page) 时,roff 工作在后台。
502 程序查看,它是一个 X 发行版的标准程序。参见
508 一些 roff 实现提供了包装程序,使得人们可以简单地在命令行使用 roff 系统。
512 提供了命令行选项来避免传统 troff 中过长的的命令管道;
514 程序试着从文档猜测应当使用什么参数来运行 groff;
517 程序来图形化地显示 groff 文件和手册页
520 .\" --------------------------------------------------------------------
521 .SS "管道 The roff Pipe"
522 .\" --------------------------------------------------------------------
524 roff 系统由预处理器 (preprocessor),roff 排版程序和后处理器 (postprocessor) 组成。
529 队列中的每个程序的输出就作为下一个程序的输入
533 .ds @1 "cat \f[I]file\f[P] |\""
534 .ds @2 "\*[Ellipsis] | \f[I]preproc\f[P] | \*[Ellipsis] |\""
535 .ds @3 "troff \f[I]options\f[P] | \f[I]postproc\f[P]\""
537 .ShellCommand "\*[@1] \*[@2] \*[@3]"
543 预处理器产生 roff 代码,传给一个 roff 处理器 (例如,troff),
544 然后 roff 处理器接下来产生中间输出,传给一个后处理器程序,
551 此外,还可以包括为特殊目标而制作 (tailor) 的 roff 宏包
554 大多数 roff 文档中掺杂着使用一些包中的宏、
555 一个或多个预处理器的代码,还会添加 roff 语言中的一些元素。
557 用户很少需要用到 roff 排版语言的完整功能;
558 只有宏包的作者需要知道底层细节 (gory details)
562 .\" --------------------------------------------------------------------
563 .SS "预处理器 Preprocessors"
564 .\" --------------------------------------------------------------------
566 预处理器是任何产生符合 roff 排版语言语法的输出的程序。
568 每个预处理器都有它自己的语言,在预处理器运行时被翻译为 roff 代码。
570 roff 文档中可以包含以这种语言写成的片段;
572 (they are identified by special roff requests or macros)。
574 加入了预处理器代码的文档必须通过所有相应的预处理器处理之后,
576 因为真正的 roff 排版程序会忽略所有陌生的代码。
578 预处理器只会分析并转换指定由它处理的文档部分
584 还有一些预处理器被认为是 roff 系统不可分割的部分。
590 .\" local indent for .TP
591 .TP \\w'\\f[B]soelim\\f[P]'u+2n
601 数学公式 (mathematical formul\[ae])
607 书目索引 (bibliographic references)
615 其他已知预处理器,但不是在所有系统上都可用,包括
622 化学公式 (chemical formul\[ae])
625 构造图元 (graphical elements)
636 .\" --------------------------------------------------------------------
637 .SS "排版程序 Formatter Programs"
638 .\" --------------------------------------------------------------------
642 排版程序是一个解释用 roff 排版语言或 roff 宏包写成的文档的程序。
645 .IR "intermediate output" ,
646 将送入单一设备后处理器。后处理器必须在排版程序的命令行选项中指定。
651 roff 排版程序的输出以另外一种语言表示:
652 .IR "intermediate output format"
661 中间输出语言与高级的 roff 语言相比像一种汇编指令语言。
663 产生的中间输出是为一种特定的设备优化过的,
667 roff 排版程序是整个 roff 系统的核心。
679 (is used as a general term to refer to both formatters)。
682 .\" --------------------------------------------------------------------
683 .SS "设备 后处理器 Devices and Postprocessors"
684 .\" --------------------------------------------------------------------
686 设备是类似打印机、字符或图形终端等的硬件接口,
687 或者是用于转换为另一种字符或图形设备的软件接口
690 后处理器是将 troff 输出转化为一种适于某种特殊设备的格式的程序。
692 对于输出目标来说,roff 后处理器像是它们的设备驱动
697 后处理器解释中间输出,产生设备相关的代码,传送给设备
707 旧的硬件不再存在,旧的图形转换程序与现代同等功能的程序相比太不精确了
712 在传统 troff 中分辨率是 720,而 groff 的
717 现在,操作系统为大多数类似打印机的硬件提供了设备驱动,
721 .\" --------------------------------------------------------------------
722 .SH "roff 编程 ROFF PROGRAMMING"
723 .\" --------------------------------------------------------------------
725 roff 文档是加入了 roff 排版元素的普通文档。
728 它几乎是一个完整的程序语言,并且提供了扩充自身的元素。
730 使用这些元素,就可以开发为特殊程序定制的宏包。
732 这样的宏包比普通的 roff 要容易上手得多。
738 .\" --------------------------------------------------------------------
739 .SS "宏包 Macro Packages"
740 .\" --------------------------------------------------------------------
742 宏包是一些适于以便利的办法格式化某种特殊文档的宏的集合。
752 所有 tmac 文件保存在标准位置的一个或多个目录中。
762 它们也可以在文档中指定,使用 roff 语言的 “包含文件” 命令,参见
770 处理 BSD 样式的手册页;此类书籍、文档和信件的宏集合是
777 .IR "Manuscript Macros\/" ),
781 .IR "Memorandum Macros\/" ).
784 .\" --------------------------------------------------------------------
785 .SS "roff 排版语言 The roff Formatting Language"
786 .\" --------------------------------------------------------------------
788 传统的 roff 排版语言记述在 troff 用户手册
789 .I Troff User's Manual
793 roff 语言是完整的编程语言,提供了命令 (request),宏定义,转义序列 (escape sequence),
794 字符串变量,数字或数量寄存器 (number or size registers),还有流程控制语句
798 “命令” 是预定义的基础的排版命令,与 shell 提示下的命令类似。
800 用户可以定义类似 “命令” 的元素,使用 roff 的 “预定义” 元素。
805 文档作者不会体会到 命令和宏 之间用法的任何区别;
806 它们都写在一行中,并以一个点 (dot, `.') 开始
810 “转义序列” 是以反斜杠 (backslash,
813 它们可以被插入到任何地方,包括文本的一行中间。
821 插入行内注释,它们也可以转义特殊的控制字符,像这样
848 .\" --------------------------------------------------------------------
849 .SH "文件扩展名 FILE NAME EXTENSIONS"
850 .\" --------------------------------------------------------------------
852 手册页使用章节号作为文件扩展名,例如本文档的文件名是
874 但是没有 roff 文档统一的命名方式,尽管
880 也许应当有 roff 文件扩展名的一个标准
887 它提供了用单一的方式打开各种输入的可能性,
893 .ShellCommand LESSOPEN='|lesspipe %s'
897 可以是一个系统提供的命令或者是你自己的脚本。
900 .\" --------------------------------------------------------------------
901 .SH "编辑 EDITING ROFF"
902 .\" --------------------------------------------------------------------
904 最好的 roff 文档编辑器是 Emacs,参见
908 模式,适于所有种类的 roff “方言”。
914 .RI ` "M-x nroff-mode" '
926 也可以在编辑器加载文件的时候,自动改变模式
933 .B \*[Comment] Local Variables:
934 .B \*[Comment] mode: nroff
939 有一系列的文件扩展名,例如手册页的扩展名,会自动触发 nroff 模式
944 .B \*[Comment] \%-*-\ nroff\ -*-
946 作为文件的第一行,也可以使 emacs 在加载文件时启用 nroff 模式。
953 所有的 roff 排版程序都提供了自动的断行以及水平和竖直间距。
958 不要在 roff 文档中包含空行或只包含空格的行,
960 而是使用“空行”命令 (一行中只包含一个点),或者一行注释
965 不要在行首用空格,因为这会导致不可预测的行为。
967 段落缩进可以以受控的方式,用 roff 命令构造出来
970 每句话应当放到自己的一行中,因为句号后面的空格的处理方法是根据它结束的是短语还是句子而不同的。
972 要区别这两种情况,在每句话后面加上一个换行
975 另外要使用 Emacs 的 auto-fill 模式的话,最好在每句话后面添加一个空的 roff 命令 (一行中只包含一个点)
978 下面的例子显示了最佳的 roff 编辑习惯是怎样的
987 行;类似 `cf.' 这样的短语可以很容易地
992 (译注:如果使用中文的标点“。”就不用考虑这些,
993 但是每句话后面换行总是个好主意。少用 `.' 为妙)
997 除了 Emacs,其他一些编辑器也提供了 nroff 格式文件的支持,例如
1004 .\" --------------------------------------------------------------------
1006 .\" --------------------------------------------------------------------
1011 但是在 Caldera 在 2001 年收购 SCO UNIX 之后,事情发生了极大的好转
1014 (译注:为什么 2003 年 SCO 又会成为 M$ 的走狗呢?)
1017 .\" --------------------------------------------------------------------
1019 .\" --------------------------------------------------------------------
1023 讲述传统 troff 的原始文档仍可获得,groff 的所有方面也都详细地记录在文档中
1026 .\" --------------------------------------------------------------------
1027 .SS "Internet sites"
1028 .\" --------------------------------------------------------------------
1032 .URL http://\:www.troff.org "“历史上的 troff”"
1033 提供了 roff 所有历史方面的概述和指引。
1035 这个网站仍在建设;但是,它将成为 roff 历史的主要来源
1039 .URL http://\:www.multicians.org "“Multics 的官方站点”"
1040 包含很多 MIT 的项目的信息,CTSS,Multics,早期的 Unix,还包括
1042 尤其有用的是一个术语字典,还有很多到古老的文档的链接
1046 .URL http://\:www.tuhs.org/\:Archive/ \
1049 提供了古老的 Unix 的源码和一些二进制文件
1050 (包括 troff 的源码和它的文档),它们
1051 是 Caldera 自 2001 年以来公开的,例如著名的 Unix 版本\~7
1053 .URL http://\:www.tuhs.org/\:Archive/\:PDP-11/\:Trees/\:V7 \
1057 Developers at AT&T Bell Labs
1058 .URL http://\:cm.bell-labs.com/\:cm/\:index.html \
1065 .URL http://\:plan9.bell-labs.com "“Plan\~9 操作系统”"
1067 AT&T Bell Labs 贝尔实验室的作品
1071 .URL http://web.mit.edu/\:Saltzer/\:www/\:publications/\:pubs.html \
1072 "“Jerry Saltzer 的主页”"
1074 保存了古老的 runoff 排版语言写成的一些文档
1078 .URL http://\:cm.bell-labs.com/\:cm/\:cs/\:cstr.html \
1081 保存了原始的 troff 手册 (CSTR #54, #97, #114, #116, #122)
1086 .URL http://\:www.gnu.org/\:software/\:groff "“groff 的官方网站”"
1087 提供了 自由的 roff 实现:groff,并且它是 roff 的事实标准
1090 .\" --------------------------------------------------------------------
1091 .SS "历史文档 Historical roff Documentation"
1092 .\" --------------------------------------------------------------------
1103 .URL http://\:cm.bell-labs.com/\:cm/\:cs/\:54.ps \
1104 "\fINroff/\:Troff User's Manual\fP" ;
1106 (《用户手册》) Bell Labs, 1976; revised by Brian Kernighan, 1992.
1112 .URL http://\:cm.bell-labs.com/\:cm/\:cs/\:97.ps \
1113 "\fIA Typesetter-independent TROFF\fP" ,
1115 (《设备无关的 troff》) Bell Labs, 1981, revised March 1982.
1118 将 roff 作为一种“小语言”("little language") 来讲述的论文有
1122 Jon L. Bentley and Brian W. Kernighan,
1123 .URL http://\:cm.bell-labs.com/\:cm/\:cs/\:114.ps \
1124 "\fIGRAP \(em A Language for Typesetting Graphs\fP" ;
1126 (《grap: 一种图形排版语言》) Bell Labs, August 1984.
1131 .URL http://\:cm.bell-labs.com/\:cm/\:cs/\:116.ps \
1132 "\fIPIC -- A Graphics Language for Typesetting\fP" ;
1134 (《pic: 一种排版用的图形控制语言》) Bell Labs, December 1984.
1138 J. L. Bentley, L. W. Jelinski, and B. W. Kernighan,
1139 .URL http://\:cm.bell-labs.com/\:cm/\:cs/\:122.ps \
1140 "\fICHEM \(em A Program for Typesetting Chemical Structure Diagrams, \
1141 Computers and Chemistry\fP" ;
1143 (《chem: 排版化学结构图的程序,计算机与化学》) Bell Labs, April 1986.
1146 .\" --------------------------------------------------------------------
1147 .SS "手册页 Manual Pages"
1148 .\" --------------------------------------------------------------------
1150 由于它结构复杂,完整的 roff 系统包含很多很多手册页,
1153 不幸的是,不同的 roff 实现之间,它们的手册没有相同的命名格式
1160 包含了 groff 相关的所有文档的索引
1168 .\" --------------------------------------------------------------------
1170 .\" --------------------------------------------------------------------
1172 Copyright (C) 2000, 2001, 2002 Free Software Foundation, Inc.
1175 This document is distributed under the terms of the FDL (GNU Free
1176 Documentation License) version 1.1 or later.
1178 You should have received a copy of the FDL on your system, it is also
1179 available on-line at the
1180 .URL http://\:www.gnu.org/\:copyleft/\:fdl.html "GNU copyleft site" .
1188 .MTO bwarken@mayn.de "Bernd Warken" ;
1190 .MTO wl@gnu.org "Werner Lemberg".
1194 .B bbbush <bbbush@163.com>
1197 .SH "《中国linux论坛man手册翻译计划》:"
1198 .BI http://cmpp.linuxforum.net
1200 .\" --------------------------------------------------------------------
1202 .\" --------------------------------------------------------------------
1204 .\" Local Variables: