EN JA
GROFF_MDOC(7)
GROFF_MDOC(7) FreeBSD Miscellaneous Information Manual GROFF_MDOC(7)

名称

groff_mdocgroff mdoc の実装に関するリファレンス

書式

groff -mdoc file ...

解説

GNU troff(1) 用の コンテントベース でかつ 領域ベース な書式設定用パッケージである -mdoc マクロパッケージを使って UNIX マニュアルページを書くための完全なリファレンスです。前身である -man(7) パッケージは、フォントの操作や他の写植方法の詳細は、個々の作者に任せ、ページのレイアウトを取り扱ってきました。 -mdoc では、ページレイアウトマクロは、タイトル、セクションのヘッダ、ディスプレイ、リストのマクロからなる ページ構造領域 を形成しています。本質的にこれらの要素は、書式設定されたページにおけるテキストの物理的位置に影響を与えます。ページ構造領域に加え、さらに マニュアル 領域と 一般 テキスト領域の 2 つの領域があります。一般テキスト領域は、テキストの一部をクォートしたり強調したりといったような作業を実行するマクロとして定義されています。マニュアル領域は、コマンドやルーチン、それに UNIX の関連ファイルを記述するための日常使用されるインフォーマルな言葉のサブセットであるマクロとして定義されています。マニュアル領域のマクロは、コマンド名、コマンド行の引数とオプション、関数名、関数のパラメータ、パス名、変数名、他のマニュアルページへのクロスリファレンスなどを扱います。これらの領域の項目は、作者とマニュアルページの将来のユーザの両者にとって価値のあるものです。マニュアル間で一貫性を高めることによって将来のドキュメントツールへの移行が容易になることが期待されます。

UNIX マニュアルページ全体を通して、マニュアルのエントリは、単純にマニュアルページ (a man page) とみなされます。これは、実際のページ数と関係ありませんし、性差別をする意図もありません。

さあ、始めよう

このドキュメントの残りの部分で説明されている題材は、以下のような構成になっています。
  1. TROFF に特有な表現
    マクロの使用方法
    引数に空白文字を指定する
    行末の空白文字
    特殊文字のエスケープ
    その他の注意点
  2. マニュアルページのテンプレート
  3. 使用法
  4. タイトルマクロ
  5. マニュアル領域と一般テキスト領域の紹介
    この名前には何が...
    一般的な構文
  6. マニュアル領域
    アドレス
    作者名
    引数
    コンフィギュレーション宣言 (セクション 4 のみ)
    コマンド修飾子
    定義済みの変数
    errno (セクション 2 のみ)
    環境変数
    フラグ
    関数の宣言
    関数の型
    関数 (ライブラリルーチン)
    関数の引数
    戻り値
    終了ステータス
    対話的なコマンド
    ライブラリ名
    リテラル
    名称
    オプション
    パス名
    標準
    変数の型
    変数
    マニュアルページのクロスリファレンス
  7. 一般テキスト領域
    AT&T マクロ
    BSD マクロ
    NetBSD マクロ
    FreeBSD マクロ
    DragonFly マクロ
    OpenBSD マクロ
    BSD/OS マクロ
    UNIX マクロ
    強調マクロ
    フォントモード
    囲い/クォートマクロ
    無操作または通常テキストマクロ
    空白なしマクロ
    セクションのクロスリファレンス
    記号
    数式記号
    参考文献と引用
    商標名 (頭字語とタイプ名)
    拡張引数
  8. ページ構造領域
    セクションヘッダ
    サブセクションヘッダ
    段落と行スペース
    キープ
    例示とディスプレイ
    リストとカラム
  9. その他のマクロ
  10. 定義済みの文字列
  11. 診断
  12. GROFF, TROFF と NROFF を使用した書式設定
  13. 関連ファイル
  14. 関連項目
  15. バグ

TROFF に特有な表現

-mdoc パッケージは、マニュアルページを記述するプロセスを簡単にすることを目的としています。 -mdoc を使うために GNU troff(1) のゴタゴタした詳細を学ぶ必要がないのが理想ですが、いくつか片付けるべき避けられない制限事項があります。また、このパッケージは、高速で ない ということも予め警告しておきます。

マクロの使用方法

GNU troff(1) のように、マクロは、‘ .’ (ドット) を行頭に置き、それに続けて 2 文字 (または 3 文字) からなるマクロの名称を指定することによって呼び出されます。ドットとマクロの間には、スペースかタブを置くことができます。引数は、マクロの後にスペースで区切って指定することができます (タブは、使用 できません)。行頭にドットを指定することによって GNU troff(1) にそれに続く 2 文字 (あるいはそれより多い文字) をマクロ名として解釈するよう指示しています。最初にドット 1 文字をとり、その後ろに何も来ない場合は、無視されます。マクロを起動させたくないような文脈で、入力行の先頭に‘ .’ (ドット) を置くためには、‘ .’ (ドット) の前にエスケープシーケンス‘ \&’を指定します。‘ \&’は、文字通りスペース幅が 0 として解釈され、出力には現れません。

一般的に GNU troff(1) マクロは、取り得る引数の数に制限はありません (9 つ以上の引数を扱うことのできない他のバージョンの troff とは違います)。限られた場合ではありますが、引数を次の行に続けたり、拡張したりすることができます (後述の 拡張引数 のセクションを参照)。ほとんどすべてのマクロで引用符に囲まれた引数を扱うことができます (後述の 引数に空白文字を指定する のセクションを参照)。

-mdoc での一般テキスト領域とマニュアル領域のほとんどのマクロは、呼び出し可能なマクロ名を決定するためにその引数のリストが 構文解析 されるという点で特別なものです。これは、つまり、一般テキスト領域またはマニュアル領域のマクロ名に一致し (かつ、呼び出し可能であると定義された) 引数リスト中の引数は、処理される時に実行されるか、もしくは呼び出されるということです。この場合、引数がマクロの名前であっても‘ .’ (ドット) で前置されません。このようにしてたくさんのマクロを入れ子にすることができます。例えばオプションマクロ‘ .Op’は、フラグマクロと引数マクロ‘ Fl’と‘ Ar’を 呼び出し て、オプションのフラグを引数とともに指定することができます:

[ -s bytes]
は、‘ .Op Fl s Ar bytes’で生成されます。

文字列がマクロ名と解釈されないようにするには、その文字列の前にエスケープシーケンス‘ \&’を指定します。

[ Fl s Ar bytes]
は、‘ .Op \&Fl s \&Ar bytes’で生成されます。

ここで文字列‘ Fl’と‘ Ar’は、マクロとして解釈されていません。このドキュメントを通じて、呼び出し可能な引数を調べるために引数リストが構文解析されるマクロは、 構文解析される マクロとして参照し、引数リストから呼び出されることができるマクロは、 呼び出し可能 なマクロとして参照します。 -mdoc のマクロは、ほとんどすべてが構文解析されるのですから、これは、技術的には 適当でない 表現ですが、常にマクロを「呼び出し可能である」とか「他のマクロを呼び出すことができる」と表現するのは面倒なことであるため、「構文解析される」という用語を使います。

以降、この区別が必要な場合、行頭 (でドットで開始する) -mdoc マクロを コマンド と呼びます。

引数に空白文字を指定する

1 つ以上の空白文字を含む文字列を引数として指定したい場合があります。引数リスト中の要素が特定の並びをしていることを期待しているコマンドに引数を指定する時に必要になることがあります。さらに、こうすると -mdoc が速く実行されるようになるのです。例えば、関数コマンド‘ .Fn’では、第 1 引数は、関数名であり、残りの引数が関数のパラメータであると想定されています。 ANSI C では、関数のパラメータ宣言を括弧で囲まれたパラメータリスト中に明示することを規定しているので、各パラメータは、最低でも 2 語の文字列となります。例えば、 int foo のようになります。

空白を含む引数を指定するには、2 通りの方法があります。 1 つは、空白を含む文字列を渡すのに、固定の空白、つまりパディングされない空白文字‘ ’を使う方法です。すなわち、空白の前にエスケープ文字‘ \’を指定します。この方法は、どのマクロでも使うことができますが、1 行が長くなり過ぎたテキストを調整するときの邪魔になるという副作用があります。 troff では、固定の空白は、他の印刷可能な文字と同様に扱われ、通常期待されるようにその箇所で文字列を空白や改行で分けることは行われなくなります。この方法は、文字列が行の境界にまたがることが好ましくない場合に有用です。代替案としては、パディング可能 (すなわち伸長可能) で分割不可能な空白‘ \~’を使うことがあります (これは、 GNU troff(1) 拡張です)。 2 つ目の方法は、文字列をダブルクォートで括ることです。

例えば、次のようにします:

fetch( char *str)
は、‘ .Fn fetch char\ *str’で生成されます。
fetch( char *str)
は、また‘ .Fn fetch "char *str"’でも生成することができます。

もし、最初の例の空白の前もしくは次の例のダブルクォートの前の‘ \’が省略されていた場合には、‘ .Fn’は、引数が 3 つであるとみなし、その結果は、

fetch( char, *str)

となります。

行末の空白文字

troff は、行末に空白文字があると混乱してしまうことがあります。<空白><行末>の文字の並びからすべての空白文字を取り除くのは良い予防策です。どうしても行末に空白文字をおく必要性が出てきた場合は、パディングされない空白とエスケープ文字‘ \&’を使用することによって対応できます。例えば、‘ string\ \&’のようにします。

特殊文字のエスケープ

改行‘ \n’のような特殊文字は、バックスラッシュを保存するために‘ \’を‘ \e’で置き換え (たとえば‘ \en’とする) て扱います。

その他の注意点

表示領域外で空の入力行が見つかった場合には、警告が発生します (後述)。代わりに‘ .sp’を使用してください ( -mdoc マクロを使用して、低レベルコマンドを使用しないようにするとずっと良いです)。

先頭に空白を置くと行分割が生じ、そのまま出力されてしまいます。可能ならばこうなることを避けてください。同様に、通常のテキスト行において単語間に 2 つ以上の空白文字を使用しないでください。これは、他のテキストフォーマッタとは対照的です。空白文字を 2 つ以上置いても 1 つの空白文字に置き換わり ません

引数として‘ "’を直接渡すことはできません。代わりに‘ \*[q]’ (あるいは‘ \*q’) を使用してください。

デフォルトでは、 troff(1) は、文を終了させる句読点の後に空白文字を 2 つ挿入します。つまり、‘ )’あるいは‘ '’などの文字は、そのまま扱われ、文の終了には影響を与えません。この動作を変更するには、ドットの前あるいは後に‘ \&’を挿入してください。

The 
.Ql . 
character. 
.Pp 
The 
.Ql \&. 
character. 
.Pp 
.No test . 
test 
.Pp 
.No test. 
test

は、

The ‘ ’. character.

The ‘ .’ character.

test. test

test. test

 

となります。

1 行目と 3 行目にみられるように、 -mdoc は、マクロ引数の中では句読点を特別に扱います。これについては、後述の 一般的な構文 の節で述べます。同様の方法で、幅 0 の空白を続けることで、省略形の後に続いたピリオドを保護しなくてはなりません。例えば‘ e.g.\&’のようにします。

マニュアルページのソースファイル中のコメントは、独立した行では、‘ .\"’、何らかの入力があった後では、‘ \"’を、あるいはどのような場所でも使いたい場合は、‘ \#’を使うことができます (後者は、 GNU troff(1) 拡張です)。このような行の残りの部分は、無視されます。

マニュアルページのテンプレート

マニュアルページの中身は、次のような基本的なテンプレートから簡単に作成できます。

.\"以下のコマンドは、すべてのマニュアルページで必要な項目です。 
.Dd 月日, 年 
.Dt ドキュメントタイトル [セクション番号] [アーキテクチャ/ボリューム] 
.Os [オペレーティングシステム] [バージョン/リリース] 
.Sh NAME 
.Nm 名称 
.Nd 名称についての 1 行での説明 
.\"次のコマンドは、セクション 2, 3 でのみ必要なものです。 
.\" .Sh LIBRARY 
.Sh SYNOPSIS 
.Sh DESCRIPTION 
.\"以下のコマンドについては、必要に応じてコメントをはずして使用して 
.\"ください。 
.\" .Sh IMPLEMENTATION NOTES 
.\"この次のコマンドは、セクション 2, 3, 9 でのみ必要な、関数の 
.\"戻り値です。 
.\" .Sh RETURN VALUES 
.\"次のコマンドは、セクション 1, 6, 7, 8, 9 でのみ必要なものです。 
.\" .Sh ENVIRONMENT 
.\" .Sh FILES 
.\" .Sh EXAMPLES 
.\"次のコマンドは、セクション 1, 6, 7, 8, 9 でのみ必要なものです。 
.\"     ((シェルへの)コマンドの戻り値と 
.\"       fprintf/stderr タイプの診断です) 
.\" .Sh DIAGNOSTICS 
.\" .Sh COMPATIBILITY 
.\"次のコマンドは、セクション 2, 3, 9 でのみ必要な、 
.\"     エラーハンドリングとシグナルハンドリングです。 
.\" .Sh ERRORS 
.\" .Sh SEE ALSO 
.\" .Sh STANDARDS 
.\" .Sh HISTORY 
.\" .Sh AUTHORS 
.\" .Sh BUGS

このテンプレートにおける最初のコマンドは、マクロ‘ .Dd’, ‘ .Dt’と‘ .Os’であり、それぞれドキュメントの日付、マニュアルページもしくは題材となっているソースの開発や変更の対象となったオペレーティングシステム、そしてマニュアルページのタイトルを属するマニュアルのセクション番号とともに ( 大文字で) 指定したもの、となっています。これらのコマンドは、そのページを識別するものであり、後述の タイトルマクロ で解説されます。

テンプレート中の残りの項目は、セクションのヘッダ ( .Sh) であり、それらのうち NAME, (名称) SYNOPSIS (書式) と DESCRIPTION (解説) は、必須項目です。これらのヘッダについては、 マニュアル領域 を説明した後、 ページ構造領域 で解説されます。いくつかのコンテントマクロは、ページレイアウトマクロの説明に使用されていますので、ページレイアウトマクロの前にコンテントマクロについて読むことを推奨します。

使用法

次に説明するマクロは、すべて、オプションの引数は、角括弧 ([]) で括られます。省略符号 (‘...’) は、さらに 0 個以上の引数があることを表しています。パラメータの代替値は、‘ |’で区切って示します。必須パラメータに代替値がある場合は、 (‘ |’と一緒に) 中括弧 ({}) を用い、値の組を括ります。メタ変数は、山括弧 (<>) の中で指定されます。

例:

.Xx <foo>{bar1 | bar2}[ -test1 [ -test2 | -test3]] ...

とくに明示しない限り、すべてのマクロは、構文解析され、呼び出し可能なものです。

マクロの効果が持続するのは、次のネストしたマクロまでであることに注意してください。例えば‘ .Ic foo Aq bar’は、‘ foo <bar>’とはならず‘ foo <bar>’となります。この結果、最初の引数がマクロである場合、ほとんどのコマンドに対して警告が出力されます。マクロがコマンド呼び出しの効果を完全に打ち消してしまうからです。また、マクロをクォートしても、文字通りのクォートは、挿入されないことは重要です。‘ foo <bar>’は、‘ .Ic "foo <bar>"’から生成されます。

大部分のマクロは、デフォルトの幅の値を持っており、これを‘ .Bl’と‘ .Bd’マクロ用にラベル width ( -width) あるいは offset ( -offset) を指定するのに使用することができます。 -mdoc パッケージのローカルな変更に依存することのないように、このとても曖昧な機能は、使わないことを推奨します。

タイトルマクロ

タイトルマクロは、ページ構造領域の一部ですが、マニュアルページを昨日書き始めようと思ったという人のために、最初に、他のとは別に記述されています。 3 つのヘッダマクロでドキュメントまたはマニュアルページのタイトル、オペレーティングシステム、と原著の日付を指定します。これらのマクロは、ドキュメントの最初で一度だけ呼び出されるもので、ヘッダとフッタを構成するためだけに使用されます。
.Dt [ <ドキュメントタイトル>][ <セクション番号>][ <ボリューム>]
ドキュメントタイトルは、マニュアルページの主題であり、 troff の制限により大文字でなければいけません。省略された場合、‘UNTITLED’が使われます。セクション番号は、 1, ..., 9 の範囲の番号もしくは‘ unass’, ‘ draft’, ‘ paper’のいずれかを取ることができます。セクション番号が指定されており、ボリューム名が与えられていない場合には、デフォルトのボリューム名が使用されます。

では、次のセクションが定義されています:

1
2
3
4
5
6
7
8
9

ボリューム名は、任意であるか、もしくは次のものを取ることができます:

USD
PS1
AMD
SMM
URM
PRM
KM
IND
LOCAL
CON

互換性を保つため、‘ IND’の代わりに‘ MMI’を使用することができ、‘ LOCAL’の代わりに‘ LOC’を使用できます。先の表の値は、新しいボリューム名を指定します。第 3 パラメータがコンピュータアーキテクチャを表すキーワードである場合、その値は、第 2 パラメータで指定したボリューム名の前に追加されます。デフォルトでは、次のアーキテクチャに関するキーワードが定義されています:

 

acorn26, acorn32, algor, alpha, amd64, amiga, amigappc, arc, arm, arm26, arm32, armish, atari, aviion, beagle, bebox, cats, cesfic, cobalt, dreamcast, emips, evbarm, evbmips, evbppc, evbsh3, ews4800mips, hp300, hp700, hpcarm, hpcmips, hpcsh, hppa, hppa64, i386, ia64, ibmnws, iyonix, landisk, loongson, luna68k, luna88k, m68k, mac68k, macppc, mips, mips64, mipsco, mmeye, mvme68k, mvme88k, mvmeppc, netwinder, news68k, newsmips, next68k, ofppc, palm, pc532, playstation2, pmax, pmppc, powerpc, prep, rs6000, sandpoint, sbmips, sgi, sgimips, sh3, shark, socppc, solbourne, sparc, sparc64, sun2, sun3, tahoe, vax, x68k, x86_64, xen, zaurus

セクション番号が 1 から 9 の範囲の数値ではなく、また前述のキーワードでない場合、第 3 パラメータがそのままボリューム名として使用されます。

次の例では、マニュアルページのヘッダの左側 (これは、右側と同じものです) と中央に書かれる文字列を示しています。‘ \&’が数値 7 を正当な数値として解釈されないようにしている点に注意してください。

.Dt FOO 7
FOO(7)’‘
.Dt FOO 7 bar
FOO(7)’‘
.Dt FOO \&7 bar
FOO(7)’‘ bar
.Dt FOO 2 i386
FOO(2)’‘ /
.Dt FOO "" bar
FOO’‘ bar

ローカルな追加項目や OS に特化した追加項目が、ファイル mdoc.local にあるかもしれません。このファイル中で‘ volume-ds-XXX’ (前者のタイプについて) と‘ volume-as-XXX’ (後者のタイプについて) という名前の文字列を検索してください。ここで‘ XXX’は、‘ .Dt’マクロで使用されるキーワードを表しています。

このマクロは、呼び出し不可能であり、構文解析もされません。

.Os [ <オペレーティングシステム>][ <リリース番号>]
第 1 パラメータが空の場合、デフォルト値‘’が使用されます。これは、ローカルの設定ファイル mdoc.local で上書きできます。一般的には、オペレーティングシステムの名称には、一般的な頭字語 (略称) を使わなければなりません。例えば BSD や ATT といったものです。リリース番号は、各システムでの標準のリリースの命名法を使用します。次の表では、いくつか事前に定義されているオペレーティングシステムに対して取り得る第 2 引数をリストしています。‘ .Dt’と同じように、ローカルな追加項目が mdoc.local に定義されているかもしれません。このファイル中で‘ operating-system-XXX-YYY’という名前の文字列を検索してください。ここで‘ XXX’は、オペレーティングシステムの頭字語 (略称) そして‘ YYY’がリリース ID です。
ATT
7th, 7, III, 3, V, V.2, V.3, V.4
BSD
3, 4, 4.1, 4.2, 4.3, 4.3t, 4.3T, 4.3r, 4.3R, 4.4
NetBSD
0.8, 0.8a, 0.9, 0.9a, 1.0, 1.0a, 1.1, 1.2, 1.2a, 1.2b, 1.2c, 1.2d, 1.2e, 1.3, 1.3a, 1.4, 1.4.1, 1.4.2, 1.4.3, 1.5, 1.5.1, 1.5.2, 1.5.3, 1.6, 1.6.1, 1.6.2, 1.6.3, 2.0, 2.0.1, 2.0.2, 2.0.3, 2.1, 3.0, 3.0.1, 3.0.2, 3.0.3, 3.1, 3.1.1, 4.0, 4.0.1, 5.0, 5.0.1, 5.0.2, 5.1, 6.0
FreeBSD
1.0, 1.1, 1.1.5, 1.1.5.1, 2.0, 2.0.5, 2.1, 2.1.5, 2.1.6, 2.1.7, 2.2, 2.2.1, 2.2.2, 2.2.5, 2.2.6, 2.2.7, 2.2.8, 3.0, 3.1, 3.2, 3.3, 3.4, 3.5, 4.0, 4.1, 4.1.1, 4.2, 4.3, 4.4, 4.5, 4.6, 4.6.2, 4.7, 4.8, 4.9, 4.10, 4.11, 5.0, 5.1, 5.2, 5.2.1, 5.3, 5.4, 5.5, 6.0, 6.1, 6.2, 6.3, 6.4, 7.0, 7.1, 7.2, 7.3, 8.0, 8.1, 8.2, 9.0
OpenBSD
2.0, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6, 2.7, 2.8, 2.9, 3.0, 3.1, 3.2, 3.3, 3.4, 3.5, 3.6, 3.7, 3.8, 3.9, 4.0, 4.1, 4.2, 4.3, 4.4, 4.5, 4.6, 4.7, 4.8, 4.9, 5.0
DragonFly
1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.8, 1.8.1, 1.10, 1.12, 1.12.2, 2.0, 2.2, 2.4, 2.6, 2.8, 2.9, 2.9.1, 2.10, 2.10.1, 2.11
Darwin
8.0.0, 8.1.0, 8.2.0, 8.3.0, 8.4.0, 8.5.0, 8.6.0, 8.7.0, 8.8.0, 8.9.0, 8.10.0, 8.11.0, 9.0.0, 9.1.0, 9.2.0, 9.3.0, 9.4.0, 9.5.0, 9.6.0, 9.7.0, 9.8.0, 10.1.0, 10.2.0, 10.3.0, 10.4.0, 10.5.0, 10.6.0, 10.7.0, 11.0.0

ATT に関しては、判別できない第 2 パラメータがある時には、それを文字列 UNIX に置き換えます。事前に定義されているその他の頭字語 (略称) については、そのようなパラメータは、無視され、警告メッセージが出力されます。認識できない引数は、ページフッタ中に記述された通りに表示されます。例えば、典型的なフッタは、次のようになるでしょう:

.Os BSD 4.3

は、‘ 4.3 Berkeley Distribution’となります。また、ローカルで作られたセットの例では、

.Os CS Department

は、‘ CS Department’となります。

.Os’マクロがない場合、ページの左下隅は、見苦しくなってしまうでしょう。

このマクロは、呼び出し不可能であり、構文解析もされません。

.Dd [ <月><日>, <年>]
Dd’に引数がない場合は、日付には、‘ 基準時点 (協定世界時 1970年1月1日 00:00:00)’が使用されます。ちょうど 3 つ引数がある場合には、それらは、連結され、分割できない空白で分けられたものになります。

.Dd January 25, 2001

月の名前は、簡略化されないでしょう。

他の数値の引数があっても、パラメータを無視して、現在の日付が使用されます。

このマクロは、呼び出し不可能であり、構文解析もされません。

マニュアル領域と一般テキスト領域の紹介

この名前には何が...

マニュアル領域のマクロ名は、コマンドやサブルーチン、それに関連ファイルを説明するために使われている日常のインフォーマルな言葉から取られています。この言葉と少し違うバリエーションのものがマニュアルページを書く上での 3 つの異なった側面を記述するのに使われます。最初のものは、 -mdoc マクロコマンド使用方法の説明です。 2 番目は、 -mdoc マクロを 用いた UNIX コマンドの記述です。 3 番目は、コマンドを通常の言葉の感覚でユーザに示したものです。これは、すなわち、マニュアルページのテキスト中でのコマンドの説明となります。

最初のケースでは、 troff(1) マクロは、それ自身、一種のコマンドとなっています。 troff コマンドは、一般的に以下のような形式をとります。

.Xx argument1 argument2 ...

.Xx’は、マクロコマンドを示しており、それに続くものは、すべて処理されるべき引数として処理されます。 2 番目のケースでは、コンテントマクロを使用する UNIX コマンドの記述がもう少し含まれます。典型的な SYNOPSIS (書式) コマンド行は、このように表示されます。

filter [ -flag]< infile>< outfile>

ここで filter は、コマンド名であり、角括弧で囲まれた文字列 -flag は、 フラグ 引数で、これは、角括弧で囲むことによってオプションであることを示しています。 -mdoc の用語では、< infile>と< outfile>は、 メタ引数 と称されています。この例では、ユーザは、山括弧 (<>) の中で与えられたメタ引数を実際のファイル名に置き換えなくてはなりません。このドキュメントでは、メタ引数は、 -mdoc コマンドを記述するのに使用していることに注意してください。多くのマニュアルページでは、メタ変数は、わざわざ山括弧を使って書かれていません。上の例を書式設定したマクロは、以下のものです。

.Nm filter 
.Op Fl flag 
.Ao Ar infile Ac Ao Ar outfile Ac

3 番目のケースでは、コマンドの説明や構文に上記の例の両方が使われ、さらに細かい記述が追加されるでしょう。上の例での引数< infile>と< outfile>は、 オペランド もしくは ファイル引数 として参照されます。コマンド行の引数のリストは、かなり長くなる場合もあります。

make
[ -eiknqrstv][ -D variable][ -d flags][ -f makefile][ -I directory][ -j max_jobs][ variable= value][ target ...]

ここでは、コマンド make について記述しており、 makefile をフラグ -f の引数としています。またオプションのファイルオペランドである target についても言及しています。言葉での説明では、こういった詳細な記述が混乱を防いでくれますが、 -mdoc パッケージには、フラグ への 引数のためのマクロがありません。その代わりに target のようなオペランドやファイル引数に使われる引数マクロ‘ Ar’が variable のようなフラグへの引数と同様に使われます。この make コマンド行は、次の指定により生成されています。

.Nm make 
.Op Fl eiknqrstv 
.Op Fl D Ar variable 
.Op Fl d Ar flags 
.Op Fl f Ar makefile 
.Op Fl I Ar directory 
.Op Fl j Ar max_jobs 
.Op Ar variable Ns = Ns Ar value 
.Bk 
.Op Ar target ... 
.Ek

マクロ‘ .Bk’と‘ .Ek’は、 キープ セクションにおいて解説されています。

一般的な構文

マニュアル領域のマクロと一般テキスト領域のマクロとは、いくつか小さな違いがあるものの、同様な構文を使用しています。とりわけ、‘ .Ar’, ‘ .Fl’, ‘ .Nm’, と‘ .Pa’は、引数なしで呼び出された時の違いしかありません。また、‘ .Fn’と‘ .Xr’は、引数のリストの順番が異なります。すべてのコンテントマクロが句読点を認識し、それを正しく扱うには、各々の句読点文字が先行する空白で分離されている必要があります。次のようにコマンドが指定されている場合、

.Ar sptr, ptr),

その結果は、以下のようになります。

sptr, ptr),

ここでは、句読点は認識されず、すべての出力は、‘ .Ar’で使用されるフォントで行われています。句読点が空白文字で区切られている場合、

.Ar sptr , ptr ) ,

結果は、以下のようになります。

sptr, ptr),

今度は、句読点が認識され、出力は、デフォルトのフォントで行われ引数文字列とは区別されています。句読点文字の特別な意味を取り除くには、‘ \&’でエスケープしてください。

-mdoc は、次の句読点文字を認識します。

. , : ; (
) [ ] ? !

troff は、マクロ言語としての限界から、以下のような、数学、論理学、引用符の集合のメンバを含んだ文字列を表現するのは困難です。

{+,-,/,*,%,<,>,<=,>=,=,==,&,`,',"}

問題なのは、文字によって示唆されている操作もしくは評価が、実行されるべきであると troff が仮定する場合があることです。これらの文字が予期しない形で評価されないようにするには、‘ \&’でこれらをエスケープしてください。最初のコンテントマクロは、以下の‘ .Ad’において、その典型的な構文が示されています。

マニュアル領域

アドレス

アドレスマクロは、アドレスの構成を識別します。

使い方: .Ad <アドレス> ...

.Ad addr1
addr1
.Ad addr1 .
addr1.
.Ad addr1 , file2
addr1, file2
.Ad f1 , f2 , f3 :
f1, f2, f3:
.Ad addr ) ) ,
addr)),

デフォルトの文字幅は、12n です。

作者名

.An’コマンドは、文書化されている項目の作者の名前、もしくは実際のマニュアルページの作者の名前を指定するために使われます。

使い方: .An <作者名> ...
.An "Joe Author"
Joe Author
.An "Joe Author" ,
Joe Author,
.An "Joe Author" Aq nobody@FreeBSD.org
Joe Author <nobody@FreeBSD.org>
.An "Joe Author" ) ) ,
Joe Author)),

デフォルトの文字幅は、12n です。

AUTHORS (作者) セクションでは、‘ .An’リクエストは、改行を引き起こし、新しい名前がそれぞれの行に表示されます。この動作が望ましくない場合、

.An -nosplit

を呼び出すことで無効にできます。それぞれの行に表示させる動作に戻したい場合は、

.An -split
 

と記述します。

引数

引数マクロ .Ar は、コマンド行の引数を参照する際にはいつでも使用することができます。引数なしで呼ばれた場合、‘ file ...’が出力になります。

使い方: .Ar [ <引数>] ...

.Ar
file ...
.Ar file1
file1
.Ar file1 .
file1.
.Ar file1 file2
file1 file2
.Ar f1 f2 f3 :
f1 f2 f3:
.Ar file ) ) ,
file)),

デフォルト幅は、12n です。

コンフィギュレーション宣言 (セクション 4 のみ)

.Cd’コマンドは、セクション 4 のマニュアルにおいて、デバイスインタフェースの config(8) による宣言の説明に使われます。

使い方: .Cd <引数> ...
.Cd "device le0 at scode?"
device le0 at scode?

SYNOPSIS (書式) セクションでは、‘ .Cd’リクエストは、その引数が表示される前後で改行を入れます。

デフォルト幅は、12n です。

コマンド修飾子

コマンド修飾子は、‘ .Cm’マクロがすべての引数の前にダッシュ文字を付けないことを除いて、‘ .Fl’ (フラグ) コマンドと同じです。伝統的にフラグは、ダッシュ文字に引き続いて指定されますが、この方法を使わないコマンドやコマンドのサブセットもあります。コマンド修飾子は、エディタコマンドのような対話的なコマンドでも指定されることがあります。 フラグ セクションを参照してください。

デフォルト幅は、10n です。

定義済みの変数

インクルードファイルにおいて定義されている変数 (もしくは定数) は、マクロ‘ .Dv’によって指定します。

使い方: .Dv <定義済みの変数> ...

.Dv MAXHOSTNAMELEN
MAXHOSTNAMELEN
.Dv TIOCGPGRP )
TIOCGPGRP)

デフォルト幅は、12n です。

errno

.Er’ errno マクロは、セクション 2, 3, 9 のライブラリルーチンにおけるエラーの戻り値を指定します。下記の 2 番目の例では、‘ .Er’は、一般テキスト領域マクロである‘ .Bq’ (これは、セクション 2 のマニュアルページで使われています) と共に使われています。

使い方: .Er <errno のタイプ> ...

.Er ENOENT
ENOENT
.Er ENOENT ) ;
ENOENT);
.Bq Er ENOTDIR
[ ENOTDIR]

デフォルト幅は、17n です。

環境変数

.Ev’マクロは、環境変数を指定します。

使い方: .Ev <引数> ...

.Ev DISPLAY
DISPLAY
.Ev PATH .
PATH.
.Ev PRINTER ) ) ,
PRINTER)),

デフォルト幅は、15n です。

フラグ

.Fl’マクロは、コマンド行のフラグを扱います。フラグの前には、ダッシュ‘ -’が挿入されます。ダッシュがつかない対話的なコマンドのために‘ .Cm’ (コマンド修飾子) マクロが用意されています。これは、ダッシュを付けないことを除いて同じ働きをします。

使い方: .Fl <引数> ...

.Fl
-
.Fl cfv
-cfv
.Fl cfv .
-cfv.
.Cm cfv .
cfv.
.Fl s v t
-s -v -t
.Fl - ,
--,
.Fl xyz ) ,
-xyz),
.Fl |
| -

引数なしで‘ .Fl’マクロを指定すると、標準入力/標準出力を意味するダッシュとなります。‘ .Fl’マクロにダッシュを 1 つ与えると、2 つのダッシュとなることに注意して下さい。

デフォルト幅は、12n です。

関数の宣言

.Fd’コマンドは、 SYNOPSIS (書式) セクションにおいて、セクション 2 または 3 の関数の説明で使われます。このマクロは、呼び出し不可能であり、構文解析もされせん。

使い方: .Fd <引数> ...

.Fd "#include <sys/types.h>"
#include <sys/types.h>

SYNOPSIS (書式) セクションでは、関数がすでに示されており、改行がまだされていない場合には、‘ .Fd’リクエストは、改行を入れます。これによって前の関数呼び出しと次の関数の宣言の間に最適な行間が設定されます。

.In’マクロは、 SYNOPSIS (書式) セクションで使用すると、 #include 文を表現するものであり、以上の例を短く記述したものです。このマクロは、C プログラム中でインクルードされる C ヘッダファイルを指定します。このマクロも改行を挿入します。

SYNOPSIS (書式) セクション以外で使用すると、山括弧で括られたヘッダファイルを表現します。

使い方: .In <ヘッダファイル>

.In stdio.h
< stdio.h>
.In stdio.h
< stdio.h>

関数の型

このマクロは、 SYNOPSIS (書式) セクションで使うものです。マニュアルページ中の他の場所でも問題なく使うことができますが、セクション 2 と 3 の SYNOPSIS (書式) セクションにおいてカーネルの通常の形式で関数の型を示すことがこのマクロの目的です (このマクロは、関数名が次の行に置かれるように改行を挿入します)。

使い方: .Ft <型> ...

.Ft struct stat
struct stat

関数 (ライブラリルーチン)

.Fn’マクロは、 ANSI C の記法を規範としています。

使い方: .Fn <関数>[ <パラメータ>] ...

.Fn getchar
getchar()
.Fn strlen ) ,
strlen()),
.Fn align "char *ptr" ,
align( char *ptr),

他のマクロを呼び出すと‘ .Fn’呼び出しの終了を意味することに注意してください (閉じ括弧がその箇所に挿入されます)。

多くのパラメータをとる関数 (これは、滅多にないことですが) では、‘ .Fo’マクロ (関数マクロの開始) と‘ .Fc’マクロ (関数マクロの終了) を‘ .Fa’ (関数の引数) と共に使って、この制限を回避することができます。

使用例:

.Ft int 
.Fo res_mkquery 
.Fa "int op" 
.Fa "char *dname" 
.Fa "int class" 
.Fa "int type" 
.Fa "char *data" 
.Fa "int datalen" 
.Fa "struct rrec *newrr" 
.Fa "char *buf" 
.Fa "int buflen" 
.Fc

生成結果:

int res_mkquery( int op, char *dname, int class, int type, char *data, int datalen, struct rrec *newrr, char *buf, int buflen);

SYNOPSIS (書式) セクションでは、関数は、常に行の先頭から開始されます。 SYNOPSIS (書式) セクションにおいて複数の関数が示されており、関数の型が示されない場合、改行が挿入され、現在の関数名とその前の関数名の間に最適な改行量が設定されます。

.Fn’と‘ .Fo’のデフォルト幅の値は、それぞれ 12n と 16n です。

関数の引数

.Fa’マクロは、関数の引数 (パラメータ) をマニュアルの SYNOPSIS (書式) のセクション外で参照する場合、あるいは‘ .Fn’の代わりに‘ .Fo’と‘ .Fc’囲いマクロを使用した場合には、 SYNOPSIS (書式) のセクション内で参照する場合にも使われます。‘ .Fa’は、構造体のメンバを参照する場合にも使われます。

使い方: .Fa <関数の引数> ...

.Fa d_namlen ) ) ,
d_namlen)),
.Fa iov_len
iov_len

デフォルト幅は、12n です。

戻り値

.Rv’マクロは、 RETURN VALUES (戻り値) のセクションで使うテキストを生成します。

使い方: .Rv [ -std][ <関数> ...]

例えば、‘ .Rv -std atexit’は、次のテキストを生成します。

 

The atexit() function returns the value 0 if successful; otherwise the value -1 is returned and the global variable errno is set to indicate the error.

-std オプションは、セクション 2 と 3 のマニュアルページでのみ有効です。現在のところ、このマクロは、 -std フラグなしで使用しても何も起こりません。

終了ステータス

.Ex’マクロは、 DIAGNOSTICS (診断) のセクションで使うテキストを生成します。

使い方: .Ex [ -std][ <ユーティリティ> ...]

例えば‘ .Ex -std cat’は、次のテキストを生成します。

 

The cat utility exits 0 on success, and >0 if an error occurs.

-std オプションは、セクション 1 と 6 と 8 のマニュアルページでのみ有効です。現在のところ、このマクロは、 -std フラグなしで使用しても何も起こりません。

対話的なコマンド

.Ic’マクロは、対話的なコマンド、もしくは内部コマンドを指定します。

使い方: .Ic <引数> ...

.Ic :wq
:wq
.Ic "do while {...}"
do while {...}
.Ic setenv , unsetenv
setenv, unsetenv

デフォルト幅は、12n です。

ライブラリ名

.Lb’マクロは、関数がどのライブラリに組み込まれるかを指定します。

使い方: .Lb <引数> ...

.Lb’マクロに対して使用可能な引数と結果は、次の通りです:

libarchive
Streaming Archive Library (libarchive, -larchive)
libarm
ARM Architecture Library (libarm, -larm)
libarm32
ARM32 Architecture Library (libarm32, -larm32)
libbluetooth
Bluetooth Library (libbluetooth, -lbluetooth)
libbsm
Basic Security Module User Library (libbsm, -lbsm)
libc
Standard C Library (libc, -lc)
libc_r
Reentrant C Library (libc_r, -lc_r)
libcalendar
Calendar Arithmetic Library (libcalendar, -lcalendar)
libcam
Common Access Method User Library (libcam, -lcam)
libcdk
Curses Development Kit Library (libcdk, -lcdk)
libcipher
FreeSec Crypt Library (libcipher, -lcipher)
libcompat
Compatibility Library (libcompat, -lcompat)
libcrypt
Crypt Library (libcrypt, -lcrypt)
libcurses
Curses Library (libcurses, -lcurses)
libdevinfo
Device and Resource Information Utility Library (libdevinfo, -ldevinfo)
libdevstat
Device Statistics Library (libdevstat, -ldevstat)
libdisk
Interface to Slice and Partition Labels Library (libdisk, -ldisk)
libdwarf
DWARF Access Library (libdwarf, -ldwarf)
libedit
Command Line Editor Library (libedit, -ledit)
libelf
ELF Access Library (libelf, -lelf)
libevent
Event Notification Library (libevent, -levent)
libfetch
File Transfer Library (libfetch, -lfetch)
libform
Curses Form Library (libform, -lform)
libgeom
Userland API Library for Kernel GEOM subsystem (libgeom, -lgeom)
libgpib
General-Purpose Instrument Bus (GPIB) library (libgpib, -lgpib)
libi386
i386 Architecture Library (libi386, -li386)
libintl
Internationalized Message Handling Library (libintl, -lintl)
libipsec
IPsec Policy Control Library (libipsec, -lipsec)
libipx
IPX Address Conversion Support Library (libipx, -lipx)
libiscsi
iSCSI protocol library (libiscsi, -liscsi)
libjail
Jail Library (libjail, -ljail)
libkiconv
Kernel-side iconv Library (libkiconv, -lkiconv)
libkse
N:M Threading Library (libkse, -lkse)
libkvm
Kernel Data Access Library (libkvm, -lkvm)
libm
Math Library (libm, -lm)
libm68k
m68k Architecture Library (libm68k, -lm68k)
libmagic
Magic Number Recognition Library (libmagic, -lmagic)
libmd
Message Digest (MD4, MD5, etc.) Support Library (libmd, -lmd)
libmemstat
Kernel Memory Allocator Statistics Library (libmemstat, -lmemstat)
libmenu
Curses Menu Library (libmenu, -lmenu)
libnetgraph
Netgraph User Library (libnetgraph, -lnetgraph)
libnetpgp
Netpgp Signing, Verification, Encryption and Decryption (libnetpgp, -lnetpgp)
libossaudio
OSS Audio Emulation Library (libossaudio, -lossaudio)
libpam
Pluggable Authentication Module Library (libpam, -lpam)
libpcap
Capture Library (libpcap, -lpcap)
libpci
PCI Bus Access Library (libpci, -lpci)
libpmc
Performance Counters Library (libpmc, -lpmc)
libposix
POSIX Compatibility Library (libposix, -lposix)
libprop
Property Container Object Library (libprop, -lprop)
libpthread
POSIX Threads Library (libpthread, -lpthread)
libpuffs
puffs Convenience Library (libpuffs, -lpuffs)
librefuse
File System in Userspace Convenience Library (librefuse, -lrefuse)
libresolv
DNS Resolver Library (libresolv, -lresolv)
librpcsec_gss
RPC GSS-API Authentication Library (librpcsec_gss, -lrpcsec_gss)
librpcsvc
RPC Service Library (librpcsvc, -lrpcsvc)
librt
POSIX Real-time Library (librt, -lrt)
libsdp
Bluetooth Service Discovery Protocol User Library (libsdp, -lsdp)
libssp
Buffer Overflow Protection Library (libssp, -lssp)
libSystem
System Library (libSystem, -lSystem)
libtermcap
Termcap Access Library (libtermcap, -ltermcap)
libterminfo
Terminal Information Library (libterminfo, -lterminfo)
libthr
1:1 Threading Library (libthr, -lthr)
libufs
UFS File System Access Library (libufs, -lufs)
libugidfw
File System Firewall Interface Library (libugidfw, -lugidfw)
libulog
User Login Record Library (libulog, -lulog)
libusbhid
USB Human Interface Devices Library (libusbhid, -lusbhid)
libutil
System Utilities Library (libutil, -lutil)
libvgl
Video Graphics Library (libvgl, -lvgl)
libx86_64
x86_64 Architecture Library (libx86_64, -lx86_64)
libz
Compression Library (libz, -lz)

ローカルな追加項目や OS 特有の追加項目が、ファイル mdoc.local にあるかもしれません。‘ str-Lb-XXX’という名前の文字列を検索してください。ここで‘ XXX’は、‘ .Lb’マクロとともに使用されるキーワードを示しています。

ライブラリ のセクションでは、‘ .Lb’コマンドは、引数の表示の前後でラインブレークを引き起こします。

リテラル

リテラルマクロ‘ .Li’は、特殊文字や変数定数、その他タイプされた通りに表示する必要があるものに使用することができます。

使い方: .Li <引数> ...

.Li \en
\n
.Li M1 M2 M3 ;
M1 M2 M3;
.Li cntrl-D ) ,
cntrl-D),
.Li 1024 ...
1024 ...

デフォルト幅は、16n です。

名称

.Nm’マクロは、文書のタイトルやサブジェクト名を指定するために使われます。このマクロは、呼び出された時の第 1 引数を覚えておくという変わった特性を持っており、それは、常にそのページのサブジェクト名であるべきです。引数なしで呼び出されると‘ .Nm’は、作者のために最低限の仕事をするという意味で、この初期化された名称を出力します。‘ .Nm’によって、 SYNOPSIS セクション内で改行 (line break) します。

注: セクション 2 または 3 のドキュメントの関数名は、 NAME セクションにおいて‘ .Nm’で指定され、 SYNOPSIS セクションや残りのセクションでは、‘ .Fn’で指定されます。 csh(1) での‘ while’コマンドのキーワードのような対話的なコマンドでは、‘ .Ic’マクロを使う必要があります。‘ .Ic’は、ほとんど‘ .Nm’と同一ですが、それが使われたときの第 1 引数を記憶することはできません。

使い方: .Nm [ <引数>] ...

.Nm groff_mdoc
groff_mdoc
.Nm \-mdoc
-mdoc
.Nm foo ) ) ,
foo)),
.Nm :
groff_mdoc:

デフォルト幅は、10n です。

オプション

.Op’マクロは、コマンド行の残りのすべての引数をオプションであることを示す角括弧で囲み、末尾の句読点は、角括弧の外に置きます。‘ .Oo’マクロと‘ .Oc’マクロ (それぞれ開き角括弧と閉じ角括弧を生成します) は、複数行に渡って使うことができ、また閉じ括弧の正確な位置を指定するのに使うことができます。

使い方: .Op [ <オプション>] ...

.Op
[ ]
.Op Fl k
[ -k]
.Op Fl k ) .
[ -k]).
.Op Fl k Ar kookfile
[ -k kookfile]
.Op Fl k Ar kookfile ,
[ -k kookfile],
.Op Ar objfil Op Ar corfil
[ objfil [ corfil]]
.Op Fl c Ar objfil Op Ar corfil ,
[ -c objfil [ corfil]],
.Op word1 word2
[ word1 word2]
.Li .Op Oo Ao option Ac Oc ...
.Op [ <option>] ...

これは、‘ .Oo’マクロと‘ .Oc’マクロを使った典型的な例です:

.Oo 
.Op Fl k Ar kilobytes 
.Op Fl i Ar interval 
.Op Fl c Ar count 
.Oc

出力結果:

[ [ -k kilobytes][ -i interval][ -c count]]

.Op’マクロと‘ .Oo’マクロのデフォルト幅は、それぞれ 14n と 10n です。

パス名

.Pa’マクロは、パス名もしくはファイル名を書式設定します。引数なしで呼ばれた場合、‘ ~’文字列が出力となり、これは、現在のユーザのホームディレクトリを表しています。

使い方: .Pa [ <パス名>] ...

.Pa
~
.Pa /usr/share
/usr/share
.Pa /tmp/fooXXXXX ) .
/tmp/fooXXXXX).

デフォルト幅は、32n です。

規格

.St’マクロは、規格の短縮名称を正式名称に置換します。

使い方: .St <短縮名称> ...

使用可能な“短縮名称/正式名称”の組は、次の通りです:

ANSI/ISO C

-ansiC
ANSI X3.159-1989 (“ANSI C89”)
-ansiC-89
ANSI X3.159-1989 (“ANSI C89”)
-isoC
ISO/IEC 9899:1990 (“ISO C90”)
-isoC-90
ISO/IEC 9899:1990 (“ISO C90”)
-isoC-99
ISO/IEC 9899:1999 (“ISO C99”)
-isoC-2011
ISO/IEC 9899:2011 (“ISO C11”)

POSIX パート 1: System API

-iso9945-1-90
ISO/IEC 9945-1:1990 (“POSIX.1”)
-iso9945-1-96
ISO/IEC 9945-1:1996 (“POSIX.1”)
-p1003.1
IEEE Std 1003.1 (“POSIX.1”)
-p1003.1-88
IEEE Std 1003.1-1988 (“POSIX.1”)
-p1003.1-90
IEEE Std 1003.1-1990 (“POSIX.1”)
-p1003.1-96
ISO/IEC 9945-1:1996 (“POSIX.1”)
-p1003.1b-93
IEEE Std 1003.1b-1993 (“POSIX.1b”)
-p1003.1c-95
IEEE Std 1003.1c-1995 (“POSIX.1c”)
-p1003.1g-2000
IEEE Std 1003.1g-2000 (“POSIX.1g”)
-p1003.1i-95
IEEE Std 1003.1i-1995 (“POSIX.1i”)
-p1003.1-2001
IEEE Std 1003.1-2001 (“POSIX.1”)
-p1003.1-2004
IEEE Std 1003.1-2004 (“POSIX.1”)
-p1003.1-2008
IEEE Std 1003.1-2008 (“POSIX.1”)

POSIX パート 2: シェルとユーティリティ

-iso9945-2-93
ISO/IEC 9945-2:1993 (“POSIX.2”)
-p1003.2
IEEE Std 1003.2 (“POSIX.2”)
-p1003.2-92
IEEE Std 1003.2-1992 (“POSIX.2”)
-p1003.2a-92
IEEE Std 1003.2a-1992 (“POSIX.2”)

X/Open

-susv2
Version 2 of the Single UNIX Specification (“SUSv2”)
-susv3
Version 3 of the Single UNIX Specification (“SUSv3”)
-svid4
System V Interface Definition, Fourth Edition (“SVID4”)
-xbd5
X/Open Base Definitions Issue 5 (“XBD5”)
-xcu5
X/Open Commands and Utilities Issue 5 (“XCU5”)
-xcurses4.2
X/Open Curses Issue 4, Version 2 (“XCURSES4.2”)
-xns5
X/Open Networking Services Issue 5 (“XNS5”)
-xns5.2
X/Open Networking Services Issue 5.2 (“XNS5.2”)
-xpg3
X/Open Portability Guide Issue 3 (“XPG3”)
-xpg4
X/Open Portability Guide Issue 4 (“XPG4”)
-xpg4.2
X/Open Portability Guide Issue 4, Version 2 (“XPG4.2”)
-xsh5
X/Open System Interfaces and Headers Issue 5 (“XSH5”)

その他

-ieee754
IEEE Std 754-1985
-iso8802-3
ISO 8802-3: 1989

変数の型

.Vt’マクロは、型を参照するときには、いつでも使用することができます。 SYNOPSIS セクションでは、改行が挿入されます (古いスタイルの変数宣言では便利です)。

使い方: .Vt <型> ...

.Vt extern char *optarg ;
extern char *optarg;
.Vt FILE *
FILE *

変数

一般的な変数への参照です。

使い方: .Va <変数> ...

.Va count
count
.Va settimer ,
settimer,
.Va "int *prt" ) :
int *prt):
.Va "char s" ] ) ) ,
char s])),

デフォルト幅は、12n です。

マニュアルページのクロスリファレンス

.Xr’マクロは、最初の引数にマニュアルページの名称をとります。オプションである第 2 引数は、文字列 (マニュアルセクションを定義します) であれば括弧で囲われます。

使い方: .Xr <マニュアルページの名称>[ <セクション>] ...

.Xr mdoc
mdoc
.Xr mdoc ,
mdoc,
.Xr mdoc 7
mdoc(7)
.Xr xinit 1x ;
xinit(1x);

デフォルト幅は、10n です。

一般テキスト領域

AT&T マクロ

使い方: .At [ <バージョン>] ...

.At
AT&T UNIX
.At v6 .
Version 6 AT&T UNIX.

<バージョン>には、次の値をとることができます:

32v, v1, v2, v3, v4, v5, v6, v7, V, V.1, V.2, V.3, V.4

BSD マクロ

使い方: .Bx {-alpha | -beta | -devel} ...
.Bx [ <バージョン>[ <リリース>]] ...

.Bx
BSD
.Bx 4.3 .
4.3BSD.
.Bx -devel
-develBSD

<バージョン>が文字列‘ BSD’の前につきます。<リリース>には、次の値をとることができます:

Reno, reno, Tahoe, tahoe, Lite, lite, Lite2, lite2

NetBSD マクロ

使い方: .Nx [ <バージョン>] ...

.Nx
NetBSD
.Nx 1.4 .
NetBSD 1.4.

<バージョン>にとり得る値については、前述の タイトルマクロ セクションの‘ .Os’コマンドの説明を参照してください。

FreeBSD マクロ

使い方: .Fx [ <バージョン>] ...

.Fx
FreeBSD
.Fx 2.2 .
FreeBSD 2.2.

<バージョン>にとり得る値については、前述の タイトルマクロ セクションの‘ .Os’コマンドの説明を参照してください。

DragonFly マクロ

使い方: .Dx [ <バージョン>] ...

.Dx
DragonFly
.Dx 1.4 .
DragonFly 1.4.

<バージョン>にとり得る値については、前述の タイトルマクロ セクションの‘ .Os’コマンドの説明を参照してください。

OpenBSD マクロ

使い方: .Ox [ <バージョン>] ...

.Ox 1.0
OpenBSD 1.0

BSD/OS マクロ

使い方: .Bsx [ <バージョン>] ...

.Bsx 1.0
BSD/OS 1.0

UNIX マクロ

使い方: .Ux ...

.Ux
UNIX

強調マクロ

テキストは、‘ .Em’マクロを用いて強調することができます。通常強調に用いられるフォントは、イタリック体です。

使い方: .Em <引数> ...

.Em does not
does not
.Em exceed 1024 .
exceed 1024.
.Em vide infra ) ) ,
vide infra)),

デフォルト幅は、10n です。

フォントモード

.Bf’フォントモードは、‘ .Ef’マクロで終了しなくてはなりません (後者のマクロは、引数をとりません)。フォントモードは、別のフォントモード内に入れ子にできます。

.Bf’は、次の文法をもっています:

.Bf <フォントモード>

<フォントモード>は、次の 3 種類のうちのいずれかでなくてはなりません。

Em | -emphasis
.Em’マクロがテキストのブロック全体に対して使用された場合と同じになります。
Li | -literal
.Li’マクロがテキストのブロック全体に対して使用された場合と同じになります。
Sy | -symbolic
.Sy’マクロがテキストのブロック全体に対して使用された場合と同じになります。

いずれのマクロも呼び出し不可能であり、構文解析もされません。

囲い/クォートマクロ

囲いの概念は、クォートと似たものです。 1 つ以上の文字列が引用符や括弧のような文字のペアで囲まれているオブジェクトを指します。クォートと囲いという用語は、この文書を通して同じ意味で使われます。ほとんどの 1 行の囲いマクロは、クォートであることをほのめかすために、小文字の‘ q’で終了しますが、例外もいくつかあります。各々の囲いマクロに対し、開始マクロと終了マクロのペアもあり、それぞれ小文字の‘ o’と‘ c’で終了します。

クォート 開始 終了 機能 結果
.Aq .Ao .Ac 山括弧による囲い <string>
.Bq .Bo .Bc 角括弧による囲い [string]
.Brq .Bro .Brc 中括弧による囲い {string}
.Dq .Do .Dc 2 重引用符 “string”
.Eq .Eo .Ec 囲い文字列 (XX による) XXstringXX
.Pq .Po .Pc 括弧による囲い (string)
.Ql クォートされたリテラル ‘string’もしくは string
.Qq .Qo .Qc まっすぐな 2 重引用符 “string”
.Sq .So .Sc 1 重引用符 ‘string’

‘q’と‘o’で終わるマクロは、すべてデフォルト幅が 12n です。

.Eo, .Ec
これらのマクロは、それぞれ第 1 引数に囲い始めに使う文字列と囲い終わりに使う文字列をとります。
.Es, .En
オリジナルの troff プログラムでは、引数の数が 9 つまでという制限がありましたので、(Eo, Ec とは) 別の 2 つのマクロが実装されています。現在は、非推奨になっています。‘ .Es’は、第 1 引数と第 2 引数に左囲い文字列と右囲い文字列をとります。この文字列は、‘ .En’の引数を囲うのに使用されます。デフォルト幅は、どちらのマクロも 12n です。
.Eq
このマクロの第 1、第 2 引数は、それぞれ囲い始めに使う文字列と囲い終わりに使う文字列であり、この文字列の後に囲われる引数が続きます。
.Ql
クォートされたリテラルマクロは、troff モードと nroff モードで違った挙動をします。 nroff で書式設定された場合、クォートされたリテラルは、常にクォートされます。 troff で書式設定された場合、その要素の幅が固定幅文字 3 文字分の幅よりも小さいときのみクォートされます。これにより、リテラル (固定幅) フォントへフォントを変更すると目立たなくなってしまうような短い文字列がより見やすくなります。

デフォルト幅は、16n です。

.Pf
プレフィックスマクロは、第 1 引数と第 2 引数の間のホワイトスペースをなくします:
.Pf ( Fa name2
( name2

デフォルト幅は、12n です。

.Ns’マクロ (後述参照) は、同じようにサフィックスに働きます。

.Ap
.Ap’マクロは、アポストロフィを追加し、特別なテキストモードから抜けます。そして‘ .No’モードで続けます。

クォートの例:

.Aq
<>
.Aq Pa ctype.h ) ,
< ctype.h>),
.Bq
[]
.Bq Em Greek , French .
[ Greek, French].
.Dq
“”
.Dq string abc .
“string abc”.
.Dq ´^[A-Z]´
“´^[A-Z]´”
.Ql man mdoc
man mdoc
.Qq
“”
.Qq string ) ,
“string”),
.Qq string Ns ),
“string),”
.Sq
‘’
.Sq string
‘string’
.Em or Ap ing
or'ing

囲いマクロの入れ子についての良い例については、オプションマクロ‘ .Op’を参照してください。このマクロは、上でリストされているような囲いマクロと同じベースの上に作られています。‘ .Xo’と‘ .Xc’拡張引数リストマクロについては後で述べます。

無操作または通常テキストマクロ

.No’マクロは、マクロコマンド行において書式設定されては ならない パラメータ用に使用できます。この英単語 (マクロでなく) をパラメータとして本当に使いたい場合は、この単語‘ No’に‘ \&’を足すように注意してください。

使い方: .No <引数> ...

.No test Ta with Ta tabs
test with Ta tabs

デフォルト幅は、12n です。

空白なしマクロ

.Ns’マクロは、現在の位置とマクロの第 1 パラメータとの間に空白を挿入するのを抑止します。例えば、フラグと引数の間に空白を含まない古いスタイルの引数リストを使う場合に便利です:

使い方: ... <引数> Ns [ <引数>] ...
.Ns <引数> ...

.Op Fl I Ns Ar directory
[ -Idirectory]

注: ‘ .Ns’マクロは、他のマクロ名が続かなければ、スペースを除去したあとに‘ .No’マクロを常に起動します。コマンドとして使用される場合 (つまり、‘使い方’の行での 2 番目の形式です)、‘ .Ns’マクロは、‘ .No’と同一です。

セクションのクロスリファレンス

.Sx’マクロは、同一文書内でのセクションのヘッダへの参照を指定します。

使い方: .Sx <セクションの参照> ...
.Sx FILES
FILES

デフォルト幅は、16n です。

記号

記号体強調マクロは、記号の意味でも伝統的な英語の使い方においても通常は、ボールド体マクロとなっています。

使い方: .Sy <記号> ...

.Sy Important Notice
Important Notice

デフォルト幅は、6n です。

数学記号

数学記号やそれに似たものについては、このマクロを使用してください。

使い方: .Ms <数学記号> ...

.Ms sigma
sigma

デフォルト幅は、6n です。

参考文献と引用

次のマクロは、多少なりとも参考文献を扱えるようにと意図したものです。これらのマクロは、せいぜい refer(1) スタイルの参考文献のサブセットを手動で作成しやすくする程度です。

.Rs
参考文献の開始 (引数はとりません)。 SEE ALSO セクションでは、改行を挿入し、参考文献の終了マクロが読み込まれるまで参考文献の情報を収集します。
.Re
参考文献の終了 (引数はとりません)。参考文献が表示されます。
.%A
参考文献の作者名。 1 回の呼び出しにつき、作者名をひとつ指定します。
.%B
書籍のタイトル。
.%C
市 / 場所 (まだ実装されていません)。
.%D
日付。
.%I
発行者/出版社名。
.%J
定期刊行物の名称。
.%N
発行番号。
.%O
追加情報。
.%P
ページ番号。
.%Q
組織内部、あるいは外部の著者。
.%R
報告書の名称。
.%T
記事のタイトル。
.%U
オプションのハイパーテキスト参照。
.%V
巻数。

%’で始まるマクロは、呼び出し不可能ですが、通常の方法で複数の引数をとることができます。パラメータとしては、‘ .Tn’マクロのみ扱います。その他のマクロを使うと奇妙な出力が得られてしまいます。‘ .%B’と‘ .%T’を‘ .Rs/.Re’環境の外側では使用することができます。

使用例:

.Rs 
.%A "Matthew Bar" 
.%A "John Foo" 
.%T "Implementation Notes on foobar(1)" 
.%R "Technical Report ABC-DE-12-345" 
.%Q "Drofnats College, Nowhere" 
.%D "April 1991" 
.Re

出力結果

Matthew Bar and John Foo, Implementation Notes on foobar(1), Technical Report ABC-DE-12-345, Drofnats College, Nowhere, April 1991.

商標名 (頭字語とタイプ名)

商標名マクロは、引数をより小さなフォントで出力します。意図される使い方は、大文字の頭字語用に小さな大文字フォントを似せて作ることです。

使い方: .Tn <シンボル> ...

.Tn DEC
DEC
.Tn ASCII
ASCII

デフォルト幅は、10n です。

拡張引数

.Xo.Xc マクロによって、‘ .It’マクロ (後述) についてマクロ境界での引数リストを拡張することができます。 .Xo.Xc マクロは、囲いを開いたり閉じたりする他のすべてのマクロに対して同じように実装されている (もちろん文字は挿入しません) ということに注意してください。つまり、次の例もこれらのマクロには当てはまります。

次は、スペーシングをオフにするために空白モードマクロを使った‘ .Xo’の使用例です。

.Sm off 
.It Xo Sy I Ar operation 
.No \en Ar count No \en 
.Xc 
.Sm on

これは、以下のような結果になります。

I operation\n count\n

例をもうひとつ:

.Sm off 
.It Cm S No / Ar old_pattern Xo 
.No / Ar new_pattern 
.No / Op Cm g 
.Xc 
.Sm on

これは、以下のような結果になります。

S/ old_pattern/ new_pattern/[ g]

囲いマクロを使った‘ .Xo’の他の例: 変数の値をテストして下さい。

.It Xo 
.Ic .ifndef 
.Oo \&! Oc Ns Ar variable Oo 
.Ar operator variable ... 
.Oc Xc

結果は、以下の通りです。

.ifndef [ !] variable [ operator variable ...]

ページ構造領域

セクションヘッダ

次の‘ .Sh’セクションヘッダマクロは、すべてのマニュアルページで必須のものです。残りのセクションヘッダは、マニュアルページの作者の裁量において、推奨されているものです。‘ .Sh’マクロは、構文解析されますが、一般的には呼び出し不可能です。‘ .Sh’を呼び出すときだけは、このマクロは、引数として使用することができます。この場合、‘ .Sh’用のデフォルトフォントを再度有効にします。

デフォルト幅は、8n です。

.Sh NAME
.Sh NAME’マクロは、必須です。これが指定されていないと、ヘッダとフッタ、それにデフォルトのページレイアウトが設定されず、結果は、かなり好ましくないものになるでしょう。 NAME セクションは、最低 3 つの項目からなります。最初のものは、名称マクロ‘ .Nm’であり、マニュアルページのサブジェクトとなります。 2 番目のものは、名称説明マクロ‘ .Nd’であり、サブジェクト名を 3 つめの項目、すなわちその名称の説明と分離します。説明に割り当てられるスペースは小さいものですので、できるだけ簡潔で分かりやすいものでなければなりません。

.Nd’は、全ての引数の頭に‘ -’を印字します。

.Sh LIBRARY
このセクションは、セクション 2 と 3 の関数呼び出しのためにあります。このセクションには、‘ .Lb’マクロ呼び出し 1 つのみが含まれている必要があります。 ライブラリ名 を参照してください。
.Sh SYNOPSIS
SYNOPSIS セクションは、そのマニュアルページのサブジェクトとなっている項目の典型的な使用法を説明します。‘ .Nm’, ‘ .Cd’, あるいは‘ .Fn’です (他には、‘ .Fo’, ‘ .Fc’, ‘ .Fd’, ‘ .Ft’のマクロも必要な場合があります)。関数名マクロ‘ .Fn’は、セクション 2 と 3 のマニュアルページにおいて必須のもので、コマンドと一般名称マクロ‘ .Nm’は、セクション 1, 5, 6, 7, 8 で必須の項目です。セクション 4 のマニュアルでは、‘ .Nm’か‘ .Fd’、もしくは設定デバイス使用法マクロ‘ .Cd’が必要です。その他のいくつかのマクロが次に示すような書式行を生成するために必要なことがあります:

cat [ -benstuv][ -] file ...

次のマクロが使われています:

.Nm cat
.Op Fl benstuv
.Op Fl
.Ar
.Sh DESCRIPTION
ほとんどの場合、 DESCRIPTION セクションでの最初のテキストは、そのコマンド、関数もしくはファイルについての短い段落で、オプションの構文リストとそれぞれの説明がそれに続きます。そのようなリストを作成するには、‘ .Bl’ (リスト開始マクロ)、‘ .It’ (リスト項目マクロ)、‘ .El’ (リスト終了マクロ) を使用します (後述の リストとカラム セクションを参照)。
.Sh IMPLEMENTATION NOTES
特定の実装に関する情報は、ここに置く必要があります。
.Sh RETURN VALUES
セクション 2, 3, 9 の関数の戻り値は、ここに来る必要があります。‘ .Rv’を使用して、セクション 2 と 3 のライブラリ関数の RETURN VALUES セクションを生成することができます。 戻り値 の項を参照してください。

次の‘ .Sh’セクションヘッダは、マニュアルページの好ましいレイアウトの一部であり、一貫性を保つために適切に使われなければなりません。これらは、使われる順番にリストされています。

.Sh ENVIRONMENT
ENVIRONMENT セクションでは、関連する環境変数とそれらの振るまいや使用方法に関する手がかりを明らかにする必要があります。
.Sh FILES
マニュアルページのサブジェクトによって使用されるか生成されるファイルで、 FILES セクション中でマクロ‘ .Pa’によってリストする必要があります。
.Sh EXAMPLES
使用例を生成するにはいくつか方法があります。詳細は、後述の 使用例 セクションを参照してください。
.Sh DIAGNOSTICS
コマンドからの診断メッセージは、このセクションに置く必要があります。‘ .Ex’マクロは、ほとんどのセクション 1、6、と 8 コマンドのために DIAGNOSTICS セクションで使われるテキストを作成するために使用されす。 終了ステータス を参照してください。
.Sh COMPATIBILITY
知られている互換性の問題 (例えば、非推奨になったオプションやパラメータ) をここにリストする必要があります。
.Sh ERRORS
特定のエラーハンドリング、特にライブラリ関数 (マニュアルページのセクション 2, 3, 9) でのエラーハンドリングは、ここで説明する必要があります。‘ .Er’マクロは、エラー (errno) を指定するのに使用されます。
.Sh SEE ALSO
SEE ALSO セクションには、そのマニュアルページの題材に関する資料への参照と他の関連するマニュアルページへのクロスリファレンスが記載されます。クロスリファレンスは、‘ .Xr’マクロによって指定されます。現在、 refer(1) スタイルのリファレンスには適合していません。

クロスリファレンスは、セクション番号順、同一セクションにあるものは、アルファベット順に並べ、コンマで区切ることを推奨します。以下に例を示します:

ls(1), ps(1), group(5), passwd(5)

.Sh STANDARDS
コマンドやライブラリ関数やファイルが、 IEEE Std 1003.2 (“POSIX.2”) や ANSI X3.159-1989 (“ANSI C89”) のような特定の実装によるものであれば、ここで記述します。もしコマンドがどの規格にも基づいていなければ、その歴史は、 HISTORY のセクションで説明されなければなりません。
.Sh HISTORY
特定の規格に基づいていないコマンドは、このセクションでその歴史の概要を説明する必要があります。
.Sh AUTHORS
クレジットは、ここに置く必要があります。名前のためには、‘ .An’マクロとオプションの連絡先としての電子メールアドレスのためには、‘ .Aq’マクロを使用します。最初のマニュアルページまたはソフトウェアを執筆した人物かどうか、またはクレジットされるべき人物なら誰でも明白に示します。
.Sh BUGS
あきらかな問題は、ここで記述します。

ユーザ指定の‘ .Sh’セクションを追加することができます。例えば、このセクションは、以下のように設定されています。

.Sh "ページ構造領域"

サブセクションヘッダ

サブセクションヘッダは、セクションヘッダとまったく同じ文法があります: ‘ .Ss’は、構文解析されますが、一般的に呼び出し不可能です。このマクロは、‘ .Ss’の呼び出し時にのみ引数として使用できます。このとき、‘ .Ss’のデフォルトフォントが再度有効になります。

デフォルト幅は、8n です。

段落と行スペース

.Pp
.Pp’段落コマンドは、必要な場合に行スペースを指定するために使われます。このマクロは、‘ .Sh’マクロや‘ .Ss’マクロの後、ならびに‘ .Bl’マクロや‘ .Bd’マクロの前では必要ありません (いずれのマクロも -compact フラグが指定されていなければ垂直方向の距離を宣言します)。

このマクロは、呼び出し不可能であり、構文解析もされません。そして引数をとりません。別名は、‘ .Lp’です。

キープ

現在実装されているキープは、単語に対するものだけです。マクロは、‘ .Bk’ (キープ開始) と‘ .Ek’ (キープ終了) です。現在‘ .Bk’が受け付けるオプションは、 -words のみで (オプションを何も与えていなければこれがデフォルトでもあります) オプションの途中で改行が入らないようにするのに便利です。 make コマンド行の引数を生成する例 ( この名前には何が の項を参照) において、キープは、 nroff がフラグと引数を別の行に分けないように使われています。

いずれのマクロも呼び出し不可能であり、構文解析もされません。

キープマクロについてはもっと作業をする必要があります。特に -line オプションは、追加する必要があるでしょう。

例示とディスプレイ

ディスプレイには、7 つのタイプがあります。
.D1
(D-いちです) インデントされたテキストを 1 行表示します。このマクロは、構文解析されますが、呼び出し不可能です。

-ldghfstru

これは、次の指定で生成されたものです: .D1 Fl ldghfstru

.Dl
(D-エルです) インデントされた リテラル テキストを 1 行表示します。‘ .Dl’マクロの例は、本ファイル中にわたって使われています。これによって 1 行のテキストのインデント (表示) が可能になります。デフォルトフォントは、固定幅 (リテラル) に設定されます。‘ .Dl’は、構文解析されますが、呼び出し不可能です。

% ls -ldg /usr/local/bin

これは、次の指定で生成されたものです: .Dl % ls \-ldg /usr/local/bin

.Bd
ディスプレイ開始。‘ .Bd’ディスプレイは、‘ .Ed’マクロで終了しなければなりません。これは、次の書式をとります:

.Bd {-literal | -filled | -unfilled | -ragged | -centered}[ -offset <文字列>][ -file <ファイル名>][ -compact]

-ragged
行詰めされますが、右マージンは、調整しません (左マージンのみです)。
-centered
現在の左マージンと右マージン間の中央線です。線それぞれが中央揃えになるということに注意してください。
-unfilled
行詰めしません。テキストのブロックを入力されたままの状態で表示します。改行もユーザが指定した通りに使われます。このため、何の警告メッセージも出さずに長過ぎる行を生成する可能性があります。
-filled
行詰めされたブロックを表示します。テキストブロックが書式設定されます (つまり、テキストは、左右どちら側にも揃えられます)。
-literal
リテラルフォント (通常固定幅) でブロックを表示します。ソースコードや、単純にタブもしくは空白で整えられたテキストには便利です。
-file < ファイル名>
-file フラグに続いた名前を持ったファイルが読み込まれ、指定されたディスプレイタイプで‘ .Bd’と‘ .Ed’マクロで囲まれたデータよりも前に表示されます。ファイル中の troff/ -mdoc コマンドは、どんなものでも処理されます。
-offset < 文字列>
-offset が以下の文字列のいずれかとともに指定されていると、その文字列は、次のテキストのブロックのインデントのレベルを示すものとして解釈されます。

left
ブロックを現在の左マージンに揃えます。これは、‘ .Bd’のデフォルトのモードです。
center
ブロックを中央揃えにします。残念ながら現時点では、単にブロックの左側を仮想的な中央マージンに揃えるだけです。
indent
デフォルトのインデント値もしくはタブの分だけインデントします。デフォルトのインデント値は、‘ .D1’と‘ .Dl’マクロでも使われていますので、この 2 つのディスプレイと行が揃うことが保証されています。インデント値は、通常 6n つまり約 2/3 インチ (固定幅文字 6 つ分) です。
indent-two
デフォルトのインデント値の 2 倍分インデントします。
right
これは、ブロックをページの右端から約 2 インチ離して 揃えします。このマクロは、ちゃんと動作する必要があるのですが、 troff ではまったくちゃんと動作してくれていません。

<文字列>がそれ以外で正しい数値表現をしている場合 (‘ u以外のスケール指示子を伴う)、インデント用にその値を使用します。スケール指示子のなかで最も役に立つものは、‘m’と‘n’です。これらは、いわゆる EmEn square を指定します。これらは、それぞれ、現在のフォントでの文字‘m’と文字‘n’の幅とほぼ同じです ( nroff の出力については、どちらのスケール指示子でも同じ値が得られます )。<文字列>が数値表現をしていない場合、文字列は、 -mdoc マクロ名であるかどうか検査され、このマクロに関連するデフォルトのオフセット値が使われます。最終的にすべてのテストが失敗した場合 the width of <文字列>の幅 (固定幅フォントでのタイプセット) がオフセットと見なされます。

-compact
ディスプレイを開始するときに垂直方向の空白を挿入しないようにします。
.Ed
ディスプレイの終了 (引数はとりません)。

リストとカラム

リスト開始マクロ‘ .Bl’で開始できるリストには、何種類かあります。リスト中の項目は、項目マクロ‘ .It’で指定され、各リストは、‘ .El’マクロで終了しなければなりません。リストは、リスト自身やディスプレイの中で入れ子にすることができます。リスト中でカラムを使ったり、カラムの中でリストを使ったりすることについては検証されていません。

さらに、タグ幅、リストのオフセット、コンパクトの度合 (項目間の空白行が許されているかどうか) のようなリストの属性をいくつか指定することができます。本ドキュメントのほとんどはタグ ( -tag) スタイルリストで書式設定されています。

このマクロは、次の文法規則を持っています:

.Bl {-hang | -ohang | -tag | -diag | -inset}[ -width <文字列>][ -offset <文字列>][ -compact]
.Bl -column [ -offset <文字列>]<文字列1><文字列2> ...
.Bl {-item | -enum [ -nested] | -bullet | -hyphen | -dash}[ -offset <文字列>][ -compact]

次に、このリストタイプの詳細な解説を行います。

-bullet
ビュレットリストです。

.Bl -bullet -offset indent -compact 
.It 
1 つ目のビュレットは、ここにきます。 
.It 
2 つ目のビュレットは、ここにきます。 
.El

生成結果は、次の通りです:

  • 1 つ目のビュレットは、ここにきます。
  • 2 つ目のビュレットは、ここにきます。

-dash (または -hyphen)
ダッシュ文字によるリストです。

.Bl -dash -offset indent -compact 
.It 
1 つ目のダッシュは、ここにきます。 
.It 
2 つ目のダッシュは、ここにきます。 
.El

生成結果は、次の通りです:

  • 1 つ目のダッシュは、ここにきます。
  • 2 つ目のダッシュは、ここにきます。

-enum
箇条書きリストです。

.Bl -enum -offset indent -compact 
.It 
1 つ目の項目は、ここにきます。 
.It 
2 つ目の項目は、ここにきます。 
.El

生成結果は、次の通りです:

  1. 1 つ目の項目は、ここにきます。
  2. 2 つ目の項目は、ここにきます。

箇条書きリストを入れ子にしたい場合、 -nested フラグを使用してください (第 2 レベルのリストが開始されます):

.Bl -enum -offset indent -compact 
.It 
1 つ目の項目は、ここにきます。 
.Bl -enum -nested -compact 
.It 
2 つ目の項目は、ここにきます。 
.It 
3 つ目の項目は、ここにきます。 
.It 
.El 
.It 
4 つ目の項目は、ここにきます。 
.El

生成結果は、次の通りです:

  1. 1 つ目の項目は、ここにきます。
    1. 2 つ目の項目は、ここにきます。
    2. 3 つ目の項目は、ここにきます。
  2. 4 つ目の項目は、ここにきます。

-item
リストの印をつけない -item タイプのリストです。

.Bl -item -offset indent 
.It 
1 つ目の項目は、ここにきます。 
1 つ目の項目は、ここにきます。 
1 つ目の項目は、ここにきます。 
.It 
2 つ目の項目は、ここにきます。 
2 つ目の項目は、ここにきます。 
2 つ目の項目は、ここにきます。 
.El

生成結果は、次の通りです:

  • 1 つ目の項目は、ここにきます。 1 つ目の項目は、ここにきます。 1 つ目の項目は、ここにきます。
  • 2 つ目の項目は、ここにきます。 2 つ目の項目は、ここにきます。 2 つ目の項目は、ここにきます。

-tag
タグつきリストです。タグ幅を指定するには、 -width を使用してください。

SL
プロセスが sleep している時間 (ブロックされた秒数)
PAGEIN
そのプロセスによって、まだメモリにロードされていないページへの参照が起こることにより生じたディスク I/O の回数
UID
数値表記によるプロセス所有者のユーザ ID
PPID
数値表記による親プロセスの ID、プロセスの優先度 (割り込み不可の待機状態のときには、正でない値になる)

元のテキストは、次の通りです:

.Bl -tag -width "PPID"-compact -offset indent 
.It SL 
プロセスが sleep している時間 (ブロックされた秒数) 
.It PAGEIN 
そのプロセスによって、まだメモリにロードされていないページ 
への参照が起こることにより生じたディスク 
.Tn I/O 
の回数 
.It UID 
数値表記によるプロセス所有者のユーザ ID 
.It PPID 
数値表記による親プロセスの ID、プロセスの優先度 
(割り込み不可の待機状態のときには、正でない値になる) 
.El

-diag
診断リストは、セクション 4 の診断リストを生成するもので、呼び出し可能なマクロが無視されることを除き、inset リストと似ています。フラグ -width は、この文脈では、意味がありません。

使用例:

.Bl -diag 
.It ここで Sy を使うことはできません。 
このメッセージは、すべて出力されます。 
.El

生成結果

ここで Sy を使うことはできません。
このメッセージは、すべて出力されます。

-hang
ぶら下がりタグつきリストです。
hanged
ラベル幅よりもラベルが小さい場合には、ぶら下げられたラベルは、タグつきリストと同じように見えます。
Longer hanged list labels
ラベル幅より長いぶら下がりリストのラベルは、タグつき段落ラベルとは違い、段落に溶け込みます。

以上の文章を生成した、書式設定前のテキストは、次の通りです:

.Bl -hang -offset indent 
.It Em hanged 
ラベル幅よりもラベルが小さい場合には、 
ぶら下げられたラベルは、タグつきリストと同じようにみえます。 
.It Em Longer Hanged list labels 
ラベル幅より長いぶら下がりリストのラベルは、 
タグつき段落ラベルとは違い、段落に溶け込みます。 
.El

-ohang
オーバハングタグ (overhanging tags) を用いたリストは、項目に対してインデントを使いません。タグは、別の行に出力されます。
SL
プロセスが sleep している時間 (ブロックされた秒数)
PAGEIN
そのプロセスによって、まだメモリにロードされていないページへの参照が起こることで生じたディスク I/O の回数
UID
数値表記によるプロセス所有者のユーザ ID
PPID
数値表記による親プロセスの ID、プロセスの優先度 (割り込み不可の待機状態のときには、正でない値になる)

元のテキストは、次の通りです:

.Bl -ohang -offset indent 
.It Sy SL 
プロセスが sleep している時間 (ブロックされた秒数) 
.It Sy PAGEIN 
そのプロセスによって、まだメモリにロードされていないページ 
への参照が起こることで生じたディスク 
.Tn I/O 
の回数 
.It Sy UID 
数値表記によるプロセス所有者のユーザ ID 
.It Sy PPID 
数値表記による親プロセスの ID、プロセスの優先度 
(割り込み不可の待機状態のときには、正でない値になる) 
.El

-inset
次は、inset ラベルの例です:
tag
タグリスト (タグ段落とも呼びます) は、バークレイのマニュアルで使われている最も一般的な種類のリストです。後で述べるように、 -width 属性を使用してください。
diag
診断リストは、セクション 4 の診断リストを生成し、呼び出し可能なマクロを無視するという点を除けば inset リストと似ています。
hang
ぶら下がりラベルは、気分の問題です。
ohang
オーバハングラベルは、空白に制限がある場合には良いです。
inset
inset ラベルは、段落ブロックを制御するのに便利で、 -mdoc マニュアルを別のフォーマットに変換するのに有用です。

上の例を生成したソーステキストは、こうなっています:

.Bl -inset -offset indent 
.It Em tag 
タグリスト (タグ段落とも呼びます) は、 
バークレイのマニュアルで使われている最も一般的な 
種類のリストです。 
後で述べるように、 
.Fl width 
属性を使用してください。 
.It Em diag 
診断リストは、セクション 4 の診断リストを生成し、 
呼び出し可能なマクロを無視するという点を除けば 
inset リストと似ています。 
.It Em hang 
ぶら下がりラベルは、気分の問題です。 
.It Em ohang 
オーバハングラベルは、空白に制限がある場合には良いです。 
.It Em inset 
inset ラベルは、段落ブロックを制御するのに便利で、 
.Nm -mdoc 
マニュアルを別のフォーマットに変換するのに有用です。 
.El

-column
この種類のリストは、複数カラムを生成します。カラムの数と各カラムの幅は、 -column リストへの引数、< string1>, < string2>等によって決定されます。< stringN>が‘ .’ (ドット) で開始し直後に有効な -mdoc マクロ名が続く場合、< stringN>を解釈して結果の幅を使用します。そうでない場合、< stringN> (固定幅フォントでのタイプセット) は、 N 番目の桁の幅になります。

.It’引数は、それぞれ構文解析され行を生成します。行中の各列は、タブや‘ .Ta’マクロで分けられた引数です。

次の表、

文字列 nroff troff
<= <=
>= >=

は、次のようにして生成されています:

.Bl -column -offset indent ".Sy 文字列" ".Sy Nroff" ".Sy Troff" 
.It Sy 文字列 Ta Sy nroff Ta Sy troff 
.It Li <= Ta <= Ta \*(<= 
.It Li >= Ta >= Ta \*(>= 
.El

このリストタイプを不正使用しないでください! より複雑な場合に、テーブルプリプロセッサ tbl(1) を使用することは、はるかに良くて、より簡単であるかもしれません。

その他のキーワード:

-width < 文字列>
< 文字列>が‘ .’ (ドット) で開始し直後に有効な -mdoc マクロ名が続く場合、< 文字列>を解釈し、その結果の幅を使います。本ドキュメントのほとんどすべてのリストは、このオプションを使用しています。

使用例:

.Bl -tag -width ".Fl test Ao Ar 文字列 Ac" 
.It Fl test Ao Ar 文字列 Ac 
これは、 
.Fl width 
フラグをタグリストと一緒に使うとどのように 
働くかを見るためのもっと長い文です。 
.El

生成結果:

-test < 文字列>
これは、 -width フラグをタグリストと一緒に使うとどのように働くかを見るためのもっと長い文です。

<文字列>が解釈される前に現在の -mdoc の状態が保存されることに注意してください。文字列が解釈された後ですべての変数が再度復元されます。しかし、ボックス (囲いに使用される) は、 GNU troff(1) では保存されません。結果としては、醜いエラーを防ぐためには、引数は常に 平衡がとれて いなくてはなりません。例えば、本当に開き山括弧だけが必要である場合には、‘ .Ao Ar 文字列’と書いてはだめで、代わりに‘ .Ao Ar 文字列 Xc’と書かなくてはなりません。

そうでない場合、< 文字列>が正当な数値表現である場合 (‘ u以外のスケール指示子を伴う)、インデント用にその値を使用します。最も有用なスケール指示子は、‘m’と‘n’です。これらは、いわゆる EmEn square を指定します。これらは、それぞれ、現在のフォントでの文字‘m’と文字‘n’の幅とほぼ同じです (nroff の出力については、どちらのスケール指示子でも同じ値が得られます)。< 文字列>が数値表現をしていない場合、文字列は、 -mdoc マクロ名であるかどうか検査され、このマクロに関連するデフォルトのオフセット値が使われます。最終的にすべてのテストが失敗した場合< 文字列>の幅 (固定幅フォントでのタイプセット) がオフセットと見なされます。

タグリストタイプ用に幅が指定されていない場合、‘ .It’が起動される度に適切な幅を決定しようと試みます。‘ .It’の第 1 引数が呼び出し可能なマクロである場合、そのマクロのデフォルト幅が使われます。そうでなければ、‘ .No’のデフォルト幅が使われます。

-offset < 文字列>
< 文字列>が indent である場合、デフォルトのインデント値 (通常 6n に設定されており、‘ .Dl’または‘ .Bd’で使われる値と似ています) が使われます。< 文字列>が正当な数値表現である場合 (‘ u以外のスケール指示子を伴う)、その値をインデントに使用します。最も有用なスケール指示子は、‘m’と‘n’であり、これらは、いわゆる EmEn square です。これらは、それぞれ、それぞれ現在のフォントでの‘m’と‘n’の幅とほぼ同じです (nroff の出力については、どちらのスケール指示子も同じ値をとります)。<文字列>が数値表現でない場合、その文字列が -mdoc のマクロ名であるかどうか検査され、このマクロに関連するデフォルトのオフセット値が使われます。最終的にすべてのテストが失敗した場合、< 文字列>の幅 (固定幅フォントでのタイプセット) がオフセットとしてとられます。
-compact
リストの前とリスト項目間に垂直方向の空白を挿入しないようにします。

その他のマクロ

ここには、いままでのセクションにはうまく当てはまらなかった残りのマクロのリストがあります。次のマクロに対しては、本物の使用例を見つけられませんでした。それは、‘ .Me’と‘ .Ot’です。この 2 つについても完璧を期するためにここに文書化はしています。もしこの 2 つのマクロの適切な使い方をご存知であれば bug-groff@gnu.org までメールを送ってください (例つきで)。
.Bt
は、

is currently in beta test.
 

を表示します。

このマクロは、呼び出し不可能であり、構文解析もされません。また引数もとりません。

.Fr

使い方: .Fr <関数の戻り値> ...

このマクロは、使わないでください。このマクロは、戻り値 (通常は、数字 1 個) の直前での改行を許してしまいます。印刷時の振る舞いとしては悪いことです。直前の単語と戻り値とを結合させるには、‘ \~’を使用してください。

.Hf
(ヘッダ) ファイルをそのまま含めるには、このマクロを使ってください。このマクロは、最初に‘ File:’とファイル名を表示し、その後で<ファイル>の内容を表示します。

使い方: .Hf <ファイル>

このマクロは、呼び出し不可能であり、構文解析もされません。

.Lk
将来書かれる予定です。
.Me
正確な使用方法は、分かりません。 -mdoc ソースファイル中の記述では、“メニューエントリ”となっています。

デフォルト幅は、6n です。

.Mt
将来書かれる予定です。
.Ot
正確な使用方法は、分かりません。 -mdoc ソースファイル中の記述では、“古い関数タイプ (fortran)”となっています。
.Sm
空白モードを有効に (トグル) します。

使い方: .Sm [ on | off] ...

空白モードが off の場合、マクロ引数の間に空白は、挿入されません。引数なしで呼ばれた場合 (あるいは次の引数が‘ on’でも‘ off’でもない場合) ‘ .Sm’マクロは、空白モードに入ります。

.Ud
マクロは、

currently under development.
 

を表示します。

このマクロは、呼び出し不可能であり、構文解析もされません。また引数もとりません。

定義済み文字列

次の文字列が定義済みです:
文字列 nroff troff 意味
<= <= 以下
>= >= 以上
Rq '' 右側のダブルクォート
Lq `` 左側のダブルクォート
ua ^ 上向き矢印
aa ´ ´ アキュートアクセント
ga ` ` グレーブアクセント
q " " まっすぐなダブルクォート
Pi pi pi ギリシャ語のパイ
Ne != 不等号
Le <= 以下
Ge >= 以上
Lt < < 小なり
Gt > > 大なり
Pm +- ± プラスマイナス
If infinity infinity 無限
Am & & アンパサンド
Na NaN NaN 非数値
Ba | | 垂直線

カラムの名前 nrofftroff は、少々誤解を招くものです。 nroff は、 ASCII 文字を表示しますが、 troff では、利用可能なもののうち一番良いグリフ形式を表示します。例えば、Unicode を使用可能にした TTY デバイスは、すべての文字列に対して適切なグリフ表現を持っていますが、それに対して Latin1 に対して機能を強化した TTY デバイスは、プラスマイナス記号しか持っていません。

文字を 2 つ含んだ文字列名は、‘ \*(xx’として表記できます。文字を 1 文字だけ含んだ文字列名は、‘ \*x’と表記できます。どのような長さの文字列名に対しても、一般的な文法は、‘ \*[xxx]’となります (これは、 GNU troff(1) 拡張です)。

 
 
 

診断

以前のバージョンの -mdoc パッケージでは、利用可能だったデバッグ用マクロ‘ .Db’は、取り除かれました。なぜなら、 GNU troff(1) では、パラメータをチェックするのにもっと良いファシリティを提供しているからです。さらに、このマクロパッケージには、エラーや警告メッセージが多数追加されており、よりロバストで饒舌なものになっています。

唯一残ったデバッグ用マクロは、‘ .Rd’であり、これは、すべてのグローバルレジスタならびに文字列のレジスタダンプを出力するものです。通常のユーザが使う必要は決してないでしょう。

GROFF, TROFF と NROFF を使用した書式設定

デフォルトでは、このパッケージでは、‘latin1’や‘unicode’のような TTY デバイスで表示する場合には、改ページやヘッダ、フッタは、禁止されており、マニュアルをオンラインで効率良く見ることができるようになっています。この振る舞いは、 groff(1) を呼んでいるときにレジスタ‘ cR’に 0 を指定することで変更することができます (例えば、 TTY 出力のハードコピーを作成したいときなど)。

groff -Tlatin1 -rcR=0 -mdoc foo.man > foo.txt

両面印刷用には、レジスタ‘ D’を 1 に設定してください:

groff -Tps -rD1 -mdoc foo.man > foo.ps

ドキュメントのフォントサイズを 11pt や 12pt に変更したい場合は、レジスタ‘ S’をそれに合わせて設定してください:

groff -Tdvi -rS11 -mdoc foo.man > foo.dvi

レジスタ‘ S’は、 TTY デバイスに対しては、無視されます。

行とタイトルの長さを変えたい場合、それぞれレジスタ‘ LL’と‘ LT’を設定してください:

groff -Tutf8 -rLL=100n -rLT=100n -mdoc foo.man | less

設定されていない場合、TTY デバイスに対しては、レジスタ値は、78n に、その他の場合 6.5i になります。

関連ファイル

doc.tmac
主なマニュアル用マクロパッケージです。
mdoc.tmac
doc.tmac を呼ぶラッパファイルです。
mdoc/doc-common
共通する文字列、定義、と印刷出力に関連する項目です。
mdoc/doc-nroff
TTY 出力デバイス用に使用される定義です。
mdoc/doc-ditroff
その他すべてのデバイス用に使用される定義です。
mdoc.local
ローカルマシンでの追加項目とカスタマイズ項目です。
andoc.tmac
-mdoc または -man パッケージのどちらが使用されるべきであるかどうかを知らないなら、このファイルを使用します。複数の man ページ (いずれかの形式) を扱うことができます。

バグ

セクション 3f は、ヘッダルーチンには追加されていません。

.NmNAME セクションにおいては、フォントを変更するべきです。

行の長さが短すぎる場合に行が分割されるのを防ぐために‘ .Fn’がチェックを行う必要があります。ときどき、最後の括弧が分割されることがあり、行詰めモードであるときにおかしな結果になることがあります。

リストマクロとディスプレイマクロは、何のキープも行いませんが、これは、キープを行うべきです。

November 2, 2010 FreeBSD