Provided by: manpages-ja_0.5.0.0.20221215+dfsg-1_all bug

名称

       tcsh  - ファイル名補完とコマンド行編集を追加した C シェル

書式

       tcsh [-bcdefFimnqstvVxX] [-Dname[=value]] [arg ...]
       tcsh -l

解説

       tcsh  は、バークレイ版 UNIX の C シェル csh(1) と完全に 互換性があり、さらに機能強化したシェルです。 対話
       的なログインシェル、またシェルスクリプトのコマンドプロセッサの 両方の用途で使われるコマンドインタプリタで
       す。  tcsh には、コマンド行編集 (コマンド行編集の項を参照)、 プログラム可能な単語の補完 (補完と一覧の項を
       参照)、 スペル訂正 (スペル訂正の項を参照)、 履歴  (ヒストリ置換の項を参照)、  ジョブ制御  (ジョブの項を参
       照)、  C 言語風の文法があります。 新機能の章では、csh(1) には存在しない、tcsh の 主な追加機能について説明
       しています。 このマニュアルを通じ、tcsh の機能のうち、 csh(1) のほとんどの実装 (特に 4.4BSD の csh) に な
       い機能について、ラベル (+) をつけてあります。 そして、csh(1) にあったけれども文書化されていなかった機能に
       ラベル (u) をつけてあります。

   引数リスト処理
       シェルへの 1 番目の引数 (引数 0 番) が `-' の場合、シェルは ログインシェルになります。 シェルを -l フラグ
       を指定して起動することでも ログインシェルにできます。

       残りのフラグは以下のように解釈されます。

       -b  このフラグは、オプションの処理を強制的に中断させる場合に使用します。 このフラグ以降の引数はすべて、オ
           プションではないものとして 処理されます。これにより、混乱を避け、小細工をしなくても、  シェルスクリプ
           トにオプションを渡すことが可能になります。  set-user  ID スクリプトは本オプションなしでは実行できませ
           ん。

       -c  コマンドを、本フラグの次にくる引数 (この引数は省略できません。 また、1 つだけである必要があります) か
           ら読み込み、実行します。 この引数は、あとで参照できるように、シェル変数 command に 格納されます。残り
           の引数は、シェル変数 argv に代入されます。

       -d  ログインシェルであるかどうかにかかわらず、   スタートアップとシャットダウンの項で解説されているように
           ~/.cshdirs から、ディレクトリスタックを読み込みます。(+)

       -Dname[=value]
           環境変数 name に値 value を設定します。(Domain/OS のみ) (+)

       -e  起動したコマンドが異常終了したり、0 でない終了ステータスを返したときに、 ただちにシェルを終了します。

       -f  ~/.tcshrc を読み込まずに無視するので、 起動が高速になります。

       -F  プロセスを生成する際に vfork(2) の代わりに fork(2) を使います。(Convex/OS のみ) (+)

       -i  たとえ端末上で実行されていなくても、対話的に動作し最上位レベルの 入力の際にプロンプトを表示します。入
           力と出力がともに端末である場合、 本オプションなしでもシェルは対話的に動作します。

       -l  ログインシェルとなります (-l が、指定された唯一のフラグである 場合にのみ有効です)。

       -m  実効ユーザに属していなくても ~/.tcshrc をロードします。 新しいバージョンの su(1) は -m をシェルに渡す
           ことが できます。(+)

       -n  コマンドの解析は行いますが、実行はしません。 シェルスクリプトのデバッグに役立ちます。

       -q  SIGQUIT  (シグナル処理の項を参照) を受け付けるようにし、 デバッガのもとで使われても作動するようになり
           ます。 ジョブ制御は無効になります。(u)

       -s  標準入力からコマンドを読み込みます。

       -t  入力から 1 行だけ読み込み、それを実行します。入力行の改行の直前に `\'  を置くことで、次の行への継続を
           行うことができます。

       -v  シェル変数  verbose を設定します。 これにより、ヒストリ置換された状態のコマンド行を表示するようになり
           ます。

       -x  シェル変数 echo を設定します。これにより、実行直前に、 実行するコマンドを表示するようになります。

       -V  ~/.tcshrc を実行する前に、シェル変数 verbose を設定します。

       -X  ~/.tcshrc を実行する前に、シェル変数 echo を設定します。

       -X  に対する -x の関係は、-V に対する -v の関係に 相当します。

       フラグ引数の処理のあと、もし引数が残っていて、かつ、 -c, -i, -s, -t のいずれのフラグも 指定されていなけれ
       ば、残っている引数のうち最初のものは  コマンドファイル、つまり「スクリプト」の名前とみなされます。 シェル
       はこのファイルをオープンし、`$0' による置換に備えて ファイル名を保存します。 多くのシステムは、スクリプト
       が本シェルと互換性のない version 6 または version 7 の標準のシェルを使っているため、 スクリプトの先頭の文
       字が `#' でない場合、 つまりスクリプトがコメントから始まらない場合、本シェルは それらの「標準」のシェルを
       起動して実行します。

       残りの引数はシェル変数 argv に設定されます。

   スタートアップとシャットダウン
       ログインシェルの場合は、実行開始に際し、まずシステムファイル  /etc/csh.cshrc/etc/csh.login を読み込ん
       で実行します。 そしてシェルを起動したユーザのホームディレクトリの中から、 まずはじめに ~/.tcshrc (+) を読
       み込んで実行します。   もし、~/.tcshrc   が見つからない場合は、~/.cshrc   を   読み込んで実行します。  次
       に、~/.history (もしくは、シェル変数 histfile の値) を、 その次に ~/.login を、最後に、~/.cshdirs (もしく
       は、   シェル変数   dirsfile   の値)   (+)   を読み込んで実行します。  コンパイルの仕方によって、シェルは
       /etc/csh.cshrc の後ではなく前に /etc/csh.login を読み込み、 ~/.tcshrc (または ~/.cshrc) と ~/.history  の
       後ではなく前に ~/.login を読み込む場合があります。 シェル変数 version を参照してください。(+)

       ログインシェルでない場合は、/etc/csh.cshrc と、 ~/.tcshrc (または ~/.cshrc) のみを起動時に読み込みます。

       スタートアップファイルの例は、 http://tcshrc.sourceforge.net を見てください。

       stty(1) や tset(1) のようなコマンドは、ログインする ごとに 1 度だけ実行される必要がありますが、これらのコ
       マンドは、 普通は ~/.login ファイルに入れます。 csh(1) と tcsh の両方で同じファイルのセットを使う  必要が
       あるユーザは、~/.cshrc  だけを使い、その中で  シェル変数  tcsh  (値は任意)  があるかどうかチェックして か
       ら、tcsh 特有のコマンドを使うようにします。または、 ~/.cshrc~/.tcshrc の両方を使うが、~/.tcshrc  で、
       source  コマンド (組み込みコマンドの項を参照) を使い ~/.cshrc を読み込むようにします。 以下、このマニュア
       ルの残りの部分で  `~/.tcshrc'  と表現したときは、  「~/.tcshrc、または  ~/.tcshrc  が見つからない  場合は
       ~/.cshrc」という意味で使います。

       通常、シェルはプロンプト `> ' を表示し、端末からコマンドの読み込みを 開始します (引数処理と、コマンドスク
       リプトを含むファイルの処理のための シェルの使用については、後で説明します)。 シェルは、入力されたコマンド
       行の読み込み、読み込んだコマンド行を単語に  分解、およびコマンド履歴への格納、コマンド行の解析、 コマンド
       行の中のコマンドそれぞれの実行を繰り返します。

       ログアウトするには、空の行で `^D' とタイプするか、`logout' するか、 `login'  するか、シェルの自動ログアウ
       ト機構 (シェル変数 autologout を参照) を使います。 ログインシェルが実行終了する際には、ログアウトの状況に
       応じて シェル変数 logout を `normal' か `automatic' に設定し、 /etc/csh.logout ファイルと ~/.logout  ファ
       イルにある  コマンドを実行します。 コンパイルの仕方によっては、シェルは、ログアウト時に DTR を落とす こと
       があります。これについてはシェル変数 version を参照してください。

       システムのログインファイル名、ログアウトファイル名は、 異なる csh(1) 間での互換性を保つために、  システム
       ごとにファイルが違います。これについては、 関連ファイルを参照してください。

   編集
       はじめに、コマンド行エディタについて説明します。 補完と一覧と、スペル訂正の 2 つの機能は、 編集コマンドと
       して実装されていますが、 特に分けて説明する必要があるため、項を改めて説明します。  最後に、編集コマンドの
       項で、シェルに特有の編集コマンドについて、 一覧をあげ、デフォルトのバインドとともに説明します。

   コマンド行編集 (+)
       コマンド行の入力データは、GNU  Emacs や vi(1) で使われているものと、 よく似たキーシーケンスを使って編集で
       きます。  シェル変数  edit  がセットされているときのみ、編集できるように   なっています。対話的なシェルで
       は、この値はデフォルトで  設定されています。 組み込みコマンド bindkey で、キーバインドを変更したり、 表示
       したりできます。 デフォルトでは、Emacs 形式のキーバインドが使われています (違う方法でコンパイルしなければ
       そうなります。  シェル変数 version を参照)。 しかし、コマンド bindkey で、キーバインドを vi 形式に 一括し
       て変更できます。

       シェルは、つねに矢印キー (環境変数 TERMCAP で定義されたものです) を、次のように割り付けています。

           下矢印  down-history
           上矢印  up-history
           左矢印  backward-char
           右矢印  forward-char

       他の  1   文字バインドによって、変わっていなければこのようになります。   このようなバインドにしたくない場
       合、settc を使って、矢印キーの エスケープシーケンスを空の文字列にセットすることができます。 ANSI/VT100 の
       矢印キーシーケンスは、つねにバインドされています。

       その他のキーバインドは、そのほとんどは、Emacs、vi(1) ユーザが 予想できるものです。また、簡単に bindkey コ
       マンドで表示させる   こともできるので、ここで、それらのバインドを並べあげる必要は   ないでしょう。   同じ
       く、bindkey コマンドは、それぞれの編集コマンドを 簡単な説明付きで、表示させることができます。

       注意: 「単語」という概念に関して、編集コマンドは、シェルと同じ概念を 持たないことに注意してください。  エ
       ディタは、シェル変数 wordchars の中にはない非英数文字 (英文字、数字のどちらでもない文字) によって単語の区
       切りを決めます。 一方、シェルは、ホワイトスペース (空白、タブ、改行) と、  字句構造の項で列挙する特殊な意
       味を持つ文字のいくつかを 識別します。

   補完と一覧 (+)
       シェルは、一意に決まる短縮形を与えられると、しばしば単語の補完を  行うことができます。 単語の一部 (たとえ
       ば `ls /usr/lost') をタイプして、タブキーを押すと、 編集コマンド  complete-word  が実行します。シェルは、
       ファイル名  `/usr/lost' を補完して `/usr/lost+found/' にします。 このとき、入力バッファの中で、不完全な単
       語を完全な単語で置き換えます。 (注意: 末端の `/'  について:  補完では、ディレクトリ名を補完すると  最後に
       `/'  を付け加えます。 そして、ディレクトリ名以外の単語を補完すると、末尾に空白文字を 付け加えます。こうす
       ることで、タイプ入力が速くなり、また、 補完が成功したことが一目で分かります。 シェル変数 addsuffix のセッ
       トをはずせば、    これらを付け加えなくすることもできます。)    合致するものが見当たらない場合   (おそらく
       `/usr/lost+found' が 存在しない場合でしょう)、端末のベルが鳴ります。 単語がすでに補完されている場合 (シス
       テムに `/usr/lost' が 存在する場合か、あるいは、ユーザがはるか先まで考えて、すべてを 入力してしまっていた
       場合でしょう)、`/' または空白文字が末尾に まだなければ、付け加えられます。

       補完は、行の一番最後でなくても、途中どこででも機能します。 そして、テキストの補完によって、その分、行の残
       りは右方向へ押されます。  単語の中間で補完された場合、しばしばカーソルの右側に文字が残り、 それを消すはめ
       になることもあります。

       コマンドと変数は、ほとんど同じ方法で補完できます。 たとえば、`em[tab]' とタイプした時、使用しているシステ
       ムで  `em' から始まるコマンドが唯一 emacs だけならば、 `em' は `emacs' と補完されます。 補完は、path 中の
       ディレクトリにあるコマンドか、     フルパスが与えられれば、そこにあるコマンドを見つけ出すことができます。
       `echo $ar[tab]' とタイプした時、他に `ar' から始まる変数がなければ、 `$ar' は `$argv' と補完されます。

       シェルは、入力バッファを解析して、補完したい単語を、ファイル名としてか、     コマンドとしてか、変数として
       か、どのように補完すべきかを決めます。 バッファの中の最初の単語と、`;', `|', `|&', `&&', `||' の すぐ次に
       くる単語は、コマンドとみなします。  `$' で始まる単語は、変数とみなします。 その他のものは、ファイル名とみ
       なします。 空の行は、ファイル名として `補完されて' います。

       いつでも、`^D' とタイプすることで、編集コマンド delete-char-or-list-or-eof を実行させて、  補完可能な単語
       の候補を並べ挙げることができます。 シェルは、組み込みコマンド ls-F (q.v.) を使って、 補完可能な候補を並べ
       挙げます。 そして、プロンプトと未完成のコマンドラインを再表示します。 次に例を示します。

           > ls /usr/l[^D]
           lbin/       lib/    local/      lost+found/
           > ls /usr/l

       シェル変数 autolist をセットしていれば、シェルは、 補完に失敗したときはいつでも残りの選択肢を表示します。

           > set autolist
           > nm /usr/lib/libt[tab]
           libtermcap.a@ libtermlib.a@
           > nm /usr/lib/libterm

       シェル変数 autolist を `ambiguous (あいまいな)' に セットした場合は、補完に失敗して補完される単語へ新しい
       文字を それ以上追加できなくなったときに限り、選択肢を表示します。

       補完するファイル名には、変数、自分もしくは他人のホームディレクトリ  (`~' で短縮したもの。ファイル名置換の
       項を参照)、 ディレクトリスタックエントリ (`=' で短縮したもの。 ディレクトリスタック置換の項を参照) を含め
       ることができます。 たとえば、次のようになります。

           > ls ~k[^D]
           kahn    kas    kellogg
           > ls ~ke[tab]
           > ls ~kellogg/

       あるいは、

           > set local = /usr/local
           > ls $lo[tab]
           > ls $local/[^D]
           bin/ etc/ lib/ man/ src/
           > ls $local/

       変数については、編集コマンド expand-variables を指定して使っても 展開できることに注意してください。

       コマンド  delete-char-or-list-or-eof は、行の最後でのみ リストを表示します。 行の中間の場合、カーソル位置
       の文字を消去します。  空行の場合、ログアウトします。ただし、ignoreeof  がセットされて  いれば、何もしませ
       ん。 `M-^D' は、編集コマンド list-choices にバインドされていますが、 これは行中のどこでも、補完の候補のリ
       ストを表示します。 list-choices (または、delete-char-or-list-or-eof のところで 列挙するコマンドで、消去す
       るコマンド、しないコマンド、  リスト表示するコマンド、ログアウトするコマンドのどれでも)  は、そうしたい場
       合、組み込みコマンド bindkey で `^D' にバインドすることもできます。

       編集コマンド complete-word-fwdcomplete-word-back (デフォルトでは、どのキーにも割り付けられていません)
       を使うことで、 補完候補のリストを上または下に順に巡り、リスト上の現在の単語を、 次の単語または 1 つ前の単
       語に置き換えることができます。

       シェル変数 fignore に、補完の際に無視するファイルの サフィックスのリストをセットできます。 次の例を考えて
       みます。

           > ls
           Makefile    condiments.h~   main.o    side.c
           README    main.c    meal     side.o
           condiments.h    main.c~
           > set fignore = (.o \~)
           > emacs ma[^D]
           main.c   main.c~  main.o
           > emacs ma[tab]
           > emacs main.c

       `main.c~' と `main.o' は、fignore にサフィックスが 登録されているために、補完では無視されます (しかしリス
       ト上には表示されます)。 ファイル名置換の項で解説しているように、home に 拡張されないようにするために、`~'
       の前に  `\'  が必要なことに 注意してください。補完の候補が1 つしかない場合は、 fignore の設定は無視されま
       す。

       シェル変数 complete が `enhance(拡張)' にセットされていた場合、補完は 1) 大文字小文字の区別を無視し、  2)
       ピリオド、ハイフン、アンダスコア (`.', `-', `_')を、 単語を分ける記号であるとみなし、ハイフンとアンダスコ
       アは 同等なものとみなします。 次のようなファイルがある場合、

           comp.lang.c     comp.lang.perl   comp.std.c++
           comp.lang.c++    comp.std.c

       `mail -f c.l.c[tab]' とタイプすれば、`mail -f comp.lang.c' のように補完され、^D の場合には、`comp.lang.c'
       と `comp.lang.c++' が リストとして表示されます。 `mail -f c..c++[^D]' とタイプした場合は、`comp.lang.c++'
       と `comp.std.c++' が表示されます。 次のファイルがあるディレクトリで、`rm a--file[^D]' とタイプした 場合、

           A_silly_file    a-hyphenated-file    another_silly_file

       の 3 つのファイルすべてが一覧表示されます。 なぜならば、大文字小文字の区別は無視されて、 ハイフンとアンダ
       スコアは同等と解釈されるからです。しかしながら、 ピリオドは、ハイフンやアンダスコアと同等ではありません。

       補完と一覧は、他にもいくつかのシェル変数の影響を受けます。  そのひとつ、recexact をセットすると、続けてタ
       イプすれば   より長い単語に合致するような場合でさえも、    最短で一意に一致する単語に合致するようになりま
       す。たとえば、

           > ls
           fodder   foo      food     foonly
           > set recexact
           > rm fo[tab]

       この場合はベルが鳴るだけです。  なぜなら、`fo' は、`fod' または `foo' に展開できるからです。 しかし、さら
       に `o' とタイプすると、

           > rm foo[tab]
           > rm foo

       `food' や `foonly' も合致するにもかかわらず、 補完は `foo' で完了します。 autoexpand をセットすると、補完
       を試みる前に、毎回、  編集コマンド  expand-history  を実行するようになります。  autocorrect  をセットする
       と、補完を試みる前に、毎回、 その単語のスペル訂正をするようになります (スペル訂正の項を参照)。 correct を
       セットすると、`return (enter)' キーを押したあと、 自動的にコマンドを補完するようになります。 matchbeep を
       セットすると、補完に際して、状況の変化に応じて、 ベルを鳴らしたり、鳴らないようにできます。 nobeep をセッ
       トすると、まったくベルを鳴らさないようにできます。 nostat には、ディレクトリのリストやディレクトリに 合致
       するパターンをセットでき、これらのディレクトリで補完機構が stat(2) を実行しないようにすることができます。
       listmaxlistmaxrows にセットすることで、 まず問い合わせずに一覧表示する項目の数や、列の数を、それぞれ
       制限することができます。  recognize_only_executables  をセットすると、   シェルがコマンド一覧を表示する際
       に、実行可能ファイルだけを 一覧表示するようにさせることができます。ただし、動作はきわめて 遅くなります。

       最後に、組み込みコマンド complete を使って、ファイル名、 コマンド、変数以外の単語を補完する方法をシェルに
       教えることができます。 補完と一覧は、グロブパターン (ファイル名置換の項を参照) 上では機能しませんが、編集
       コマンド list-globexpand-glob はグロブパターンに対し同等の機能として実行されます。

   スペル訂正 (+)
       シェルは、補完したり一覧表示するのと同様に、ファイル名、コマンド、 変数名のスペルを訂正することができるこ
       とがあります。

       個々の単語は、編集コマンド spell-word (普通は M-s  と  M-S  に  バインドされています)  でスペル訂正できま
       す。入力バッファ全体は spell-line  (普通は M-$ に割り付けられています) で スペル訂正できます。 シェル変数
       correct に `cmd' を設定されておけば、コマンド名が スペル訂正されます。`all'  を設定しておけば、リターンが
       タイプされる  たびに行全体がスペル訂正されます。 autocorrect がセットされていれば、単語に補完を試みる前に
       その単語をスペル訂正します。

       スペル訂正が、ここで説明した方法のいずれかにより呼び出され、 コマンド行のどこかにスペル誤りがあると判断す
       ると、 シェルは、次のように訂正済みのコマンド行を表示し入力を待ちます。

           > set correct = cmd
           > lz /usr/bin
           CORRECT>ls /usr/bin (y|n|e|a)?

       これに対し、`y' または空白文字で答えると、訂正済み行を実行し、 `e' で答えると、入力バッファに訂正前のコマ
       ンドを残し、 `a' で答えると、`^C' が押された場合と同様にコマンドを中止し、 それ以外の場合は、元のままの行
       を変えないで実行します。

       スペル訂正は、ユーザ定義の補完を識別します  (組み込みコマンド complete を参照)。 もし、補完が実行される位
       置で、入力された単語が補完リストの中の単語に 似ていたとき、スペル訂正は、ミススペル記録して、見つかった単
       語を  訂正候補として提案します。しかし、入力された単語がその位置で、 どの補完候補にも合致しなかった時、ス
       ペル訂正は、 ミススペルを示しません。

       補完と同様、スペル訂正は行のどこでも機能します。行の残りを右に 押し出したり、残りの余分な文字をカーソルの
       右に残したりします。

       注意: スペル訂正は、意図どおりに動作する保証はありません。 そして、ほとんど実験的な機能として提供されてい
       ます。 提案、改善する点があれば歓迎します。

   編集コマンド (+)
       `bindkey' はキーバインド一覧を表示し、 `bindkey -l'  は編集コマンドの一覧と短い解説を表示します。  ここで
       は、新しい編集コマンド、または、特に興味深い編集コマンドに  ついてのみ解説します。 エディタのキーバインド
       割り付けの記述については、 emacs(1) と vi(1) を参照してください。

       デフォルトでそれぞれのコマンドにバインドられた文字     (あるいは複数文字)      は、括弧の中に示しました。
       `^character'  は制御文字を意味します。  `M-character'はメタ文字です。 メタキーがない端末の場合は、escape-
       character  とタイプします。  大文字小文字の区別はありますが、  デフォルトで英文字に割り付けられるコマンド
       は、便宜上、 大文字、小文字の両方にキーバインドされています。

       complete-word (tab)
               補完と一覧の項で解説しているとおり、単語を補完します。

       complete-word-back (not bound)
               complete-word-fwd と同様ですが、単語リストの終わりから、 上へあがって行きます。

       complete-word-fwd (not bound)
               現在の単語を、補完可能単語リスト上の始めの単語で置き換えます。 本コマンドを繰り返すことで、単語リ
               スト上を下へ降りていくことができます。 単語リストの最後までいくと、ベルが鳴り、未補完の単語へ戻り
               ます。

       complete-word-raw (^X-tab)
               complete-word と同様ですが、ユーザ定義した補完は無視されます。

       copy-prev-word (M-^_)
               現在の行で、1 つ前の単語を入力バッファへコピーします。 insert-last-word も参照してください。

       dabbrev-expand (M-/)
               以前入力した単語の中で、現在の単語が先頭部分文字列であり、しかも 最近のものを見つけて、それで展開
               します。 必要ならば、ヒストリリストを一周回って元に戻って探します。 dabbrev-expand を中断せず繰り
               返すことで、  その次の単語に変わります。  history-search-backward と同様に、同一のマッチングは ス
               キップします。

       delete-char (割り付けなし)
               カーソル下の文字を削除します。 delete-char-or-list-or-eof も参照してください。

       delete-char-or-eof (割り付けなし)
               カーソル下に文字があれば delete-char を実行し、 空行では end-of-file を実行します。  delete-char-
               or-list-or-eof も参照してください。

       delete-char-or-list (割り付けなし)
               カーソル下に文字があれば  delete-char を実行し、 行の末尾では list-choices を実行します。 delete-
               char-or-list-or-eof も参照してください。

       delete-char-or-list-or-eof (^D)
               カーソル下に文字があれば delete-char を実行し、  行の末尾では  list-choices  を実行し、  空行では
               end-of-file を実行します。 これらの 3 つのコマンドも参照してください。 これらのコマンドは、それぞ
               れ 1 つの動作を実行するだけです。 delete-char-or-eof, delete-char-or-list, list-or-eof は、  それ
               ぞれ 3 つのうちの異なる 2 つを実行します。

       down-history (下矢印, ^N)
               up-history と同様ですが、1 つずつ下に移動し、もとの入力行で止まります。

       end-of-file (割り付けなし)
               ファイルの終端であることをシェルに通知します。 シェル変数 ignoreeof (そちらも参照) がセットされて
               いない場合、その結果として、シェルは実行を終了します。 delete-char-or-list-or-eof  も参照してくだ
               さい。

       expand-history (M-space)
               現在の単語のヒストリ置換を展開します。   ヒストリ置換を参照してください。   magic-space,  toggle-
               literal-history と、シェル変数 autoexpand も参照してください。

       expand-glob (^X-*)
               カーソルの左にグロブパターンを展開します。 ファイル名置換を参照してください。

       expand-line (割り付けなし)
               expand-history と同様ですが、入力バッファのそれぞれの単語の ヒストリ置換を展開します。

       expand-variables (^X-$)
               カーソルの左に変数を展開します。 変数置換を参照してください。

       history-search-backward (M-p, M-P)
               ヒストリリストを後方へ向かって、入力バッファの現在の中身 (カーソル位置まで)  で始まるコマンドを検
               索し、 それを入力バッファへコピーします。 検索文字列は、`*', `?', `[]', `{}' を含んだグロブパター
               ン (ファイル名置換を参照) であってもかまいません。 up-historydown-history  は、ヒストリリスト
               の該当する  地点から始める事ができます。  Emacs  モードのみです。  history-search-forwardi-
               search-back も参照してください。

       history-search-forward (M-n, M-N)
               history-search-backward と同様ですが、前方へ検索します。

       i-search-back (割り付けなし)
               後方へ、history-search-backward  のように検索して、  最初に合致したものを入力バッファへコピーし、
               カーソルをパターンの最後に位置させます。  そして、`bck: 'プロンプトと最初に合致したものを表示しま
               す。 追加の文字をタイプして、その検索を延長することができます。 i-search-back  をタイプして、同じ
               パターンで検索を延長する  こともできます。必要があれば、ヒストリリストを一周回って 元に戻って検索
               を続けます。  (これを行うためには、i-search-back  は、1  文字に  バインドされていなければなりませ
               ん。) あるいは、以下の特殊文字をタイプすることもできます。

                   ^W      カーソル下の単語の残りを検索パターンに加えます。
                   delete (あるいは backward-delete-char にバインドされた文字)
                           最後にタイプされた文字の効果をとりけし、 適当なら検索パターンから文字を削除します。
                   ^G      前の検索が成功していたなら、検索全体を中止します。 そうでないなら、一番最後に成功した
                           検索まで戻ります。
                   escape  検索を終え、入力バッファの現在の行をそのまま残します。

               この他の文字で、self-insert-command にバインドされている 以外のものをタイプすると、検索が終了しま
               す。入力バッファの現在の行は   そのままになり、タイプした文字は通常の入力として解釈されます。  特
               に、キャリッジリターンの場合は、現在の行を実行に移します。 Emacs モードのみです。 i-search-fwdhistory-search-backward も参照してください。

       i-search-fwd (割り付けなし)
               i-search-back と同様ですが、前方へ検索します。

       insert-last-word (M-_)
               1  つ前の入力行  (`!$')  の最後の単語を入力バッファに挿入します。 copy-prev-word も参照してくださ
               い。

       list-choices (M-^D)
               補完と一覧で解説しているように、補完の可能性を一覧表示します。   delete-char-or-list-or-eoflist-choices-raw も 参照してください。

       list-choices-raw (^X-^D)
               list-choices と同様ですが、ユーザ定義された補完を無視します。

       list-glob (^X-g, ^X-G)
               カーソルの左側のグロブパターン (ファイル名置換を参照) に 合致したものを (組み込みコマンド ls-F を
               用いて) 一覧表示します。

       list-or-eof (割り付けなし)
               list-choices を実行するか、または、空行の場合 end-of-file を  実行します。delete-char-or-list-or-
               eof も参照してください。

       magic-space (割り付けなし)
               まず  expand-history  と同様に、現在の行のヒストリ置換を展開して、  その後で空白を 1 つ付け加えま
               す。 magic-space はスペースキーにバインドするように  設計されていますが、デフォルトではバインドさ
               れていません。

       normalize-command (^X-?)
               パスの中の現在の単語を検索します。そして、見つかった場合、 実行可能ファイルを指すフルパスで置き換
               えます。 特殊文字はクォートされます。エイリアスは展開されて、クォートされますが、  エイリアス中の
               コマンドは展開  /  クォートされません。 このコマンドは、たとえば、`dbx' や `sh -x' などのように、
               コマンドが引数を取得する場合に役立ちます。

       normalize-path (^X-n, ^X-N)
               シェル変数 symlinks の設定 `expand' の項で説明されているように、 現在の単語を展開します。

       overwrite-mode (割り付けられていません)
               入力モードと上書きモードの間で切り替えます。

       run-fg-editor (M-^Z)
               現在の入力行を保存します。そして、環境変数 EDITOR または VISUAL  のファイル名部分の最後の構成要素
               (または、どちらもセットされていなければ、`ed' か `vi') と等しい名前を持ち、ストップしているジョブ
               を探します。 そのようなジョブが見つかれば、`fg %job' とタイプしたのと  同じように、実行再開されま
               す。 これは、エディタとシェルの間を抜けて交互に切り替えるのを容易にする ために使われます。 このコ
               マンドを `^Z' にバインドし、もっと簡単に交互の切り替えが できるようにする人もいます。

       run-help (M-h, M-H)
               補完ルーチンの `現在のコマンド'  と同じ概念による  現在のコマンドのドキュメントを検索し、表示しま
               す。 ページャを使う方法はありません。run-help は短いヘルプファイルと のために設計されているためで
               す。 特別なエイリアス helpcommand が定義されていた場合、 コマンド名を唯一の引数としてその値が実行
               されます。  ほかに、ドキュメントのファイル名は、コマンド名.help, コマンド名.1, コマンド名.6, コマ
               ンド名.8, コマンド名のいずれかでなければなりません。  また、そのファイルは、環境変数  HPATH  の中
               で、 一覧にあがっているディレクトリのうちの 1 つに入っていなければなりません。 もし、1 つ以上のヘ
               ルプファイルがある場合は、最初の 1 つのみが プリントされます。

       self-insert-command (テキスト文字)
               挿入モード (デフォルト) では、タイプした文字を、 カーソル下の文字の後に挿入します。  上書きモード
               では、タイプした文字で、カーソル下の文字を置き換えます。 入力モードは、通常、各行の間で維持されて
               いますが、 シェル変数 inputmode を `insert(挿入)' あるいは、 `overwrite(上書き)' にセットしておく
               と、 エディタを、各行の始まりで、そのモードにすることができます。 overwrite-mode も参照してくださ
               い。

       sequence-lead-in (矢印接頭辞、メタ接頭辞、^X)
               次に続く文字がマルチキーシーケンス (複数文字の連続) であることを 表します。マルチキーシーケンスを
               コマンドにバインドする場合、   実際には、次の   2   つのバインドを作ります。   まず、最初の文字を
               sequence-lead-in とします。そして、 シーケンス全体をそのコマンドにバインドします。 sequence-lead-
               in にバインドされた文字で始まる すべてのシーケンスは、他のコマンドにバインドされていなければ、 実
               質的には undefined-key にバインドされたのと同じことに なります。

       spell-line (M-$)
               spell-word と同様に、入力バッファ中の各単語のスペル訂正を  試みます。しかし、単語の最初の文字が、
               `-', `!', `^', `%' のうちのどれかの場合と、 単語中に `\', `*', `?' のいずれかを含んでいる場合は、
               スイッチや、置換などの問題を避けるために、これらの単語を無視します。   スペル訂正を参照してくださ
               い。

       spell-word (M-s, M-S)
               スペル訂正の項で説明されているのと同じやり方で、現在の単語の  スペルの訂正を試みます。 パス名とし
               て現れる単語の部分をそれぞれにチェックします。

       toggle-literal-history (M-r, M-R)
               入力バッファのヒストリ置換を展開したり、`しなかったり'  します。  expand-history   と、シェル変数
               autoexpand も参照してください。

       undefined-key (割り付けのコマンドが無いキー)
               ベルを鳴らします。

       up-history (上矢印, ^P)
               ヒストリリストの中から  1 つ前のエントリを入力バッファにコピーします。 histlit がセットされている
               場合、その記入された文字どおりの 形式を使います。 ヒストリリストを上の方へ 1 つずつ移動を繰り返し
               た場合、 一番上で止まります。

       vi-search-back (?)
               検索文字列  (history-search-backward と同様、グロブパターンでも 構いません) の入力のために `?' を
               プロンプト表示します。 その文字列を検索して、同じ文字列を入力バッファへコピーします。  合致するも
               のが見つからなければ、ベルが鳴ります。  リターンキー  (enter キー) を押すと、検索を終了して、入力
               バッファ中に 最後に合致した単語を残します。 escape キーを押すと、検索を終了して、合致したものを実
               行します。 vi モードのみです。

       vi-search-fwd (/)
               vi-search-back と同様ですが、前方へ検索します。

       which-command (M-?)
               入力バッファの最初の単語に対して、which (組み込みコマンド の解説を参照) を実行します。

   字句構造
       シェルは入力された行をタブや空白で単語に分割します。 特殊文字 `&', `|', `;', `<', `>', `(', `)', 2 文字繰
       り返しの `&&', `||', `<<' ,  `>>'  は、空白で囲まれているか  どうかにかかわらず、常に単語の区切りになりま
       す。

       シェルの入力が端末からではないとき、文字  `#' は、コメントの始まりと して扱われます。`#' とその後ろの入力
       行の残りはコメントと解釈され、 文法解析されずに捨てられます。

       特殊文字  (空白、タブ含む)  は、その文字の直前にバックスラッシュ   `\'   を置くことで、または、単一引用符
       `''、二重引用符  `"'、  逆引用符  ``'  で囲むことで、特殊な意味合いを持たないようにしたり、  場合によって
       は、他の単語の一部分にすることもできます。 他に引用がなされない限り、`\' の直後に改行文字を置くと、改行文
       字は 空白扱いになります。しかし、引用中では、この文字の並びは改行文字に なります。

       さらに、ヒストリ置換を除く、すべての置換 (次項を参照) は、置換を含む文字列 (あるいは文字列の一部) を 単一
       引用符で囲むことで防ぐことができます。 あるいは、重大な文字 (たとえば、変数置換 ならば `$' や、コマンド置
       ならば ``') を `\' で クォートすることで 防ぐことができます。(エイリアス置換も例外ではありません。 一度
       定義された alias に対して、何らかの方法でその単語の  どれかの文字をクォートすることで、そのエイリアスの置
       換を防ぐことが  できます。エイリアスをクォートする普通の方法は、そのエイリアスの前に バックスラッシュを置
       くことです。) ヒストリ置換は、バックスラッシュを用いることで防ぐことが できますが、単一引用符では防ぐこと
       ができません。。 二重引用符、逆引用符でクォートされた文字列は、 変数置換コマンド置換は受けますが、 その
       他の置換は受けません。

       単一引用符、二重引用符で囲まれたテキストは 1 つの単語 (または その一部) となります。 それらの文字列中のメ
       タ文字 (空白、タブを含む) は、単語を分割しません。 ひとつだけ特殊な場合 (次のコマンド置換を参照) として、
       二重引用符で囲まれた文字列を 1 つ以上の単語に分けることができます。  これは、単一引用符で囲まれた文字列で
       は決してできません。 逆引用符は特殊で、コマンド置換 (そちらも参照) に、 影響を与え、その結果が 1 つ以上の
       単語になることもあります。

       複雑な文字列をクォートする場合、特に、文字列自身にクォート文字が 含まれている場合は、わかりにくいかもしれ
       ません。 人間が書いたものの中では、引用符を引用のために使う必要はないことを 忘れないように!  文字列全体を
       クォートするのではなく、もし適当ならば異なるタイプの 引用符を用い、クォートする必要のある文字列の一部分の
       みをクォートする ことの方が、簡単かもしれません。

       シェル変数 backslash_quote (そちらも参照) を セットすると、 バックスラッシュが常に `\', `'', `"' をクォー
       トするようにできます。(+) これによって、複雑な引用をする仕事が簡単になるかもしれません。 しかし csh(1) の
       スクリプトでは、構文エラーの原因になります。

   置換
       ここで、シェルが入力に対して行うさまざまな変換を、 処理が行われる順に記述します。同時に、処理に関わるデー
       タ構造と、 データ構造に影響を与えるコマンドと変数とにも触れておきます。  字句構造のところで説明する引用に
       より、置換を抑制できることを 覚えておいてください。

   ヒストリ置換
       端末から入力したコマンドひとつひとつ (イベント) は、ヒストリリストに 保存されます。直前のコマンドは常に保
       存されます。さらに、保存する コマンド数を、シェル変数 history に設定することができます。 重複するイベント
       を保存するかどうか、同じイベントの連続をそのまま  保存するかどうかを、シェル変数 histdup に設定することが
       できます。

       保存されたコマンドには、1 から始まる連続した番号が振られ、 タイムスタンプが打たれます。普通イベント番号を
       用いる必要はありませんが、 シェル変数 prompt の中に `!' を置くことで、現在のイベント番号を プロンプトの一
       部にすることができます。

       実際のところ、シェルは、ヒストリを展開形式と 文字どおり  (未展開)  の形式とで保存しています。  シェル変数
       histlit を設定しておくと、 ヒストリを表示する / ヒストリに保存するコマンドで 文字どおりの形式を用いるよう
       になります。

       組み込みコマンド history により、ヒストリリストの表示、  ファイルに保存、ファイルからの読み込み、クリアを
       いつでも行えます。  シェル変数 savehisthistfile により、 ヒストリリストのログアウト時の自動保存と、ロ
       グイン時の自動読み込みを 設定することができます。

       ヒストリ置換により、ヒストリリストから単語の列を入力ストリームに 持ち込みます。これにより、前のコマンドの
       繰り返し、前のコマンドで使った    引数の繰り返し、前のコマンドで間違えたスペルの修正を   わずかなキー入力
       で、かなり確実に 容易に行うことができるようになります。

       ヒストリ置換は、文字  `!'  で始まります。ヒストリ置換は、  入力ストリームのどこから開始してもかまいません
       が、入れ子には  できません。  文字  `!'  の前に `\' を置くことで、`!' の特殊な意味を打ち消すことが できま
       す。文字 `!' が、空白文字、タブ文字、改行文字、`='、`(' の 前にある場合は、そうした方が便利なので、無変更
       のまま渡されます。 入力行が `^' で始まる場合にも、ヒストリ置換が生じます。 この省略表現については後で説明
       します。 ヒストリ置換を示すための文字 (`!' と `^') は、 シェル変数 histchars を設定することにより変更する
       ことが できます。入力行がヒストリ置換を含む場合、実行前に置換結果が 常に表示されます。

       ヒストリ置換には「イベント指定」、「単語指定子  (word designator)」、 「修飾子 (modifier)」を含めることが
       できます。イベント指定は、 どのイベントから単語の列を取り出すかを指定します。単語指定子は、  選択したイベ
       ントからどの単語を選ぶかを指定します。修飾子は、 選択した単語をどう操作するかを指定します。

       イベント指定には、次のものがあります。

           n       番号: これはある特定のイベントを指定します。
           -n      オフセット: これは現在のイベントの前 n 個目のイベントを 指定します。
           #       現在のイベントを指定します。これは   csh(1)  の中では注意して  扱わねばなりません。csh(1)  で
                   は、再帰呼び出しのチェックを していないからです。tcsh では、再帰呼び出しは 10 レベルまで 許さ
                   れています。(+)
           !       1 つ前のイベントを指定します (`-1' と等価)。
           s       先頭の単語が s で始まるイベントのうち、最も新しいものを 指定します。
           ?s?     文字列  s を含むイベントのうち、最も新しいものを指定します。 直後が改行文字の場合は、2 番目の
                   `?' は省略可能です。

       たとえば、次のようなヒストリリストがあるとします。

            9  8:30    nroff -man wumpus.man
           10  8:31    cp wumpus.man wumpus.man.old
           11  8:36    vi wumpus.man
           12  8:37    diff wumpus.man.old wumpus.man

       コマンドが、イベント番号とタイムスタンプ付きで表示されています。   現在のイベントは、まだ入力していません
       が、イベント  13 です。 `!11' と `!-2' は、イベント 11 を指します。`!!' は、直前の イベントであるイベント
       12 を指します。`!!' は、後ろに `:' が 付いている場合、`!'  と省略することができます  (`:'  は後で説明しま
       す)。`!n'  は、`n'  から始まっている、 イベント 9 を指します。`!?old?' は、`old' を含んでいる イベント 12
       を指します。単語指示子も単語修飾子もどちらも含まない場合、 ヒストリ参照はそのイベント全体を展開するだけで
       す。ですから、  コピーコマンドを再実行したいときは `!cp' と入力しますし、`diff' の 出力が画面上端からスク
       ロールして消えてしまう場合、`!!|more' と 入力します。

       必要に応じ、中括弧で囲むことで、ヒストリ置換を前後のテキストから           分離することができます。たとえ
       ば、`!vdoc'  とすると、`vdoc'  で始まる  コマンドを探しますが、この例で見つからないにしても、`!{v}doc' で
       は、 あいまいさもなく `vi wumpus.mandoc' に展開されます。  中括弧の中でも、ヒストリ置換は入れ子になりませ
       ん。

       (+)  csh(1) では、たとえば `!3d' は、イベント 3 の後ろに 英文字 `d' を付加して展開しますが、tcsh では、こ
       れを `3d' で 始まるイベントのうち最新のものに展開します。つまり、完全な数値引数  だけをイベント番号と見な
       します。これにより、数字から始まるイベントを  呼び出すことが可能となります。`!3d' を csh(1) のように 展開
       させるには、`!\3d' と指定してください。

       イベントから単語を選択する場合、`:'   と選択する単語を表す指示子を使い、   イベント指定を行うことができま
       す。入力行の単語には、0 から始まる 番号が振られています。最初の単語 (普通、コマンドです) は 0 で、 2 番目
       の単語 (第 1 引数) は 1 といった具合です。基本的な単語指示子は 次のようになります。

           0       最初の単語 (コマンド)
           n       n 番目の引数
           ^       最初の引数、`1' と等価
           $       最後の引数
           %       ?s? 検索で一致した単語
           x-y     ある範囲の単語
           -y      `0-y' と等価
           *       `^-$' と等価。但し、イベントが 1 単語しか含まない場合は何も返さない。
           x*      `x-$' と等価
           x-      `x*' と等価。但し、最後の単語 (`$') は除く。

       選択した単語は、空白文字 1 つで区切られてコマンド行に挿入されます。 たとえば、`diff !!:1.old !!:1' と打ち
       込むことで、先の例の  `diff' コマンドを入力することもできます (`:1' で、直前のイベントから 最初の引数を選
       択しています)。また、`diff !-2:2 !-2:1' と 打ち込むことで `cp' コマンドの引数を選択し、入れ換えることがで
       きます。  `diff'  コマンドの引数の順番を気にしなければ、`diff  !-2:1-2' と 打ち込んでも構いませんし、単に
       `diff !-2:*' でも構いません。 `cp' コマンドは、現在のイベントを指す `#' を使い、 `cp wumpus.man !#:1.old'
       と書くことができます。`!n:-  hurkle.man'  は、  `nroff' コマンドから最初の 2 単語を再利用し、 `nroff -man
       hurkle.man' とすることになります。

       文字 `:' は単語指定からイベント指定を分離しますが、引数選択子が `^', `$', `*', `%', `-'  で始まるとき、こ
       の文字  `:'  は省略可能  です。たとえば、先ほどの  `diff'  コマンドは  `diff  !!^.old !!^' もしくは `diff
       !!$.old !!$' でも構わなかったのです。 しかし、`!!' が `!' に省略可能である場合、`-'  で始まる引数選択子は
       イベント指定として解釈されます。

       ヒストリ参照に、イベント指定のない単語指示子があっても構いません。 その場合、直前のコマンドを参照します。
       `diff' の例を続けるなら、単純に `diff !^.old !^' と入力することが  できます。もしくは、逆順の引数を得るだ
       けならば、単に `diff !*' で いいです。

       ヒストリ参照の中の単語は編集可能です。つまり、単語の後ろに  1 つまたは 複数の修飾子 (修飾子それぞれは `:'
       で始まります) を付けることで 「修飾」可能です。

           h       先頭のもの 1 つを残し、パス名の構成要素の後ろの部分を削除します。
           t       末尾のもの 1 つを残し、パス名の構成要素の先頭の部分を削除します。
           r       ファイル名拡張子 `.xxx' を削除し、名前の基本部分だけを残します。
           e       拡張子だけを残し、他をすべて削除します。
           u       最初の英小文字を大文字に変換します。
           l       最初の英大文字を小文字に変換します。
           s/l/r/  lr で置換します。 lr と同様に、単なる文字列です。名付け親である ed(1)  コマンドのよう
                   な正規表現ではありません。 `/' の代わりに任意の文字を区切り文字として使うことができます。 `\'
                   を使い、lr の中で区切り文字をクォートすることが できます。 r 中の文字 `&' は、l  で置き換
                   えられます。`\'  で `&' も クォートできます。l が空 (``'') の場合、以前の置換の l 、 または以
                   前のイベント指定 `?s?' の s を使用します。 最後の区切り文字の直後が改行文字の場合、その区切り
                   文字を省略できます。
           &       以前の置換を繰り返します。
           g       後ろの修飾子を単語それぞれに適用します。
           a (+)   後ろの修飾子を、ある単語だけにできるだけ多くの回数、適用します。  `a' と `g' をいっしょに用い
                   て、修飾子をグローバルに適用することが できます。現在の実装では、修飾子 `a' と修飾子 `s' を同
                   時に使用すると、  無限ループに陥る可能性があります。たとえば、`:as/f/ff/' は決して 終わりませ
                   ん。この動作は今後変更されるかもしれません。
           p       新しいコマンド行を表示しますが、実行はしません。
           q       置換された単語をクォートし、それ以上の置換が起きないようにします。
           x       q と同じです。ただし、単語を空白 / タブ / 改行文字のところで分割します。

       修飾子は最初に見つかった修飾可能な単語だけに適用されます (`g' を  使用しない限り)。修飾可能な単語がない場
       合はエラーになります。

       たとえば、先の例の `diff' コマンドは、`diff wumpus.man.old !#^:r' とも 書くことができます。これは、`r' を
       用いて、同じ行 (`!#^') の最初の 引数から `.old' を削除しています。`echo hello out there' と  言っておいて
       から、`echo  !*:u' を使い `hello' を大文字にできます。 `echo !*:au' を使い大声で言うようにできます。`echo
       !*:agu' を使い 絶叫させることもできます。`mail -s "I forgot my password" rot' の後で `!:s/rot/root'  を続
       けることで、`root' のスペル間違いを直すこと ができます (スペル間違いの訂正については、スペル訂正の項に 別
       のやり方があります)。

       置換には特別な省略記法があります。`^' が入力行の先頭にある場合、 `!:s^'  と等価です。よって、先の例でスペ
       ルを訂正するには、 ^rot^root と言うこともできたわけです。これは明示的に `!' で 始まらないヒストリ置換とし
       ては唯一のものです。

       (+) csh では、ヒストリ展開または変数展開に適用される修飾子は 1 つだけです。tcsh では、1  つ以上の修飾子が
       使用される可能性が あります。たとえば、次のような場合を考えます。

           % mv wumpus.man /usr/man/man1/wumpus.1
           % man !$:t:r
           man wumpus

       csh では、この結果は `wumpus.1:r' となります。コロンが後ろに続く 置換は、中括弧を用いてコロンと区切る必要
       があります。

           > mv a.out /usr/games/wumpus
           > setenv PATH !$:h:$PATH
           Bad ! modifier: $.
           > setenv PATH !{-2$:h}:$PATH
           setenv PATH /usr/games:/bin:/usr/bin:.

       最初の試みは csh では成功しますが、tcsh では失敗します。 この理由は、tcsh は 2  番目のコロンの後ろに、`$'
       ではなく 修飾子があると思っているからです。

       最後に、ヒストリはここで説明してきた置換だけでなく、エディタでも 利用することができます。編集コマンド up-
       history, down-history, history-search-backward, history-search-forward, i-search-back, i-search-fwd,  vi-
       search-back,  vi-search-fwd, copy-prev-word, insert-last-word は ヒストリリスト中のイベントを検索し、入力
       バッファにイベントを コピーします。編集コマンド toggle-literal-history は、  入力バッファでヒストリ行を展
       開するか文字どおりに扱うかを切り替えます。   expand-history,  expand-line  はそれぞれ、現在の単語、  また
       は、入力バッファ全体でヒストリ置換を展開します。

   エイリアス置換
       シェルは、エイリアスのリストを保持しています。このリストは、  alias,   unalias   コマンドを使って設定、削
       除、表示する ことができます。コマンド行を解釈し単純コマンド (コマンドを参照) に分割したあと、複数のコマン
       ドを左から右へ、それぞれの最初の単語が   エイリアスを持っているかをチェックします。エイリアスを持っている
       場合、最初の単語をエイリアスで置き換えます。置き換えたエイリアスが ヒストリ参照を含む場合、元のコマンドを
       直前の入力行とみなして、 ヒストリ置換 (そちらも参照) が適用されます。  エイリアスがヒストリ置換を含まない
       場合、引数リストは変更されず そのままです。

       そのため、たとえば  `ls'  のエイリアスが  `ls -l' だった場合、コマンド `ls /usr' は `ls -l /usr' になりま
       す。ここで、引数リストは 影響を受けません。`lookup' のエイリアスが `grep !^ /etc/passwd' だとすると、コマ
       ンド `lookup bill' は `grep bill /etc/passwd' に なります。エイリアスを使い、パーザのメタ記法を利用できま
       す。 たとえば、`alias print 'pr \!* | lpr'' は、引数を ラインプリンタに pr(1) する  ``コマンド''(`print')
       を 定義します。

       コマンドの最初の単語がエイリアスを持たなくなるまで、エイリアス置換は  繰り返されます。(先の例のように) エ
       イリアス置換が最初の単語を 変更しない場合、そのエイリアスに印を付けてループが生じない  ようにします。それ
       以外のループは検出され、エラー扱いになります。

       シェルが参照するエイリアスがいくつかあります。特殊エイリアス を参照してください。

   変数置換
       シェルは変数のリストを管理しており、それらは   0   個またはそれ以上の  個数の単語のリストを値として持ちま
       す。シェル変数の値は、コマンド  set,  unset  により表示、変更することができます。システムは、  自分自身の
       ``環境'' 変数のリストを保持しています。環境変数は コマンド printenv, setenv, unsetenv により表示、 変更す
       ることができます。

       (+) `set -r' (参照) により変数を読み出し専用にすることが できます。読み出し専用変数は、変更や unset  がで
       きません。これを  試みるとエラーになります。一度読み出し専用にした変数は、 書き込み可能に戻すことはできま
       せん。ですから、`set -r' は  注意して使用する必要があります。環境変数は読み出し専用に  することはできませ
       ん。

       シェルが設定、参照する変数がいくつかあります。たとえば、変数  argv は、シェルの引数リストの複製で、この変
       数の値である単語は特別な方法で     参照されます。シェルが参照する変数の中には、トグルスイッチがあります。
       シェルは、これらの変数が何の値を持っているかではなく、値が設定されて いるかどうかにだけ影響を受けます。た
       とえば、変数 verbose は、  コマンド入力をエコーするかどうかを制御するトグルスイッチです。  コマンド行オプ
       ション -v がこの変数に値を設定します。 シェルが参照する変数すべてのリストは、特別なシェル変数にあります。

       変数を数値として扱う操作もあります。コマンド  `@' により、 数値計算を実行し、結果を変数に代入することが可
       能となります。 しかしながら、変数の値は常に (0 個以上の) 文字列として表現されて  います。数値として扱うた
       めに、空文字列は 0 と見なされます。 複数の単語からなる値の、2 番目以後の単語は無視されます。

       入力行のエイリアス処理を終え、字句解析を終えた後で、そして、 各コマンドを実行する前に、`$' 文字をキーとし
       て変数置換が行われます。 この展開は `$' の前に `\' を置くことで抑止できます。ただし、`"' の  中は別で、こ
       こでは常に変数置換が行われます。また、`''   の中も   別で、ここでは決して変数置換が行われません。``'   で
       クォートした文字列は後で解釈されますから、 (後のコマンド置換を参照) そこでの `$' 置換は後になるまで行われ
       ません。`$' の後ろが空白、 タブ、改行文字の場合は、`$' 置換は発生しません。

       入出力リダイレクトは、変数展開の前に識別され、別々に変数展開されます。 それ以外では、コマンド名と引数リス
       ト全体が一緒に展開されます。ですから、 (この時点での) 最初の単語 (コマンド) から 2 つ以上の単語が生成され
       る 可能性があります。展開後の複数の単語のうち最初のものがコマンド名となり、 残りの単語は引数になります。

       `"' で囲まれているか、修飾子 `:q' が指定されている場合を除き、 最終的には、変数置換の結果に対し、コマンド
       置換とファイル名置換が 適用されます。`"' で囲まれている場合、値が複数の単語で構成される変数は、 1  つの単
       語  (の一部) に展開されます。 この単語には、その変数の値である単語が空白で区切られたものを 含みます。置換
       の際に修飾子 `:q'  が適用される場合、変数は複数の単語に  展開されます。それぞれの単語は空白で区切られ、以
       後、コマンド置換と ファイル名置換が適用されないようにクォートされます。

       シェルへの入力に変数の値を持ち込むための方法として、以下の構文が あります。特に注がない限り、設定されてい
       ない値の参照はエラーになります。

       $name
       ${name} 変数 name の値である単語に置換します。この単語は、 それぞれが空白で区切られたものです。  中括弧は
               name  とそれ以後の文字列とを分離し、以後の文字列も含めて 1 つの変数名として解釈されないようにしま
               す。シェル変数の名前は上限が 20 文字であり、先頭は英文字で、2 文字目以後は英文字か数字で 構成され
               ます。アンダスコアは英文字と見なします。name    が   シェル変数ではないが、環境に設定されている場
               合、環境の値を返します (ただし、修飾子 `:' と次で示す他の形式は利用可能です)。
       $name[selector]
       ${name[selector]}
               name の値のうち選択した単語のみで置換します。selector は `$' 置換が適用され、1 つの数値または `-'
               で区切った  2 つの数値で 構成することができます。変数の値の先頭の単語は 1 番目として数えます。 範
               囲の最初の値を省略した場合、デフォルトの値 1 になります。範囲の  最後の数値を省略した場合、デフォ
               ルトの値  `$#name になります。 selector `*' はすべての単語を選択します。2 番目の引数が 省略される
               か、あるいは範囲に収まっている場合、範囲が空になっても エラーになりません。
       $0      コマンド入力を読み込んでいるファイル名で置換します。ファイル名が 不明の場合エラーになります。
       $number
       ${number}
               `$argv[number]' と等価です。
       $*      `$argv' と等価です。これは `$argv[*]' と等価です。

       ヒストリ置換のところで説明した `:' 修飾子 (`:p' を除く) が、 上記の置換に対して適用できます。2 つ以上の修
       飾子も適用できます。  (+) ヒストリ置換 (そちらも参照) と同様に、 変数置換とリテラルのコロンとを分離するた
       めに、中括弧が必要なことが あります。修飾子は中括弧の中に置かねばなりません。

       以下の置換は `:' 修飾子で修飾することはできません。

       $?name
       ${?name}
               name が設定されているときは、文字列 `1' で置き換えられます。  設定されていないときは、文字列  `0'
               で置き換えられます。
       $?0     現在の入力ファイル名がわかっているときは、`1' で置き換えられます。 わかっていないときは、`0' で置
               き換えられます。 対話型のシェルでは、常に `0' です。
       $#name
       ${#name}
               name 中の単語の数で置き換えられます。
       $#      `$#argv' と等価です。(+)
       $%name
       ${%name}
               name の文字数で置き換えられます。(+)
       $%number
       ${%number}
               $argv[number] の文字数で置き換えられます。(+)
       $?      `$status' と等価です。(+)
       $$      (親) シェルの (10 進数の) プロセス番号で置き換えられます。
       $!      本シェルが開始したバックグラウンドプロセスのうち最新のものの (10 進数の) プロセス番号で置き換えら
               れます。(+)
       $_      最後に実行したコマンドのコマンド行で置き換えます。(+)
       $<      標準入力から読み込んだ    1   行を、一切解釈をせずにこの変数と置き換えます。   シェルスクリプト中
               で、キーボードから読み込む際に用います。(+) csh は、`$<:q' と等価であるかのように、$<  をクォート
               しますが、  tcsh はそうしません。それだけでなく、tcsh がユーザの 入力行を待つとき、ユーザは割り込
               みを入力して、置換されるべき行が 入る列を中断することができます。しかし csh ではそうすることが で
               きません。

       編集コマンド  expand-variables は、 通常は `^X-$' にバインドされていますが、 これを使って、個々の変数を対
       話的に展開することができます。

   コマンド置換、ファイル名置換、ディレクトリスタック置換
       組み込みコマンドの引数に対し、残りの置換が選択的に適用されます。 選択的とは、行の中で評価されなかった部分
       は、これらの展開の対象に  ならないという意味です。シェルの内部コマンドでないコマンドに対しては、 コマンド
       名は引数リストとは別個に置換されます。この置換は最後の方、 入出力リダイレクトを実行したあと、メインシェル
       の子供の中で生じます。

   コマンド置換
       ``' で囲まれたコマンドは、コマンド置換を示します。囲まれたコマンドの 出力を、空白、タブ、改行文字のところ
       で別々の単語に分割します。 この出力に変数置換、コマンド置換を実行し、 元の文字列があった場所に置きます。

       ニ重引用符  (`"')  の内側のコマンド置換は、空白、タブを保存します。  改行文字だけは新しく単語分けを行いま
       す。  ただし、どのような場合でも最後の改行文字だけは新しい単語になりません。 ですから、1 行まるまる出力す
       るようなコマンドでも、コマンド置換を 用いると単語の一部だけを生成することができます。

   ファイル名置換
       単語が `*', `?', `[', `{' のいずれかの文字を含む場合、または先頭が `~' で始まる場合、その単語はファイル名
       置換  (あるいはグロブ  (globbing) と 呼ばれます) の候補になります。このような単語をパターン (グロブパター
       ン) と見なし、そのパターンにマッチするファイル名の リストをアルファベット順で整列したもので置き換えます。

       ファイル名マッチの際に、ファイル名の先頭、または `/' の直後の 文字 `.' は、`/' と同様に、明示的にマッチさ
       せなければなりません。  文字 `*' は、空文字列を含むどのような文字列にもマッチします。 文字 `?' は、どのよ
       うな 1 文字にもマッチします。列 `[...]' は、 括弧の中で指定した文字のいずれかにマッチします。`[...]' 内で
       は、 文字の対を `-' でつなぐことで、(文字順序で) その 2 文字の範囲にある 文字のいずれかにマッチします。

       (+)  グロブパターンの中には反転を指定できるものがあります。 列 `[^...]' は、括弧内の文字 / 範囲で指定して
       いない文字 ちょうど 1 つにマッチします。

       `^' により、グロブパターン全体を反転させることもできます。

           > echo *
           bang crash crunch ouch
           > echo ^cr*
           bang ouch

       `?', `*', `[]' のいずれも使わないグロブパターンや、 `{}', `~' (あとで説明します) を使うグロブパターンは、
       反転しても正しい結果を得られません。

       メタ記法    `a{b,c,d}e'    は、`abe    ace    ade'    の省略記法です。左から右への   出現順序は保存されま
       す。`/usr/source/s1/{oldls,ls}.c' は、 `/usr/source/s1/oldls.c /usr/source/s1/ls.c' に展開します。 マッチ
       ングの結果は下位のレベルで個別に整列され、出現順序は保存  されます。 `../{memo,*box}' は、`../memo ../box
       ../mbox' などに 展開されるでしょう (ここで、`memo' が `*box' のマッチング結果とともに  整列されていないこ
       とに注意してください)。この指定が展開された結果  ファイルが存在しなくてもエラーになりませんが、展開結果を
       渡した先の コマンドでエラーになる可能性はあります。この指定は入れ子にすることが  できます。特殊な場合とし
       て、単語 `{', `}', `{}' は変更されずに そのまま渡されます。

       ファイル名先頭の文字  `~'  は、ホームディレクトリを指します。単独で  用いられた場合、つまり  `~' だけの場
       合、シェル変数 home の値に 反映されているように、呼び出したユーザの ホームディレクトリに展開されます。`~'
       の直後に英文字、  数字、または文字  `-'  で構成される名前が続く場合、シェルはその  名前を持つユーザを検索
       し、そのユーザのホームディレクトリに展開します。 ですから、`~ken' はたとえば `/usr/ken'  に展開されます。
       また、`~ken/chmach'は、たとえば `/usr/ken/chmach' に展開されます。 文字 `~' の後ろに英文字でもなく `/' で
       もない文字が続いた場合、 もしくは、文字 `~'  が単語の先頭以外に現れた場合、変更されずに  そのまま渡されま
       す。ですから、 `setenv MANPATH /usr/man:/usr/local/man:~/lib/man' のようなコマンド では、期待通りのホーム
       ディレクトリ置換が起こりません。

       `*', `?', `[', `~' のどれかを含むグロブパターン (`^' は付いていてもいなくとも同じ) は、マッチするファイル
       が ひとつもないとエラーになります。 しかし、グロブパターンのリストのうちのひとつでも マッチすれば (他のも
       のはマッチするものがなくても) エラーになりません (したがって、たとえば `rm *.a *.c *.o'  は、カレントディ
       レクトリに `.a', `.c', `.o' で終わるファイルがひとつもないときに限って エラーになります)。 また、シェル変
       数 nonomatch が設定されている場合、 どれにもマッチしないパターン (あるいはパターンの列) は エラーにならず
       に無変換のまま残されます。

       ファイル名置換を止めるために、シェル変数   noglob   を設定することが  できます。編集コマンド  expand-glob
       は、通常は `^X-*' に結合されて いますが、これを使い、個々のファイル名置換の展開を対話的に  行うことができ
       ます。

   ディレクトリスタック置換 (+)
       ディレクトリスタックはディレクトリの列であり、0 から番号付けられ、 組み込みコマンド pushd, popd, dirs (そ
       ちらも参照) が使用します。 dirs コマンドを使用すると、ディレクトリスタックを いつでも表示でき、ファイルに
       書き込むことができ、      ファイルから読み込むことができ、そしてクリアすることが     できます。シェル変数
       savedirs, dirsfile に 値を設定することで、ログアウト時のディレクトリスタックの書き込みと、 ログイン時の読
       み込みを自動的に行うことができます。シェル変数  dirstack を使い、ディレクトリスタックの中を調べることがで
       き、 ディレクトリスタックに任意のディレクトリを設定することができます。

       文字 `=' の後ろに 1 桁以上の数字が続くと、それは ディレクトリスタック中のエントリに展開されます。特殊な場
       合として、 `=-' はスタックの最新のディレクトリに展開します。たとえば、 次のようにです。

           > dirs -v
           0       /usr/bin
           1       /usr/spool/uucp
           2       /usr/accts/sys
           > echo =1
           /usr/spool/uucp
            echo =0/calendar
           /usr/bin/calendar
           > echo =-
           /usr/accts/sys

       シェル変数 noglob, nonomatch と編集コマンド expand-glob はファイル名置換と同様に ディレクトリスタックにも
       適用されます。

   その他の置換 (+)
       ファイル名を含む変換が他にいくつかあります。厳密には先に説明した ものと関係があるわけではありませんが、完
       全を期するために  ここで説明しておきます。変数  symlinks  (そちらも参照)  が  `expand' に設定されている場
       合、どのようなファイル名も フルパスに展開される可能性があります。クォートすることで  この展開を止めること
       ができ、編集コマンド normalize-path を 使用すると要求に応じて展開を止めることができます。また、編集コマン
       ド normalize-command は、PATH にあるコマンドを、 要求に応じてフルパスに展開します。 最後に、cdpushd
       は `-' を以前の作業ディレクトリ (シェル変数 owd と等価) と解釈します。これは置換でもなんでも なく、このコ
       マンドだけで認識される省略記法です。それでも、この表記も   クォートすることでこの解釈を止めることができま
       す。

   コマンド
       次の  3 つのセクションでは、シェルがどのようにコマンドを実行し、 それらの入出力をどのように扱うかを説明し
       ます。

   単純コマンド、パイプライン、コマンド列
       単純コマンドは、単語の列であり、 その最初の単語が実行されるコマンドです。 `|'  文字によって区切られた一連
       の単純コマンドは パイプラインを形成します。 パイプライン内のそれぞれのコマンドの出力は次のコマンドの 入力
       に接続されます。

       単純コマンドとパイプラインは `;' 文字を使って  コマンド列に組み入れることができ、並んでいる順に実行されま
       す。  コマンドとパイプラインは  `||'  や `&&' でコマンド列に 組み込むこともでき、C 言語で扱われるのと同様
       に、 最初のコマンドが失敗した時にだけ (`||'の場合)、 あるいは成功した時にだけ  (`&&'の場合)、次のコマンド
       が実行されます。

       単純コマンド、パイプライン、またはコマンド列は、  括弧 `()' を使って単純コマンドを形成することができ、 パ
       イプラインやコマンド列の一部として使用できます。 コマンド、パイプライン、またはコマンド列の後に `&' を 置
       いて実行すると、そのコマンドの終了を待たずに 次のコマンドを実行できます。

   組み込みコマンド、非組み込みコマンドの実行
       組み込みコマンドは、シェルの中で実行されます。 パイプラインの構成要素の最後以外が組み込みコマンドのとき、
       パイプラインは、サブシェル内で実行されます。

       括弧で括られたコマンドは、常にサブシェル内で実行されます。

           (cd; pwd); pwd

       これは、現在のディレクトリを移動することなくくホーム  ディレクトリを表示  (その後に現在のディレクトリを表
       示) し、 その一方、

           cd; pwd

       この場合はホームディレクトリに移動します。  括弧で括られたコマンドは、たいてい cd が現在のシェルに 影響す
       るのを防ぐために使用します。

       実行するコマンドが組み込みコマンドでないことが判明すると、 シェルはそのコマンドを execve(2)  を通じて実行
       しようとします。  環境変数  path 内の各語は、シェルがコマンドを検索する ディレクトリを指定します。 -c, -t
       オプションのいずれも指定されていない場合、 これらのディレクトリ内の名前を内部テーブルでハッシュし、  その
       コマンドが存在する可能性のあるディレクトリだけで  execve(2)  の実行を試みます。  このことは、検索パス内の
       ディレクトリの数が多い場合に、 コマンドの位置確定を大いに高速化します。 この機構が (unhash によって) オフ
       にされ、  シェルに -c または -t のオプションが与えられるか、 それぞれの path のディレクトリ構成要素のいず
       れかが `/' で始まっていない場合、シェルは現在の作業ディレクトリと  与えられたコマンド名を結合して実行する
       ファイルのパス名を形成します。

       ファイルに実行許可であってシステムが実行可能ではない場合、 (例 : 実行可能バイナリ、インタプリンタを指定し
       たスクリプト ではないとき)、それをシェルコマンドを含むファイルであるとみなし、 新しいシェルを起動してその
       ファイルを読み込みます。  シェルの特殊なエイリアスで、シェル自体ではなくインタプリタを 指定するように設定
       することもできます。

       慣習的な‘#!' スクリプトインタプリタを理解しないシステム上では、  シェルはそれをエミュレートするようにコン
       パイルされます  ;  シェル変数 version を参照してください。 その場合、シェルがファイルの最初の行をチェック
       し、それが `#!interpreter arg ...' の形式であるかどうかを 確認します。 この形式であれば、シェルは与えられ
       た引数とともに インタプリタを起動して、そのファイルを標準入力に供給します。

   入出力
       コマンドの標準入力と標準出力は以下の文法に従って リダイレクトすることができます:

       < name  ファイル  name  (変数、コマンド、ファイル名展開を受けます) をオープンし、コマンドの標準入力としま
               す。
       << word word と同一の行が出現するまで、シェルの入力を読み込みます。 word は変数、ファイル名、コマンド置換
               を受けません。  シェル入力の行は読み込まれるとすぐ、置換を行う前に  word  と比較されます。word に
               `\', `"', `'', ``' のクォートが出現しなければ、行の中でコマンド置換が実行されます。  この置換を抑
               制するために、`\'  によって `$', `\', ``' をクォートすることができます。コマンド置換において、 す
               べての空白、タブ、改行は保存されますが、最後の改行は削除されます。 読み込んだ行はすべてテンポラリ
               ファイルに保存され、 コマンドの標準入力として用いられます。
       > name
       >! name
       >& name
       >&! name
               ファイル name を標準出力として用います。 ファイルが存在しなければ作成されます。すでにファイルが存
               在すれば その内容は切り捨てられ、以前の内容は失われます。

               シェル変数 noclobber  がセットされている場合、  ファイルが存在しないか文字型特殊ファイル  (端末や
               `/dev/null'  のような) でなければ エラーになります。これは、すでに存在するファイルを間違えて 削除
               してしまうことを防止します。`!' を用いた形式を使うと、 この検査を抑制することができます。

               `&' を用いた形式では、標準出力とともに診断メッセージ 出力もファイルへリダイレクトされます。  name
               は、`<' の 入力ファイル名の場合と同様の展開を受けます。
       >> name
       >>& name
       >>! name
       >>&! name
               `>' と同様に、ファイル name を標準出力として用います。 ただし、コマンドの出力はファイルへ追加され
               ます。 変数 noclobber がセットされている場合、ファイルが 存在しなければエラーとなります。 `!'  を
               用いることで、この検査を抑制することができます。

       コマンドは、シェルが起動されたときの環境を引き継ぎます。 ただしこの環境は入出力のパラメータによって変更さ
       れますし、 コマンドがパイプラインの中にあった場合も変更されます。  したがって、以前のいくつかのシェルとは
       異なり、シェルの  コマンドファイルから起動されたコマンドは、デフォルトでは そのコマンドのテキストへアクセ
       スできません。かわりに それらのコマンドは、シェルのもともとの標準入力をそのまま 受け継ぎます。 シェルスク
       リプトの内部で、コマンドにあらかじめ決まった   (inline)  データを渡す場合には、標準入出力の形式ではなく、
       `<<' の機構を使うことができます。 このように制限することにより、シェルコマンドスクリプトを パイプラインの
       一部として用いることができます。  バックグラウンドで実行されているコマンドの標準入力も /dev/null 等にリダ
       イレクトされることなく、 シェルの標準入力をそのまま受け継いでいます。  もし標準入力が端末で、コマンドが端
       末から読み込もうとした場合、 そのプロセスはブロックされ、シェルはユーザにそのことを通知します (ジョブの項
       を参照)。

       診断メッセージ出力もパイプにリダイレクトすることが できます。単に `|' のかわりに `|&' を使います。

       シェルは、標準出力のリダイレクトなしで、診断メッセージ出力を    リダイレクトできなくなります。     そのた
       め、`(コマンド  >  出力ファイル) >& エラーファイル' は、無難な予備手段としてされてます。 出力ファイル
       ラーファイルのどちらかが、 端末に出力を送るための `/dev/tty' です。

   特徴
       ここではシェルがどのようにコマンドラインを受け入れ、 解釈し、実行するかを説明しました。  次は、便利な特徴
       について説明します。

   制御フロー
       このシェルには、  コマンドファイル (シェルスクリプト) や (制約はあるものの便利な) 端末からの入力 処理の流
       れを制御するために使用できる 多くのコマンドを備えています。 これらのコマンドは、 入力の再読み込みや読み飛
       ばしを行うため シェルを強制的に操作します。 これらの実装のために、幾つかのコマンドには制限があります。

       foreachswitchwhile  文は、 if 文の if-then-else 形式と同様に、 後で示すように入力行の単独の単純コマン
       ド中に 主要なキーワードが現れることを要求します。

       シェルの入力がシーク可能でない場合は、  ループが読み込まれると常に入力をバッファし、   この内部バッファを
       シークすることでループによる  再読み込みを可能にします。 (これを許可した結果、 後方へ向かう goto がシーク
       可能でない入力についても 成功することになります。)

   
       組み込みコマンドの if, while, exit は 共通した文法を持った式を使います。 式には、次の 3  つのセクションの
       中で説明される 任意の演算子を含めることができます。 @ 組み込みコマンド (そちらも参照) 自体は、 文法を区切
       るので注意してください。

   論理演算子, 算術演算子, 比較演算子
       これらの演算子は C の演算子と 同じ優先順位となっています。 演算子には、次のものがあります。

           ||  &&  |  ^  &  ==  !=  =~  !~  <=  >=
           <  > <<  >>  +  -  *  /  %  !  ~  (  )

       ここに挙げた演算子は右側のものほど優先順位が高くなっています。 ただし、`==' `!=' `=~' `!~' の 4  つ、`<='
       `>=' `<' `>' の 4 つ、 `<<' `>>' の 2 つ、`+' `-' の 2 つ、`*' `/' `%' の 3 つは それぞれ同一のグループに
       所属しており、同じグループに所属している 演算子の優先順位は同じレベルとなっています。  演算子  `=='  `!='
       `=~'  `!~' は引数を文字列として比較します。 他の演算子はすべて数値で比較します。 演算子 `=~' `!~' は `!='
       `==' と似ていますが、 左側のオペランドにマッチするグロブパターン (ファイル名置換を参照)  を右側に置くこと
       が異なります。  必要なものに対してだけパターンマッチを行うので、 シェルスクリプト中における switch 組み込
       みコマンドの使用の必要を減らします。

       `0' で始まる文字列は 8 進数とみなされます。 空の文字列や引数がぬけているものは `0' とみなされます。  すべ
       ての式の結果は 10 進数で表される文字列になります。 特に、式の構成要素が同一の単語中に複数個現れることはな
       いと いうことに注意してください。 例外として、パーサに文法的に特別な意味を持つ式の構成要素 (`&'  `|'  `<'
       `>' `(' `)') が隣りにくることは構いません。 ただし、これらは空白で区切られるべきです。

   コマンド終了ステータス
       式の中でコマンドを実行することができ、  式を中括弧  (`{}')  で囲むと  終了ステータスが返されます。 中括弧
       は、コマンドの単語から空白で区切ることを 忘れないでください。 コマンドの実行が成功した場合は、 真 (たとえ
       ば  `1')  を返します。 コマンドが 0 のステータスで終了した場合、 または実行に失敗した場合は、偽 (たとえば
       `0') を返します。  もっと詳しいステータスの情報が必要な場合は、  コマンドを式の外部で実行し、  シェル変数
       status を調べてください。

   ファイル問い合わせ演算子
       これらの演算子のうち幾つかは  ファイルと関連するオブジェクトについて 真/偽の判定を行います。 これらは -op
       file の形式です。 op は次のうちのどれか 1 つです。

           r   読み取りアクセス
           w   書き込みアクセス
           x   実行アクセス
           X   パス中にある実行可能ファイルやシェル組み込みコマンド。 たとえば `-X ls' と `-X ls-F' は一般に真で
               あり、 `-X /bin/ls' はそうではない (+)
           e   存在
           o   所有者
           z   サイズ 0
           s   サイズが 0 でない (+)
           f   通常ファイル
           d   ディレクトリ
           l   シンボリックリンク (+) *
           b   ブロック型特殊ファイル (+)
           c   キャラクタ型特殊ファイル (+)
           p   名前付きパイプ (fifo) (+) *
           S   ソケット型特殊ファイル (+) *
           u   set-user-ID ビットがセットされている (+)
           g   set-group-ID ビットがセットされている (+)
           k   スティッキービットがセットされている (+)
           t   file  (これは数字でなければならない) は 端末デバイスに対してオープンしている ファイル記述子である
               (+)
           R   migrate されている (convex システムのみ有効) (+)
           L   多重演算子の中でこの演算子の後にくる演算子は、 シンボリックリンクが指されているファイルではなく、
               シンボリックリンクそのものに適用される (+) *

       file   はコマンドと展開されたファイル名で、  指定された実ユーザに対する関係があるかどうか  テストします。
       file が存在していない場合、 もしくはアクセスできない場合、 `*' で示した演算子については、  指定のファイル
       タイプが現在のシステムに 存在していなければ すべての問い合わせは偽 (たとえば `0') を返します。

       s true これらの演算子は、簡潔にするために連結することができます。 `-xy file' は `-x file && -y file' と等
       価です。(+) たとえば `-fx' は 通常の実行可能ファイルに対しては真 (`1' を返す) ですが、 ディレクトリに対し
       てはそうではありません。

       s  L は多重演算子の中で使用できます。 この演算子の後にくる演算子は、 シンボリックリンクが指されているファ
       イルではなく、 シンボリックリンクそのものに適用されます。 たとえば `-lLo' は 呼び出しユーザが所有している
       リンクに対しては真です。 Lr, Lw, Lx は リンクに対しては常に真で、 リンクでないものに対しては偽です。 L は
       多重演算子の中で最後の演算子になった場合、 異なった意味を持ちます。 以下を参照してください。

       s file に渡すべき演算子と、そうでない演算子 (たとえば Xt)  を連結することは可能ですが、  実用的ではな
       く、しばしば間違いの元になります。 特に、ファイルでない演算子に L をつけると、 妙な結果になります。

       他の演算子は他の情報、つまり単なる `0' や `1' だけ ではない情報を返します。(+) これらは前に示したのと同じ
       書式になります。 op は次のうちのどれか 1 つです。

           A       エポックからの秒数で表した、最後にファイルにアクセスした時間
           A:      A と同じで、タイムスタンプの書式。 例: `Fri May 14 16:36:10 1993'
           M       最後にファイルを変更した時間
           M:      M と同じで、タイムスタンプの書式
           C       最後に inode を変更した時間
           C:      C と同じで、タイムスタンプの書式
           D       デバイス番号
           I       inode 番号
           F       device:inode の形式で表した 複合 file 識別子
           L       シンボリックリンクが指しているファイルの名前
           N       (ハード) リンクの数
           P       先頭に 0 がついていない 8 進数で表したパーミッション
           P:      P と同じで、先頭に 0 がつく
           Pmode   `-P file & mode' と等価。 たとえば、`-P22 file' は file  のグループと他者が書き込み可であれば
                   `22' を、 グループのみであれば `20' を、何もなければ `0' を返す。
           Pmode:  Pmode: と同じで、先頭に 0 がつく
           U       数値で表したユーザ ID
           U:      ユーザ名、ユーザ名が見つからなかった場合は数値で表したユーザ ID
           G       数値で表したグループ ID
           G:      グループ名、グループ名が見つからなかった場合は数値で表したグループ ID
           Z       バイト数で表したサイズ

       これらの演算子のうち  1 つだけ多重演算子の中に 現れることを許されていますが、必ず最後につける必要がありま
       す。 ただし、L は多重演算子の中の  最後とそれ以外の箇所では違った意味になるので注意してください。  なぜな
       ら、`0'  はこれらの演算子の多くにとって正当な返り値のためです。  これらが失敗した場合、`0' を返しません。
       たいていの場合、`-1' を返し、F は `:' を返します。

       このシェルが POSIX を定義してコンパイルされている (シェル変数 version を参照)  場合、ファイル問い合わせの
       結果は、  access(2) システムコールの結果に基づいたものではなく、 ファイルの許可ビットに基づいたものになり
       ます。 たとえば、 通常は書き込み可であるが 読み取り専用でマウントされたファイルシステム上にある  ファイル
       を -w で検査した場合、 POSIX シェルでは成功し、 非 POSIX シェルでは失敗することになります。

       ファイル問い合わせ演算子は filetest 組み込みコマンド (そちらも参照) と等価になり得ます。(+)

   ジョブ
       シェルはパイプラインの各々に対しジョブを  1 つずつ関連付けます。 シェルは、現在実行中のジョブの一覧表を保
       持しており、 これは、jobs  コマンドによって表示することができます。  ジョブには整数の番号が割り当てられま
       す。 ジョブが `&' を用いて非同期に起動された場合、 シェルは以下のような出力を行います:

           [1] 1234

       これは、非同期に起動したジョブがジョブ番号  1 であり、 プロセス ID が 1234 である (トップレベルの) プロセ
       スを 1 つ持っていることを示します。

       もし、あるジョブを実行中に他のことをしたくなった場合、サスペンドキー (通常  ^Z)  を押すことにより実行中の
       ジョブに  STOP シグナルを送信することができます。 通常、シェルはそのジョブが一時停止した (Suspended) こと
       を出力し、 プロンプトを表示します。 シェル変数の listjobs が設定されていると、 組み込みコマンドの jobs の
       ようにすべてのジョブがリストされます。 もしそれが `long' と設定されているとリストは `jobs -l' のような 長
       い形式になります。 ここで、一時停止したジョブの状態を操作することができます。 つまり、bg コマンドにより停
       止したプロセスを  ``バックグラウンド''  で走行させたり、他のコマンドを実行してから、 停止していたジョブを
       fg コマンドにより ``フォアグラウンド'' で再実行させることなどができます。  (編集コマンドの  run-fg-editor
       も参照してください。)  `^Z' は即座に効力を発揮し、割り込みと同様に、それまで待たされていた 出力とまだ読み
       込まれていない入力は捨てられます。 組み込みコマンドの wait はすべてのバックグラウンドのジョブが  終了する
       までシェルを待機状態にさせます。

       `^]' キーは遅延サスペンドシグナルを現在のジョブに送信します。 この場合はプログラムが read(2) によって読み
       込もうとした時点で STOP シグナルが送信されます。 これは、実行中のジョブに対していくつかの入力を先に入力し
       ておき、 先行入力を読み終えた時点でジョブを停止させたいときに便利です。 csh(1) ではこの機能は `^Y' キーに
       割り当てられていました。 tcsh では `^Y' は編集コマンドです。(+)

       バックグラウンドで実行しているジョブが端末からの入力を試みた場合、 そのジョブは停止します。通常、バックグ
       ラウンドジョブが端末に 出力することは可能ですが、これはコマンド `stty tostop' により 禁止することができま
       す。もしこの tty オプションを指定したなら、  バックグラウンドで実行しているジョブは、端末から入力を試みた
       ときと 同様に、端末に出力を試みたときに停止します。

       シェルでジョブを参照するにはいくつかの方法があります。文字  `%' は ジョブ名を表すのに用いられます。番号 1
       のジョブを参照する場合は `%1' とします。単にジョブ名を入力した場合、そのジョブは フォアグラウンドに移動さ
       れます。すなわち  `%1'  は `fg %1' と等価で、 ジョブ 1 をフォアグラウンドに移行します。同様に `%1 &' は、
       ちょうど `bg %1' と同じようにのジョブ 1 をバックグラウンドで 再開させます。ジョブはそのジョブを起動したと
       きにタイプされた文字列の  先頭部分によって参照することもできます。ただしこの先頭部分は あいまいでない必要
       があります。すなわち `%ex' は、`ex' という文字列で 始まる名前のサスペンドされたジョブが 1  つしかない場合
       に限り、  サスペンドされた  ex(1)  のジョブを再開します。  文字列  string  を含むジョブが  1 つしかない場
       合、`%?string' と 入力することでそれを指定することもできます。

       シェルは現在のジョブと直前のジョブを覚えています。 ジョブに関係する出力で、`+' 記号が付加されているのが現
       在のジョブ、 `-' 記号が付加されているのが直前のジョブです。 `%+', `%' と (ヒストリ機構の文法との類似から)
       `%%' は すべて現在のジョブ、`%-' は直前のジョブを参照するための省略形です。

       ある種のシステムではジョブ制御機構を利用するために stty(1) の オプション `new' を設定しておく必要がありま
       す。  ジョブ制御機構は  `新型の'  端末ドライバの実装の上に構築されているからで、 新型の端末ドライバにより
       ジョブを停止させるための割り込み文字を キーボードから入力できるようになるからです。  新型の端末ドライバの
       オプション設定については stty(1) と 組み込みコマンドの setty を参照してください。

   状態通知
       シェルは、プロセスが状態の変化を起こすとすぐにそれを検知します。     通常はプロンプトが表示される直前にの
       み、あるジョブが停止して それ以上処理が進まなくなったことを通知します。これはユーザの仕事を  邪魔しないよ
       うにするためです。しかしながら、シェル変数 notify を 設定することにより、シェルにバックグラウンドジョブの
       状態が 変化したことをただちに通知させることができます。また、 シェルコマンド notify  により、特定のジョブ
       の状態の変化をただちに  通知させるようにマークすることもできます。引数なしの notify は 現在のプロセスに対
       してマークをつけます。バックグラウンドジョブの 開始直後に単に `notify' と打つとそのジョブをマークします。

       停止したジョブが存在する状態でシェルを終了しようとすると  `You  have  stopped  jobs.'  という警告を受けま
       す。このとき jobs コマンドによりどのジョブが停止中であるのかを 確認することができます。警告を受けた直後に
       jobs コマンドで 確認した場合と、警告を受けた直後に再度シェルを終了させようとした 場合には、シェルは 2  度
       目の警告を行わずに停止中のジョブを 終了させてからシェルを終了します。

   自動イベント、定期イベント、時刻指定イベント (+)
       シェルの ``ライフサイクル'' において、いろいろな時間に自動的に コマンドの実行と他のアクションを行うさまざ
       まな方法が用意されています。 それらをここに要約し、詳しくは  組み込みコマンド特別なシェル変数特別なエ
       イリアスの 適切な場所で説明します。

       組み込みコマンドの  sched はコマンドをイベントの予定表に置き、 指定された時刻にシェルによって実行されるよ
       うにします。

       特別なエイリアスとして beepcmd, cwdcmd, periodic, precmd, postcmd, jobcmd があり、それぞれ シェルがベルを
       鳴らす時、作業ディレクトリが変わる時、  tperiod 分毎、各プロンプトの前、各コマンドの実行前、 各コマンドの
       実行後、ジョブの起動時またはフォアグラウンド移行時に 実行させたいコマンドを設定できます。

       シェル変数の autologout を使って、指定した分数の休止後に ログアウトまたはシェルをロックするように設定でき
       ます。

       シェル変数の mail を使って、定期的に新しいメールを チェックするように設定できます。

       シェル変数の printexitvalue を使って、0 以外のステータスで 終了したコマンドの終了ステータスを表示するよう
       に指定できます。

       シェル変数の rmstar を使って、`rm *' が入力されたときに  ユーザに間違いないかどうか確認を求めるように指定
       できます。

       シェル変数の  time  を使って、指定した秒数より多く  CPU 時間を 使ったプロセスの終了後に組み込みコマンドの
       time を実行するように 設定できます。

       シェル変数の watchwho を使って、指定したユーザが ログインまたはログアウトした時にレポートするように設
       定できます。 また組み込みコマンドの log でいつでもそれらのユーザに ついてのレポートを得られます。

   固有言語システムのサポート (+)
       シェルは  8 ビットクリーンなので (そのようにコンパイルされていれば。シェル変数の version を 参照)、それを
       必要とする文字セットをサポートします。 NLS サポートはシェルがシステムの NLS  を使うようにコンパイルされて
       いるか どうかによって異なります (再び、version を参照)。 どちらの場合でも 7 ビット ASCII がデフォルトの文
       字分類 (たとえばそれらの文字は表示可能) であり、そして順序づけです。 環境変数の LANG または LC_CTYPE を変
       更すると、 これらの点について変化の有無がチェックされます。

       システムの NLS を使う場合には、文字の適切な分類と順序づけを決定するために setlocale(3) 関数が呼び出されま
       す。この関数は典型的には 環境変数の LANGLC_CTYPE を調べます。  より詳細についてはシステムのドキュメン
       トを参照してください。 システムの NLS を使わない場合には、シェルは ISO 8859-1 文字セットが 使われていると
       仮定することでシミュレートします。 変数 LANGLC_CTYPE のいずれかが設定されていても、  それらの値を無視
       します。 シミュレートされた NLS では順序づけに影響しません。

       加えて、本物とシミュレートされた  NLS の両方で、\200-\377 の範囲、 つまり M-char でバインドされているすべ
       ての表示可能文字は、 自動的に self-insert-command に再バインドされます。 対応する escape-char  へのバイン
       ドは、もしあればそのまま残ります。  これらの文字は環境変数の NOREBIND が設定されていれば 再バインドされま
       せん。この機能はシミュレートされた NLS や すべてが ISO 8859-1 であると仮定した原始的な本物の NLS で有効で
       しょう。  そうでなければ、\240-\377 の範囲の M-char へのバインドは 事実上解除されます。この場合でも、もち
       ろん bindkey で明示的に 関連するキーに再バインドする事は可能です。

       未知の文字 (つまり表示可能でも制御文字でもないような文字) は \nnn  のような形式で表示されます。tty  が  8
       ビットモードになっていない 場合は、ASCII に変換して強調表示モードを使うことで別の 8 ビット文字が 表示され
       ます。シェルは tty の 7/8 ビットモードを変更することはなく、 ユーザによる 7/8  ビットモードの変更に従いま
       す。NLS 利用者 (または メタキーを利用したい利用者) は、たとえば ~/.login ファイルで 適切に stty(1) コマン
       ドを呼び出すことで、 明示的に tty を 8 ビットモードに設定する必要があるかもしれません。

   OS 固有機能のサポート (+)
       個々のオペレーティングシステムで提供されている機能をサポートするために、 多くの新しい組み込みコマンドが提
       供されています。すべて 組み込みコマンドセクションで詳細に説明されています。

       TCF をサポートするシステム (aix-ibm370, aix-ps2) では、 getspathsetspath でシステム実行パスを取得、設
       定し、 getxverssetxvers で試験バージョンプリフィックスを取得、 設定して、migrate でプロセスをサイト間
       で移動させます。 組み込みコマンドの jobs は各ジョブが実行されているサイトを表示します。

       Domain/OS では、inlib で共有ライブラリを現環境に追加し、 rootnode で rootnode を変更し、ver で systype を
       変更します。

       Mach では、setpath が Mach の setpath(1) と等価です。

       Masscomp/RTU と Harris CX/UX では、universe で universe を設定します。

       Harris CX/UX では、ucbatt によって指定した universe で コマンドを走らせます。

       Convex/OS では、warp で universe を表示または設定します。

       環境変数の VENDOR, OSTYPE, MACHTYPE は、 シェルが自身が実行されていると考えているシステムの、それぞれ  ベ
       ンダー、オペレーティングシステム、マシンタイプ  (マイクロプロセッサのクラスまたはマシンのモデル) を表示し
       ます。 これはいろいろなタイプのマシン間でホームディレクトリを共有する場合に  特に便利です。利用者はたとえ
       ば各自の ~/.login 中で

           set path = (~/bin.$MACHTYPE /usr/ucb /bin /usr/bin .)

       とし、各マシン用にコンパイルされた実行形式を適切なディレクトリに 置くことができます。

       シェル変数の version は、どのオプションを選択して シェルがコンパイルされたかを表示します。

       組み込みの newgrp、シェル変数の afsuserecho_style、そしてシステムに依存するシェルの入力ファイル (ファ
       イルを参照) の位置にも注意してください。

   シグナル処理
       ログインシェルは ~/.logout ファイルを読んでいる間は 割り込みを無視します。 シェルは起動時に -q の指定が無
       ければ  QUIT シグナルを無視します。 ログインシェルは TERM シグナルを捕捉しますが、非ログインシェルは TERM
       シグナルへの挙動を親から継承します。 他のシグナルについては親からシェルに継承された値を持っています。

       シェルスクリプトでは、シェルの INT と TERM シグナルの扱いを onintr  で制御できます。そして  HUP  の扱いを
       hupnohup で制御できます。

       シェルは  HUP  で終了します  (シェル変数の  logout も参照)。 デフォルトでは、シェルの子供たちもそうします
       が、シェルは終了時に HUP を子供たちに送りません。hup はシェルが終了時に 子供に HUP  を送るようにし、nohup
       は子供が HUP を無視するように 設定します。

   端末管理 (+)
       シェルは  3 つの異なる端末 (``tty'') モードの設定を使います。それらは 編集時に使う `edit'、文字リテラルを
       クォートする場合に使う `quote'、 コマンド実行時に使う `execute' です。 シェルは各モードでいくつかの設定を
       一定に保つので、 tty を混乱状態にして終了するコマンドがシェルに干渉することはありません。 シェルは tty の
       スピードとパディングの変更にも対応します。 一定に保たれる  tty  モードのリストは組み込みの  setty  で  取
       得、設定できます。エディタは CBREAK モード (または同等のモード) を 使いますが、先行入力された文字はいつで
       も受け付けられます。

       echotc, settc, telltc コマンドを使って、 コマンドラインから端末のケーパビリティを操作、デバッグすることが
       できます。

       SIGWINCH か SIGWINDOW をサポートするシステムでは、シェルは ウィンドウのリサイズに自動的に適応して、環境変
       数の LINESCOLUMNS が設定されていれば値を補正します。 環境変数の TERMCAP が li# と co#  のフィールドを
       含んでいると、 シェルは新しいウィンドウサイズを反映するようにそれらを補正します。

参照

       このマニュアルの以下のセクションでは使用可能なすべての  組み込みコマンド特別なエイリアス特別なシェル
       変数について説明します。

   組み込みコマンド
       %job    組み込みコマンド fg と同義です。

       %job &  組み込みコマンド bg と同義です。

       :       何もしません。常に成功します。

       @
       @ name = expr
       @ name[index] = expr
       @ name++|--
       @ name[index]++|--
               最初の形式は、すべてのシェル変数の値を表示します。

               2 番目の書式は、name に値 expr を設定します。 3 番目の書式は、値 exprnameindex 番目の要素
               に 定義します。 name とその index 番目の要素の両方が既に存在していなければ なりません。

               expr  は  C と同様に、`*', `+'のような演算子を含むことがあります。 もし expr が `<', `>', `&', `'
               を含むのであれば、少なくとも expr のその部分は `()'  の中に書かれる必要があります。  expr  の書式
               は、以下の Expressions で説明されるものとは 一切関係がないことに注意してください。

               4  番目、5 番目の書式は name またはその index 番目の要素を インクリメント (`++') またはデクリメン
               ト (`--') します。

               `@' と name の間の空白は必須です。name と `=' の間、また  `='  と  expr  の間の空白はオプションで
               す。expr の要素は空白によって 区切られていなければなりません。

       alias [name [wordlist]]
               引数がなければ、すべてのエイリアスを表示します。  name を与えると、そのエイリアスの内容を表示しま
               す。 namewordlist  を与えると、  wordlistname  のエイリアスとして定義します。  wordlist
               は、エイリアスされるコマンドとファイル名です。  name は `alias' または `unalias' であってはなりま
               せん。 組み込みコマンド unalias についても参照してください。

       alloc   動的に取得しているメモリのうちの使用量と空き容量を表示します。 何らかの引数を与えるとブロックサイ
               ズごとの使用中  / 空きブロックの数を 表示します。このコマンドの出力はシステムによって大きく異なり
               ます。 VAX 以外のシステムでは、異なるメモリ管理を行っているかもしれない からです。

       bg [%job ...]
               指定したジョブ (引数がなければ現在のジョブ) をバックグラウンドに 移動します。もしそれらが停止して
               いれば再開されます。job  は 以下の Jobs で説明するように番号、 文字列、`', `%', `+', `-' で構成さ
               れます。

       bindkey [-l|-d|-e|-v|-u] (+)
       bindkey [-a] [-b] [-k] [-r] [--] key (+)
       bindkey [-a] [-b] [-k] [-c|-s]
               [--] key command (+) オプション無しでは、第 1 の形式ではバインドされているすべてのキーと 編集コマ
               ンドを表示し、第 2 の形式では key にバインドされている 編集コマンドを表示し、第 3 の形式では 編集
               コマンド commandkey にバインドします。 オプションは以下のものを含みます。

               -l  すべての編集コマンドの一覧と、それぞれの簡単な解説を表示します。
               -d  デフォルトのエディタの標準キーバインドをすべてのキーに適用します。
               -e  GNU Emacs に似たキーバインドをすべてのキーに適用します。
               -v  標準の vi(1) に似たキーバインドをすべてのキーに適用します。
               -a  代替キーマップを表示またはそのキーバインドを変更します。 代替キーマップは vi コマンドモードの
                   ものです。
               -b  key  を次のように解釈します。 ^character (たとえば `^A')、C-character (たとえば `C-A') のよう
                   なものはコントロールキャラクタ、 M-character  (たとえば  `M-A')のようなものはメタキャラクタ、
                   F-string (たとえば `F-string')のようなものは ファンクションキー、X-character (たとえば `X-A')
                   のような ものは拡張プリフィックスキーです。
               -k  key は矢印キーの名前、`down', `up', `left', `right' の いずれかとして解釈されます。
               -r  key のバインドを解除します。 `bindkey -r' は keyself-insert-command にバインドする のでは
                   なく、そのキーのバインドを完全に解除してしまうことに 注意してください。
               -c  command は編集コマンドでなく、組み込みコマンドか 外部コマンドの名前として解釈されます。
               -s  command は通常の文字列として解釈され、key がタイプされた 時に端末から入力されたように扱われま
                   す。command で バインドされたキー自体も再び解釈が行われ、10 レベルまで繰り返し 解釈が行われま
                   す。
               --  オプション処理の中断を行います。したがって、次の単語が  '-' で 始まっていたとしても、key とし
                   て解釈されます。
               -u  (または何らかの無効なオプション)
                   使い方を表示します。

               key は 1 文字であっても、文字列であっても構いません。  もしコマンドが文字列にバインドされているな
               らば、文字列の最初の  文字は sequence-lead-in にバインドされ、文字列全体が コマンドにバインドされ
               ます。

               key に含まれるコントロール文字はコントロール文字そのもの (通常 `^V'  にバインドされているエディタ
               の  quoted-insert コマンドで入力できるもの) であっても、`^A' のような キャレット-文字形式であって
               も構いません。削除文字は  `^?'  (キャレット-疑問符)  のように表します。keycommand  は下に示
               す、バックスラッシュで始まる エスケープシーケンスを含むことができます (System V の echo(1) で用い
               られる形式です)。

                   \a      ベル
                   \b      バックスペース
                   \e      エスケープ
                   \f      改ページ (フォームフィード)
                   \n      改行
                   \r      キャリッジリターン
                   \t      水平タブ
                   \v      垂直タブ
                   \nnn    8 進数 nnn で表されるアスキー文字

               `\' は後に続く文字に特別な意味があればそれを無効にします。 特に `\' や `^' の場合です。

       break   実行を一番近い foreach または whileend の 組の、end  の後から再開します。現在の行の残りのコマ
               ンドは  実行されます。したがって、複数のレベルのブレークは、1 行にそれらを 並べることで可能になり
               ます。

       breaksw switch からのブレークで、endsw の後から 実行が開始されます。

       builtins (+)
               すべての組み込みコマンドの名前を表示します。

       bye (+) 組み込みコマンド logout  の別名です。  これが使えるようにコンパイルされている場合にのみ有効です。
               シェル変数 version を参照してください。

       case label:
               下で説明する switch 文で用いられるラベルです。

       cd [-p] [-l] [-n|-v] [name]
               もしディレクトリ名 name が与えられれば、シェルの 作業ディレクトリを name に変更します。与えられな
               ければ home に変更します。もし name が `-' であれば、  ひとつ前の作業ディレクトリとして解釈されま
               す (Other substitutions を参照)。name が 現在のディレクトリのサブディレクトリでなく、 `/', `./' ,
               `../' のいずれかで始まるものでもない場合、 変数  cdpath  の要素がひとつひとつチェックされ、  サブ
               ディレクトリ  name が探されます。最後に、そのどれもが 失敗した場合に name が `/' ではじまる値をも
               つシェル変数で あれば、その変数が指すディレクトリが探されます。

               -p を付けると、dirs と同じように最終的な ディレクトリスタックの内容を表示します。cd-l, -n, -v
               フラグは dirs のそれと同じ意味を持ち、 -p の動作を含んでいます (+)。

               シェル変数 implicitcd についても参照してください。

       chdir   組み込みコマンド cd の別名です。

       complete [command
               [word/pattern/list[:select]/[[suffix] /] ...]] (+) 引数なしの場合は、すべての補完の候補を表示しま
               す。 command をつけると、command の補完候補を表示します。 commandword  などをつけると、補完を
               定義します。

               command はコマンドのフルネームでも、何らかのパターンでも 構いません (ファイル名置換を参照)。 補完
               候補がひとつでないことを示すために、`-' ではじめることができます。

               word は現在の語の補完にどの単語が関係するのかを指定する もので、以下のうちどれか 1 つです。

                   c   現在の語の補完。 pattern は、コマンドライン上の現在の語にマッチするパターンで  なければな
                       りません。 pattern は現在の語の補完が完了すると無視されます。
                   C   c に似ていますが、現在の語の補完後に pattern を含みます。
                   n   次の語の補完。  pattern はコマンドライン上のひとつ前の語にマッチする パターンでなければな
                       りません。
                   N   n に似ていますが、現在の語のふたつ前の語に マッチするパターンでなければなりません。
                   p   位置に依存した補完。 pattern は数値の範囲を指定するものであり、シェル変数の  インデックス
                       と同じ文法が用いられます。 現在の語を含むものでなければなりません。

               list は以下のリストの中から可能な補完のリストを示します。

                   a       エイリアス
                   b       バインディング (編集コマンド)
                   c       コマンド (組み込みコマンドも外部コマンドも含みます)
                   C       指定されたパスではじまる外部コマンド
                   d       ディレクトリ
                   D       指定されたパスではじまるディレクトリ
                   e       環境変数
                   f       ファイル名
                   F       指定されたパスではじまるファイル名
                   g       グループ名
                   j       ジョブ
                   l       制限値
                   n       何にも補完しません
                   s       シェル変数
                   S       シグナル
                   t       プレイン (``テキスト'') ファイル
                   T       プレイン (``テキスト'') ファイルで、指定されたパスではじまるもの
                   v       すべての変数
                   u       ユーザ名
                   x       n に似ていますが、list-choices が使われている時には select を表示します。
                   X       補完
                   $var    変数 var に格納されている語
                   (...)   リスト中の語
                   `...`   コマンドの出力に含まれる語

               select  は glob パターンです (省略可能)。 これを指定すると、list にある単語のうち select にマッチ
               するものだけが対象となり、 シェル変数 fignore は無視されます。 最後の 3  つの補完形式には  select
               パターンを与えることはできません。  また  xlist-choices 編集コマンドが用いられた時には select
               を説明メッセージとして扱います。

               suffix は単一の文字で、補完が成功するとそのあとに追加されます。  空の場合は何も追加されません。省
               略されると  (この場合 4 番目のデリミタも省略できます) ディレクトリにはスラッシュ文字が、 その他の
               文字にはスペース文字が追加されます。

               ではいくつか例を示します。   コマンドによっては、ディレクトリのみを引数として取るものがあります。
               (そのようなコマンドに対して) 通常ファイルを補完することは、的外れです。

                   > complete cd 'p/1/d/'

               `cd'  に続く最初の単語のみ (`p/1') をディレクトリで補完します。 コマンド補完を絞りこむために p-形
               式の補完を用いることもできます。 `cd' に続く最初の単語のみ (`p/1') をディレクトリで補完します。

                   > co[^D]
                   complete compress
                   > complete -co* 'p/0/(compress)/'
                   > co[^D]
                   > compress

               これは `co' で始まる (すなわち `co*' にマッチする) コマンド (位置 0  にある単語  `p/0')  を補完し
               て、  `compress' (リストにある唯一の単語) を与えたものです。 先頭にある `-' は、 この補完がコマン
               ドを確定できない場合にのみ用いられることを意味します。

                   > complete find 'n/-user/u/'

               これは n-形式の補完の例です。 `find' の後で、かつ `-user' の直後にある単語を、 ユーザーのリストで
               補完します。

                   > complete cc 'c/-I/d/'

               c-形式の補完の例です。`cc' の後にあり、 かつ `-I' ではじまる単語をディレクトリで補完します。 ここ
               では小文字の c を用いているので、 `-I' はディレクトリの一部とはみなされません。

               コマンドに応じて、便利な list も異なります。

                   > complete alias 'p/1/a/'
                   > complete man 'p/*/c/'
                   > complete set 'p/1/s/'
                   > complete true 'p/1/x:Truth has no options./'

               これらでは、 `alias' に続く単語をエイリアスで、 `man' に続く単語をコマンドで、 `set' に続く単語を
               シェル変数で置き換えています。 `true' はオプションを取らないので、 補完が試みられたときに何も行わ
               ず、 補完リストの選択画面には `Truth has no options.' を表示する x を指定しています。

               man の例や、以下に示すいくつかの例では、 `p/*' の代わりに `c/*' や `n/*' を用いることもできます。

               単語の補完を変数で行うこともできます。これらの変数は補完の際に評価されます。

                   > complete ftp 'p/1/$hostnames/'
                   > set hostnames = (rtfm.mit.edu tesla.ee.cornell.edu)
                   > ftp [^D]
                   rtfm.mit.edu tesla.ee.cornell.edu
                   > ftp [^C]
                   > set hostnames = (rtfm.mit.edu tesla.ee.cornell.edu uunet.uu.net)
                   > ftp [^D]
                   rtfm.mit.edu tesla.ee.cornell.edu uunet.uu.net

               また補完の際にコマンドを実行し、そこから補完を行うこともできます。

                   > complete kill 'p/*/`ps | awk \{print\ \$1\}`/'
                   > kill -9 [^D]
                   23113 23377 23380 23406 23429 23529 23530 PID

               complete コマンド自身は、その引数をクォートしません。 したがって `{print $1}'  にある括弧、スペー
               ス、`$' は 明示的にクォートしなければなりません。

               1 つのコマンドに複数の補完を指定することもできます。

                   > complete dbx 'p/2/(core)/' 'p/*/c/'

               これは  `dbx'  の第 2 引数を `core' という単語で補完し、 他のすべての引数をコマンドで補完します。
               位置指定タイプの補完は、逐次補完より前に指定することに注意してください。 補完は左から右に評価され
               るので、 (常にマッチする) 逐次補完が先に指定されていると、 位置指定補完は決して行われなくなってし
               まいます。 これは補完定義の際によくやるミスなので注意してください。

               select パターンは、 コマンドが特定の形式を持ったファイルだけを引数にとるような場合に便利です。 以
               下に例を示します。

                   > complete cc 'p/*/f:*.[cao]/'

               これは  `cc' の引数を、`.c', `.a', `.o' で終わるファイルだけから補完します。 以下のファイル名置換
               で述べるようなやり方で グロブパターンの否定を指定すれば、 select で特定のファイルを排除することも
               できます。

                   > complete rm 'p/*/f:^*.{c,h,cc,C,tex,1,man,l,y}/'

               これは大事なソースコードを  `rm'  の補完に現れないようにします。 もちろんこの排除された名前を手で
               打ったり、 complete-word-rawlist-choices-raw などの編集コマンドを用いて補完の仕組みを変更する
               こともできます (それぞれ該当の部分を参照)。

               `C',  `D', `F', `T' 各リストは、 それぞれ `c', `d', `f', `t' と似ていますが、 select の引数の解釈
               の仕方が異なり、 補完対象のファイルを前置パス名が特定のものに限ります。  たとえば、メールプログラ
               ム  Elm  は `=' を ユーザのメールディレクトリの省略名として用います。 この場合 `elm -f =' を `elm
               -f ~/Mail/' であるかのように補完するには

                   > complete elm c@=@F:$HOME/Mail/@

               とすべきです。ここでは `/' の代わりに `@' を用い、 select  引数を見やすくしています。  またホーム
               ディレクトリの置換は単語の先頭でのみ動作するので、 `~' の代わりに `$HOME' を用いています。

               suffix  は標準では用意されていないサフィックス (スペースやディレクトリに対する `/' 以外) を単語補
               完用に追加するために用います。

                   > complete finger 'c/*@/$hostnames/' 'p/1/u/@'

               これは `finger' の引数を、まずユーザのリストから補完し、 それに `@' を追加し、さらに `@' の後を変
               数 `hostnames' のリストから 補完します。ここでも補完指定の順序に注意してください。

               最後に、示唆に富む複雑な例を示しましょう。

                   > complete find \
                   ´n/-name/f/' 'n/-newer/f/' 'n/-{,n}cpio/f/' \
                   ´n/-exec/c/' 'n/-ok/c/' 'n/-user/u/' \
                   ´n/-group/g/' 'n/-fstype/(nfs 4.2)/' \
                   ´n/-type/(b c d f l p s)/' \
                   ´c/-/(name newer cpio ncpio exec ok user \
                   group fstype type atime ctime depth inum \
                   ls mtime nogroup nouser perm print prune \
                   size xdev)/' \
                   ´p/*/d/'

               これは  `-name', `-newer', `-cpio', `ncpio' に続く単語を ファイルで補完し (最後の両者にマッチする
               パターンに注意)、 `-exec', `-ok' に続く単語をコマンドで補完し、 `user'  の後をユーザ名で、`group'
               の後をグループ名で補完し、  `-fstype' と `-type' の後をそれぞれに与えたリストのメンバーで補完しま
               す。 また find に与えるスイッチ達も与えたリストから補完し (c-型の補完を用いていることに注意)、 そ
               れ以外のものすべてをディレクトリで補完します。ふぅ。

               補完指定は、対象となる単語がチルダ置換 (`~' ではじまる) や 変数 (`$' ではじまる) の場合は無視され
               ることに留意してください。 complete は実験的な機能であり、 文法はこのシェルの将来のバージョンでは
               変更されるかもしれません。 組み込みコマンド uncomplete の説明も見てください。

       continue
               もっとも近い while または foreach ループの実行を継続します。 現在の行にある残りのコマンドは実行さ
               れます。

       default:
               switch 文のデフォルトの場合のラベルです。 これはすべての case ラベルの後に置くべきです。

       dirs [-l] [-n|-v]
       dirs -S|-L [filename] (+)
       dirs -c (+)
               最初の形式はディレクトリスタックを表示します。 スタックの上が左に来て、  スタック先頭のディレクト
               リは現在のディレクトリになります。  -l  を指定すると、出力の  `~' や `~name' は、 home や、ユーザ
               name のホームディレクトリのパス名に 明示的に展開されます。  (+)  -n  を指定すると、エントリはスク
               リーンの終端に達する前に 桁折りされます。 (+) -v を指定すると、各エントリが 1 行に 1 つずつ表示さ
               れ、 スタック内部での位置がエントリの前に表示されます。 (+) -n-v がひとつ以上指定されると  -v
               が優先されます。

               -S  を指定した  2  番目の形式では、  ディレクトリスタックを  cdpushd からなるコマンド列として
               filename に保存します。 -L を指定すると、このシェルは filename を  source  します。  このファイル
               は、以前に -S オプションや savedirs 機構で保存されたディレクトリスタックです。 いずれの場合でも、
               filename が与えられなければ dirsfile を用います。 dirsfile も指定されていなければ ~/.cshdirs を用
               います。

               ログインシェルは  `dirs -L' と同様のことを起動時に行っており、 また savedirs が設定されていれば終
               了前に `dirs -S' と同様のことを行います。 通常 ~/.tcshrc だけが ~/.cshdirs の前に source されるの
               で、 dirsfile~/.login ではなく ~/.tcshrc で設定すべきです。

               最後の形式はディレクトリスタックをクリアします。

       echo [-n] word ...
               各    word   をスペースで区切り、改行で終端させて   シェルの標準出力に書き出します。   シェル変数
               echo_style を指定すると、 BSD や System V の echo のフラグやエスケープシーケンスを エミュレートす
               る (しない) ようにできます。 詳細は echo(1) を見てください。

       echotc [-sv] arg ... (+)
               arg で与えられた端末の機能 (termcap(5) を参照) を実行します。 たとえば `echotc home' はカーソルを
               ホームポジションに移動し、 `echotc cm 3 10' はカーソルを 3 列 10 行に移動し、 `echotc ts 0;  echo
               "This is a test."; echotc fs' は "This is a test." をステータス行に表示します。

               arg  が `baud', `cols', `lines', `meta', `tabs' の いずれかであった場合は、その機能の値を表示しま
               す ("yes" または "no" は、端末がその機能を持っているかいないかを示します)。  遅い端末でシェルスク
               リプトの出力をより寡黙にしたり、 コマンドの出力をスクリーンの行数に制限したりするような場合には、
               以下のコマンドを使うと良いでしょう。

                   > set history=`echotc lines`

                   > @ history--
               termcap 文字列はワイルドカードを含むことができますが、 これは正しく echo されません。  シェル変数
               に端末機能文字列を設定するときには、  以下の例のようにダブルクォートを用いてください。 この例では
               日付をステータス行に表示しています。

                   > set tosl="`echotc ts 0`"
                   > set frsl="`echotc fs`"
                   > echo -n "$tosl";date; echo -n "$frsl"

               -s を指定すると、存在しない機能を指定したとき、 エラーをおこさずに空文字列を返します。 -v  を指定
               するとメッセージが冗長になります。

       else
       end
       endif
       endsw   以下の foreach, if, switch, while 文の説明を見てください。

       eval arg ...
               引数をシェルへの入力として扱い、  残りのコマンドを現在のシェルのコンテキストで実行します。 これは
               通常、コマンド置換や変数置換の結果として生成されたコマンド列を 実行する場合に用いられます。  これ
               はそれらの置換に先立って文法解析が行われてしまうためです。  eval  の利用例は tset(1) を見てくださ
               い。

       exec command
               指定したコマンドを現在のシェルの代わりに実行します。

       exit [expr]
               指定した expr (で解説した式) の値で (expr が指定されていなければ status 変数の値で)  シェルを終
               了します。

       fg [%job ...]
               指定したジョブ  (あるいは引数がなければ現在のジョブ) をフォアグラウンドに移動します。停止状態にあ
               るものは再開します。 job にはジョブで解説されているように、 数値、文字列、`', `%', `+', `-'  のど
               れかを指定できます。 run-fg-editor 編集コマンドも見てください。

       filetest -op file ... (+)
               (ファイル問合わせ演算子で解説されている)  ファイル問合わせ演算子 op を各 file に適用し、 結果をス
               ペース区切りのリストで返します。

       foreach name (wordlist)
       ...
       end     wordlist のメンバーを name に順々に代入し、 これと対応する end に挟まれた範囲の  コマンドシーケン
               スを実行します。  (foreachend  は  1  行に単独で現れなければなりません。)  組み込みコマンド
               continue を用いると ループを途中で継続することができ、 組み込みコマンド break を用いると ループを
               途中で終了させることができます。  このコマンドが端末から読み込まれると、  一度ループを `foreach?'
               プロンプト (あるいは prompt2) で読み込み、全体を読み終えてからループの各文を実行します。 端末から
               の入力時にループの途中でタイプミスをした場合は 修正できます。

       getspath (+)
               システムの実行パスを表示します。 (TCF のみ)

       getxvers (+)
               実験的バージョンのプレフィックスを表示します。 (TCF のみ)

       glob wordlist
               echo と似ていますが、`\' でのエスケープを認識せず、 また出力での単語区切りをヌル文字にします。 単
               語リストをファイル名に展開するために プログラムからシェルを利用したいような場合に便利です。

       goto word
               word はファイル名と `label' 形式の文字列を出力するコマンド置換です。 シェルは入力を可能なかぎりさ
               かのぼり、 `label:' 形式の行 (空白やタブが前置されていても良い) を検索し、 その行の次から実行を継
               続します。

       hashstat
               内部のハッシュテーブルが、 これまでのコマンド探索にどの程度効率的であったか (そして exec 類を使わ
               ずに済んだか) を示す統計行を表示します。 path の各成分のうち、 ハッシュ関数がヒットの可能性がある
               としたものや、 `/' で始まらないものに対して exec が試みられます。

               vfork(2) のないマシンでは、 単にハッシュバケツのサイズを表示します。

       history [-hTr] [n]
       history -S|-L|-M [filename] (+)
       history -c (+)
               最初の形式はイベントリストの履歴を表示します。 n を与えると、新しい方最大 n 個のイベントを 表示ま
               たは保存します。  -h を指定すると、行頭の数字抜きでリストを表示します。 -T を指定すると、タイムス
               タンプもコメントのかたちで表示されます。 (これを用いると、 `history -L' や `source -h' でのロード
               に適したファイルが作成できます。)  -r を指定すると、 表示の順番がデフォルトの古い順ではなく新しい
               順になります。

               2 番目の形式で -S を指定すると、履歴リストを filename に保存します。シェル変数 savehist  の最初の
               単語が  数値に設定されていると、最大でその数値までの行数が保存されます。 savehist の 2 番目の単語
               が `merge' だった場合には、  履歴リストが現存の履歴ファイルにマージされ、タイムスタンプ順にソート
               されます  (デフォルトでは現存のファイルを置き換えます)。  (+) マージは X Window System のように、
               複数のシェルを同時に用いるような場合向けのものです。 現在は、シェルが行儀良く順々に終了するような
               場合でないと、 マージは成功しません。

               -L  を指定すると、シェルは  filename を 履歴リストに追加します。filename は以前に -S オプションや
               savehist 機構で保存された履歴リストファイルです。 -M-L と似ていますが、 filename の内容は履歴
               リストにマージされ、 タイムスタンプの順にソートされます。 いずれの場合でも、filename が与えられな
               ければ histfile を用い、 histfile も設定されていなければ ~/.history を用います。 `history -L'  は
               ほとんど `source -h' と同じですが、 前者ではファイル名を省略できます。

               ログインシェルは `history -L' と同様のことを起動時に行っており、 また savehist が設定されていれば
               終了前に `history -S' と同様のことを行います。 通常 ~/.tcshrc だけが ~/.history の前に source  さ
               れるので、 histfile~/.login ではなく ~/.tcshrc で設定すべきです。

               histlit が設定されていると、 最初の形式と 2 番目の形式は履歴リストを 文字通りの (展開されない) か
               たちで表示、保存します。

               最後の形式は履歴リストをクリアします。

       hup [command] (+)
               command を指定すると、 hangup シグナルが送られたときに終了するようにして command を実行し、  シェ
               ルが終了するときにそのコマンドに hangup シグナルを送るようにします。 コマンドによっては hangup に
               対するそれぞれ独自の反応を設定することがあり、 これは hup より優先されるかもしれません。 引数を設
               定しないと  (シェルスクリプト内部のみで許されます)、  そのシェルは残りのスクリプトの途中で hangup
               シグナルを受け取ると終了するようになります。 シグナル処理と組み込みコマンド nohup  の部分も見てく
               ださい。

       if (expr) command
               expr  (で解説した式)  の評価結果が真なら、  command  が実行されます。  command に対する変数置換
               は、実行に先だって if コマンドの残りの部分と同時に行われます。 command は単純なコマンドでなければ
               ならず、 エイリアス、パイプライン、(括弧で括られた / ていない) コマンドリストは指定できません。た
               だし引数は指定できます。 expr が偽で、 command実行されない場合でも  入出力リダイレクションは行
               われてしまいます。 これはバグです。

       if (expr) then
       ...
       else if (expr2) then
       ...
       else
       ...
       endif   指定した  expr が真の場合、 最初の else までのコマンド群が実行されます。 expr が偽で expr2 が真の
               場合は、 2 番目の else までのコマンド群が実行されます。以下同じです。 else-if  のペアはいくつでも
               指定できますが、  endif はひとつしかいりません。 また else 部は省略可能です。 (elseendif の各
               単語は入力行の先頭にしか置けません。 if は入力行の先頭に単独で置くか、 else  の後に置くかしなけれ
               ばなりません。)

       inlib shared-library ... (+)
               各     shared-library    を現在の環境に追加します。    共有ライブラリを削除する方法はありません。
               (Domain/OS のみ)

       jobs [-l]
               アクティブなジョブをリストします。 -l を指定すると、 通常の情報に加えてプロセス  ID  もリストしま
               す。 TCF システムでは、各ジョブが実行されているサイトも表示します。

       kill [-s signal] %job|pid ...
       kill -l 1 番目または 2 番目の形式は signal を (何も指定されなければ TERM (terminate) シグナルを) 指定した
               ジョブやプロセスに送ります。 job にはジョブで解説されているように、 数値、文字列、`',  `%',  `+',
               `-'  のどれかを指定できます。  シグナルは数値または名前 (/usr/include/signal.h にあるものから前の
               `SIG' を取り除いたもの) のいずれかで与えます。 デフォルトの job はありません。 単に `kill' として
               も、現在のジョブへはシグナルを送りません。  TERM (terminate) または HUP (hangup) シグナルを送った
               場合は、 そのジョブやプロセスには CONT (continue) シグナルも送信されます。 3 番目の形式はシグナル
               の名前をリストします。

       limit [-h] [resource [maximum-use]]
               現在のプロセスと、  現在のプロセスが生成するプロセスが消費する資源が、 指定した resource に対して
               プロセスひとつにつき  maximum-use  を越えないようにします。  maximum-use  を指定しないと、current
               limit  が表示されます。 resource を指定しないと、すべての制限値を表示します。 -h フラグを指定する
               と、 current limit の代わりに hard limit を用います。 hard limit は current limit  の限度を与えま
               す。 hard limit はスーパーユーザーしか増やすことができませんが、 current limit は一般ユーザも可能
               な範囲内で増減できます。

               現在制御できる資源は、 cputime (プロセスひとつにつき利用できる cpu 秒)、 filesize (作成できる単一
               ファイルの最大サイズ)、  datasize  (プログラムテキストの終端を越えて  sbrk(2) で増やせる データ領
               域+スタック領域の最大サイズ)、      stacksize      (自動的に拡張されるスタック領域の最大サイズ)、
               coredumpsize (生成されるコアダンプの最大サイズ)、 memoryuse (プロセスひとつにいちどきに割り当てる
               ことのできる物理メモリの最大サイズ)、 です。

               maximum-use は浮動小数点値または整数値に、 単位をつけて指定します。  cputime  以外の制限値は、`k'
               または   `kilobytes'   (1024   バイト)  をデフォルトの単位としています。  単位として  `m'  または
               `megabytes' を用いることもできます。 cputime のデフォルトの単位は `seconds' です。 分を表す  `m',
               時間を表す `h', 分 + 秒を表す `mm:ss' の形式などを用いることもできます。

               resource も単位も、他と区別がつく範囲で後半部を省略可能です。

       log (+) シェル変数  watch を表示し、そこにリストアップされている ユーザがログインしていればログインした時
               刻に関わらず報告します。 watchlog についても参照してください。

       login   ログインシェルを終了して、/bin/login (訳注: FreeBSD では /usr/bin/login です)  のインスタンスで置
               き換えます。これはログオフする 方法のひとつであり、sh(1) との互換性を保つ意味もあります。

       logout  ログインシェルを終了します。ignoreeof がセットされている場合に 特に役立つでしょう。

       ls-F [-switch ...] [file ...] (+)
               `ls -F' と同じようにファイルのリストを表示しますが、ずっと高速です。 各種の特別なファイル形式は特
               殊文字を用いて以下のように示されます。

               /   ディレクトリ
               *   実行可能
               #   ブロック型デバイス
               %   キャラクタ型デバイス
               |   名前付きパイプ (名前付きパイプのあるシステムでのみ)
               =   ソケット (ソケットのあるシステムでのみ)
               @   シンボリックリンク (シンボリックリンクのあるシステムでのみ)
               +   隠しディレクトリ (AIX のみ) またはコンテキスト依存 (HP/UX のみ)
               :   ネットワーク特殊型 (HP/UX のみ)

               シェル変数 listlinks がセットされている場合は、  シンボリックリンクに関してより詳しく表示されます
               (もちろん、シンボリックリンクを持つシステムでだけです)。

               @   ディレクトリでないものへのシンボリックリンク
               >   ディレクトリへのシンボリックリンク
               &   どこへのリンクでもないシンボリックリンク

               listlinks はシンボリックリンクの指し示すファイルが 存在するパーティションのマウントを引き起こすた
               め、ls-F を 遅くしてしまいます。

               もしシェル変数 listfrags が `x', `a', `A' のいずれかに セットされているか、それらの組合せ (たとえ
               ば  `xA') に セットされている場合は、これが `ls -xF' や `ls -Fa'、 もしくは組み合わせて `ls -FxA'
               のように ls-F の フラグとして使われます。`ls -C' がデフォルトでないマシンでは listflags が `x' を
               含む場合には  ls  -xF'  のように、  そうでなければ  ls  -F は `ls -CF' のように振舞います。 ls -F
               は、何らかのスイッチが与えられた場合には ls(1) に引数を渡すので、`alias ls ls-F' は通常、正しく動
               作します。

               組み込みの ls-F はファイルタイプや拡張子によってファイル名を 色分けすることができます。シェル変数
               color tcsh と 環境変数 LS_COLORS を参照してください。

       migrate [-site] pid|%jobid ... (+)
       migrate -site (+)
               最初の形式では指定したプロセスまたはジョブを、指定した場所もしくは システムパスによって決定される
               デフォルトの場所に移動します。

               2 番目の形式は `migrate -site $$' と同じ意味を持ちます。 これは現在のプロセスを指定した場所に移動
               します。シェルは その tty を失わないことになっているので、シェル自身を移動することは 予期しない動
               作の原因となります。(TCF のみ)

       newgrp [-] group (+)
               `exec  newgrp' と同じ意味をもちます。newgrp(1) を 参照してください。 シェルがこれを使うことができ
               るようにコンパイルされている場合に のみ使用可能です。シェル変数 version を参照してください。

       nice [+number] [command]
               シェルのスケジューリング優先度を number に設定するか、 number が指定されていない場合は 4 に設定し
               ます。command をつけると、コマンド command を適切な優先度で実行します。 number が大きいほど、その
               プロセスが獲得する CPU 時間は短くなります。 スーパーユーザは `nice -number ...'  とすることにより
               負の値を  設定することができます。コマンドは常にサブシェルから実行され、 コマンドには単純な if 文
               の場合と同じ制限が課されます。

       nohup [command]
               command をつけると、コマンド command を ハングアップシグナルを無視して実行するようにします。 これ
               らのコマンドが  nohup をオーバーライドして ハングアップシグナルに対して自分自身で応答するようにす
               ることが あることに注意してください。引数のない場合 (シェルスクリプト中で のみ許されます)、スクリ
               プトのそれ以降の部分でシェルは  ハングアップシグナルを無視するようになります。 シグナル処理と、組
               み込みコマンド hup についても 参照してください。

       notify [%job ...]
               ユーザに非同期的に指定したジョブ (%job が省略された場合は カレントジョブ)  の状態に何らかの変化が
               あった場合に非同期的に、  通知するようにします。この場合は通常と異なり、次のプロンプトが 出力され
               るまで待ちません。 jobJobs に記述されているように番号、文字列、`', `%', `+', `-' のどれでも許
               されます。 シェル変数 notify も参照してください。

       onintr [-|label]
               割り込み時のシェルの動作を制御します。 引数がなければ、シェルのデフォルトの割り込み時の動作に設定
               されます。 この場合は、シェルスクリプトは割り込みで中断され、  コマンド実行時はコマンドの実行を中
               断してコマンド入力待ちに戻ります。  `-'  が指定された場合はすべての割り込みが無視されます。 label
               を指定すると、割り込みが発生したり子プロセスが 割り込みで中断したりした場合に `goto label' を実行
               します。

               onintr は、システムのスタートアップファイル (FILES を参照) で割り込みが禁止されている場合には無視
               されます。

       popd [-p] [-l] [-n|-v] [+n]
               引数がなければ、ディレクトリスタックからひとつ値を取り出して、 そこに移動します。`+n'  のように数
               値を与えると、 ディレクトリスタックの n' 番目のエントリを破棄します。

               また、すべての形式の  popddirs  のように ディレクトリスタックの最後のエントリを表示します。
               シェル変数 pushdsilent はこれを抑制し、 -p フラグによって pushdsilent の動作を オーバーライドする
               ことができます。 -l, -n, -v フラグは popd でも、dirs と同じ意味をもちます。

       printenv [name] (+)
               すべての環境変数の名前と値を表示するか、name を与えた場合には 環境変数 name の値を表示します。

       pushd [-p] [-l] [-n|-v] [name|+n]
               引数がなければ、ディレクトリスタックの一番上にあるふたつの           エントリを入れ換えます。もし
               pushdtohome がセットされていれば、 引数なしの pushdcd のように  `pushd  ~'  を行います。  (+)
               name  をつけると、現在の作業ディレクトリを  ディレクトリスタックに積んで name に移動します。 もし
               name が `-' であれば、ひとつ前の作業ディレクトリとして 解釈されます (ファイル名置換を参照)。  (+)
               dunique  がセットされていれば、pushd は、スタックに name を積む前にすべてのそれと同じものを指すエ
               ントリを スタックから除去します。(+) `+n' として番号をつけると、ディレクトリスタックの n 番目のエ
               ントリがトップにくるようにスタックを回転します。 dextract がセットされている場合、`pushd +n' を行
               うと n 番目のディレクトリが展開されて、 スタックのトップに移動されます。(+)

               また、すべての形式の  pushddirs  と同じように  ディレクトリスタックの最終的な内容を表示しま
               す。シェル変数  pushdsilent をセットすることでこれをやめることができ、 またさらにこれは -p フラグ
               によってオーバーライドすることが 可能です。pushd に対する -l, -n, -v フラグの意味は dirs のものと
               同様です。(+)

       rehash  path  変数の示すディレクトリの内容を保持する 内部ハッシュテーブルを再構成します。これはログインし
               ている間に 新しいコマンドが path の示すディレクトリに追加された場合に  必要です。これはあなたが自
               分の個人的なディレクトリにコマンドを 追加した場合か、システム管理者がシステムディレクトリの内容を
               変更した 場合にのみ行われるべきです。このコマンドはまた、チルダ記号を  用いたホームディレクトリ記
               述のキャッシュもフラッシュします。

       repeat count command
               指定されたコマンド  commandcount 回 繰り返し実行します。command に指定するものは 一行 if 文で
               指定する command と同様の制限を受けます。 入出力リダイレクションは count が 0 であっても、 必ず一
               回だけ処理されます。

       rootnode //nodename (+)
               ルートノードを  //nodename  に変更します。結果として  `/'  は  `//nodename'  として解釈されます。
               (Domain/OS のみ)

       sched (+)
       sched [+]hh:mm command (+)
       sched -n (+)
               最初の形式は、予定されているイベントのリストを表示します。 シェル変数 sched  は予定されているイベ
               ントのリストを 表示する形式を設定するためにセットされます。 3 番目の形式は command を予定されてい
               るイベントのリストに 追加します。たとえば、

                   > sched 11:00 echo It\'s eleven o\'clock.

               は、午前 11 時に `It's eleven o'clock.' を表示させます。 時間は 12 時間制の AM/PM  を指定する書式
               でも構いません。

                   > sched 5pm set prompt='[%h] It\'s after 5; go home: >'

               また、現在時刻からの相対的な時間でも構いません。

                   > sched +2:15 /usr/lib/uucp/uucico -r1 -sother

               相対的な指定では AM/PM を使うべきではありません。 3 番目の書式では n 番のイベントをリストから削除
               します。

                   > sched
                        1  Wed Apr  4 15:42  /usr/lib/uucp/uucico -r1 -sother
                        2  Wed Apr  4 17:00  set prompt=[%h] It's after 5; go home: >
                   > sched -2
                   > sched
                        1  Wed Apr  4 15:42  /usr/lib/uucp/uucico -r1 -sother

               予定イベントのリストにあるコマンドは、コマンドがリストに 入れられてから最初のプロンプトが出たあと
               で実行されます。  実行の正確な時間を過ぎてしまうことはありますが、 次のプロンプトでは遅れたコマン
               ドが実行されます。 シェルがユーザのコマンド入力を待っている間に実行予定時間が来た  コマンドは直ち
               に実行されます。しかし、既に実行されているコマンドの  実行に割り込むことはできませんし、 予定され
               ていたコマンドの実行についても同様です。

               この仕組みはいくつかの Unix システムに実装されている at(1) に 似ていますが同じではありません。 指
               定した時刻通りにコマンドが実行できないことがあるのは非常に大きな 短所です。しかしこの仕組みの長所
               は、sched  はシェルから  直接実行でき、シェル変数やその他の資源へのアクセスが  できるということで
               す。これは時刻によってユーザの作業環境を 変化させることを可能にします。

       set
       set name ...
       set name=word ...
       set [-r] [-f|-l] name=(wordlist) ... (+)
       set name[index]=word ...
       set -r (+)
       set -r name ... (+)
       set -r name=word ... (+)
               1 番目の形式ではすべてのシェル変数の値を表示します。 複数の単語からなる値を持つ変数は括弧で囲まれ
               た値のリストとして表示します。 2 番目の形式では name に空文字列をセットします。 3  番目の形式では
               name に単一の単語 word をセットします。 4 番目の形式では namewordlist で示した単語の リストを
               セットします。すべての場合においてコマンド置換や ファイル名置換が値に対して行われます。-r  が指定
               された場合には、 値は読み取り専用でセットされます。-f または -l が 指定された場合には、単語リスト
               の中での順番を保ちながら 重複した単語が取り除かれます。 -f は最初に出てきたものをリストに残し、-l
               は最後に出てきたものを リストに残します。 5 番目の書式では変数 name の index 番目の要素に word を
               セットします。この場合この要素は既に存在していなければなりません。  6  番目の書式は読み取り専用に
               セットされているシェル変数の  名前の一覧を表示します。 7 番目の書式は name を、値の有無に関わらず
               読み取り専用に セットします。 8 番目の書式は 3 番目の書式と同じですが、同時に name を  読み取り専
               用にセットします。

               複数の変数をセットしたり、読み取り専用にセットするために  ひとつの set コマンドへの引数を繰り返す
               ことができます。 しかし、変数への代入処理を開始する前に変数展開処理が一度に  行われることに注意し
               てください。また、`='  は namewordの両方と接しているか、空白で区切られているかの どちらかであ
               り、片方だけと接してはいけないことに注意してください。 組み込みコマンド unset  についても参照して
               ください。

       setenv [name [value]]
               引数がなければ、すべての環境変数の名前と値を表示します。  name  を与えられた場合は、環境変数 name
               の値を value に セットするか、value がなければ空文字列にセットします。

       setpath path (+)
               setpath(1) と同様です。(Mach のみ)

       setspath LOCAL|site|cpu ... (+)
               システム実行パスを設定します。(TCF のみ)

       settc cap value (+)
               シェルに端末ケーパビリティ cap (termcap(5) で定義されたもの) は 値  value  を持つことを教えます。
               妥当性のチェックは行われません。  Concept  端末のユーザは、一番右の桁で適切な折り返しを行うために
               `settc xn no' を行う必要があるかもしれません。

       setty [-d|-q|-x] [-a] [[+|-]mode] (+)
               シェルが変更してはならない tty モード (端末管理を参照) を制御します。 -d, -q, -xsetty に、 そ
               れぞれ `edit', `quote', `execute' 時の tty モードをセットします。 -d, -q, -x が指定されない場合、
               `execute' が使用されます。

               他の引数がなければ、setty はオン (`+mode') または オフ (`-mode') に固定されているモードを一覧表示
               します。 使用可能なモードはシステムごとに異なるため、表示も異なります。 -a をつけると、固定されて
               いるかどうかにかかわらず すべての tty モードを一覧表示します。 +mode,  -mode,  mode  は、それぞれ
               モード  mode をオンに固定、オフに固定、非固定にします。 たとえば、`setty +echok echoe' は `echok'
               をオンに固定し、 シェルがコマンドを実行する際に `echoe' モードを オンにしたりオフにしたりできるよ
               うにします。

       setxvers [string] (+)
               string  に試験的なバージョンプリフィックスをセットし、  string が省略された場合にはそれを削除しま
               す。(TCF のみ)

       shift [variable]
               引数がなければ、argv[1] を破棄してメンバを左にずらします。 argv がセットされていなかったり、 値が
               1  つもなかった場合にはエラーになります。 変数名 variable を指定すると、 変数 variable に対して同
               じ動作を行います。

       source [-h] name [args ...]
               name  からコマンドを読み取って実行します。  コマンドはヒストリリストには残されません。   もし引数
               args が与えられればそれは argv に 入れられます。(+) source コマンドは入れ子にすることができます。
               もし入れ子のレベルがあまりに深くなり過ぎると、     シェルはファイル記述子の不足を起こすでしょう。
               source  でのエラーはすべての入れ子になっている source の 実行を停止します。 -h を付けると、コマン
               ドを実行するかわりに `history -L' の ようにヒストリリストに入力されます。

       stop %job|pid ...
               指定したバックグラウンドで実行されているジョブまたはプロセスを  停止します。job  は番号か、文字列
               か、あるいはジョブに  示されている `', `%', `+', `-' のいずれかを指定します。 デフォルトの job は
               存在しないので、 ただ `stop' を実行するだけではカレントジョブを 停止することにはなりません。

       suspend ^Z で送られるような stop シグナルが送られたかのように、 その場でシェルを停止させます。 これは多く
               の場合 su(1) で起動したシェルを停止するのに用いられます。

       switch (string)
       case str1:
           ...
           breaksw
       ...
       default:
           ...
           breaksw
       endsw   指定された文字列  string  に対して、各  case ラベルを連続的に マッチさせます。string にはそれに先
               だってコマンド置換と ファイル名置換が行われます。case ラベルには変数置換が行われ、 ファイル名メタ
               キャラクタの `*', `?', `[...]' を用いることができます。 `default' ラベルが出てくるまでにどの case
               ラベルとも  マッチしなかった場合、default  ラベルの後から実行が開始されます。  各  case  ラベルと
               default ラベルは行の最初になければなりません。 breaksw コマンドは実行を中断して endsw の後から 再
               開させます。 breaksw を使用しない場合は C 言語と同様に case ラベルや default ラベルを通過して実行
               が続けられます。  もしマッチするラベルも default ラベルも存在しない場合は、 実行は endsw の後から
               再開されます。

       telltc (+)
               端末ケーパビリティのすべての値を一覧表示します (termcap(5) を参照)。

       time [command]
               コマンド command (エイリアスやパイプライン、コマンドリストや 括弧でくくったコマンドリストでない単
               純なものでなければなりません) を実行し、変数 time の項で説明する形式で、実行所用時間に 関する要約
               を表示します。必要ならば、コマンド終了時に時間を           表示するための追加のシェルが生成されま
               す。command  を 指定しなかった場合は、現在のシェルとその子プロセスが使用した時間に 関する要約が表
               示されます。

       umask [value]
               8 進数で指定されたファイル作成マスクを value に設定します。  一般的なマスクの値としては、グループ
               にすべての権限を与え、 その他には読み取りと実行のみを許可する 002 や、グループとその他に 読み取り
               と実行を許可する 022 があります。 value を省略すると、現在のファイル作成マスクを表示します。

       unalias pattern
               パターン pattern にマッチするすべてのエイリアスを削除します。 したがって `unalias *' とすることで
               すべてのエイリアスを 削除できます。 unalias するものがなかった場合もエラーにはなりません。

       uncomplete pattern (+)
               パターン  pattern にマッチするすべての補完対象を削除します。 したがって `uncomplete *' とすること
               ですべての補完対象を 削除します。 uncomplete するものがなかった場合もエラーにはなりません。

       unhash  実行プログラムの検索を高速化する内部ハッシュテーブルの使用を 禁止します。

       universe universe (+)
               universe を universe に設定します。(Masscomp/RTU のみ)

       unlimit [-h] [resource]
               リソース resource の制限を解除します。resource が  指定されない場合は、すべてのリソースに関する制
               限が解除されます。 -h が指定されると、対応するハードリミットが解除されます。 これはスーパーユーザ
               のみが行うことができます。

       unset pattern
               パターン  pattern  にマッチするすべての変数を、読み取り専用の  場合も含めて削除します。したがって
               `unset  *' とすることによって 読み取り専用のものも含めてすべての変数が削除されますが、 これは良い
               ことではありません。 unset するものがなかった場合もエラーにはなりません。

       unsetenv pattern
               パターン pattern にマッチするすべての環境変数を削除します。 したがって `unsetenv *'  とすることに
               よってすべての環境変数を 削除することができますが、これは良いことではありません。 unsetenv する環
               境変数がなかった場合もエラーにはなりません。

       ver [systype [command]] (+)
               引数が与えられなかった場合は SYSTYPE を表示します。 systype を指定した場合は、SYSTYPEsystype
               に設定します。systype   とコマンド  command  を指定した場合は、systypecommand  を  実行しま
               す。systype は `bsd4.3' か `sys5.3' のいずれかです。 (Domain/OS のみ)

       wait    すべてのバックグラウンドジョブの終了を待ちます。対話的にシェルが 実行されている場合、割り込みによ
               り  wait を停止することが できます。この際シェルはまだ終了していないすべてのジョブの名前と その番
               号を表示します。

       warp universe (+)
               universe を universe に設定します。(Convex/OS のみ)

       watchlog (+)
               組み込みコマンド log の別名です (そちらも参照)。 コンパイル時に使用できるように設定されている場合
               にのみ使用可能です。 シェル変数 version を参照してください。

       where command (+)
               コマンド command について、エイリアスや組み込みコマンド、 path にある実行可能ファイルを含めてシェ
               ルの知っている すべての実体を一覧表示します。

       which command (+)
               コマンド command が、path の検索などの処理のあとで、 実際に実行されるコマンドを表示します。組み込
               みのものは  which(1) とほとんど同じですが、 tcsh のエイリアスや組み込みコマンドついても正しく報告
               し、 また 10 から 100 倍高速です。 編集コマンド which-command についても参照してください。

       while (expr)
       ...
       end     指定された式 expr (で述べられている式) の評価結果が 0 でない限り、while とそれに対応する end の
               間のコマンド を繰り返し実行します。 whileend はその行に単独で書かれなければなりません。 breakcontinue は、ループを途中で中断したり再開する  場合に使用します。  入力が端末の場合は、foreach
               の場合と同じように、 ループの内容を一通り入力するまでユーザにプロンプトが出力されます。

   特別なエイリアス (+)
       これらのエイリアスは、設定されている場合それぞれ指示された時刻に 自動的に実行されます。これらのエイリアス
       は、初期状態ではすべて 未定義です。

       beepcmd シェルが端末ベルを鳴らしたいときに実行されます。

       cwdcmd  作業ディレクトリが変更されるたびに実行されます。たとえば、 ユーザが X Window System  上で作業して
               いて、  xterm(1) および twm(1) のように、 タイトルバーをサポートしている リペアレントウインドウマ
               ネージャを使用していて、

                   > alias cwdcmd  'echo -n "^[]2;${HOST}:$cwd ^G"'

               を実行すると、シェルは、動作中の xterm(1) のタイトルを ホスト名、コロン、そしてカレント作業ディレ
               クトリのフルパスに 変更します。 これをもっと面白く実行するには、次のようにします。

                   > alias cwdcmd 'echo -n "^[]2;${HOST}:$cwd^G^[]1;${HOST}^G"'

               こうすると、ホスト名および作業ディレクトリはタイトルバーに 変更されますが、アイコンマネージャのメ
               ニューにはホスト名しか 表示されなくなります。

               cwdcmd 中に cd, pushd あるいは popd を置くと、 無限ループを引き起こす可能性があることに注意してく
               ださい。 そういうことをする人は、そうしてしまった代償は受けるものだというのが 作者の見解です。

       jobcmd  各コマンドが実行される前またはコマンドが状態を変える前に実行します。 postcmd と似ていますが、組み
               込みコマンドでは表示しません。

                   > alias jobcmd  'echo -n "^[]2\;\!#^G"'

               として vi foo.c を実行すると、 コマンド文字列が xterm タイトルバーに表示されます。

       helpcommand
               run-help 編集コマンドが実行します。ヘルプが探すコマンド名は、 単一の引数として渡されます。 たとえ
               ば、

                   > alias helpcommand '\!:1 --help'

               とすると、GNU  のヘルプ呼び出し方法を使った、 コマンドそのもののヘルプ表示が実行されます。 現在の
               ところ、たくさんのコマンドを書いたテーブルを使う以外には、 いろいろな呼び出し方法 (たとえば、Unix
               の `-h' オプション)を 使い分ける簡単な方法はありません。

       periodic
               tperiod  分おきに実行されます。このエイリアスは、 たとえば新しいメールが届いたというような、 日常
               的ではあってもそれほど頻繁には起こらない変更点を チェックするのに便利な手段を提供します。  たとえ
               ば、

                   > set tperiod = 30
                   > alias periodic checknews

               とすると、30  分おきに checknews(1) プログラムが起動します。 periodic が設定されているが、tperiod
               が設定されていないか あるいは 0 に設定されている場合、periodicprecmd のように振る舞います。

       precmd  プロンプトが表示される直前に実行されます。たとえば、

                   > alias precmd date

               とすると、各コマンド用にシェルプロンプトが表示される直前に date(1) が起動します。 precmd に何を設
               定できるかには制限はありませんが、 慎重に選んでください。

       postcmd 各コマンドが実行される前に実行されます。

                   > alias postcmd  'echo -n "^[]2\;\!#^G"'

               とすると、vi foo.c を実行すると xterm のタイトルバーに このコマンド文字列が書かれます。

       shell   スクリプト中でインタプリタを指定していない実行可能スクリプト用の  インタプリタを指定します。 最初
               の単語は、使用したいインタプリタへのフルパスでなくてはなりません     (たとえば、`/bin/csh'     や
               `/usr/local/bin/tcsh')。

   特別なシェル変数
       このセクションで述べる変数は、シェルにとっては特別な意味のあるものです。

       シェルは、起動時に次の変数を設定します。addsuffix,  argv,  autologout,  command,  echo_style,  edit, gid,
       group, home, loginsh, oid, path, prompt, prompt2, prompt3, shell, shlvl, tcsh, term, tty, uid, user  そし
       て  version  です。  これらの変数は、起動後はユーザが変更しない限り変更されません。  シェルは、必要があれ
       ば、cwd, dirstack, owd および status を更新し、ログアウト時に logout を設定します。

       シェルは、シェル変数 afsuser, group, home, path, shlvl, term および user と同名の  環境変数との同期を取り
       ます。  つまり、環境変数が変更されると、シェルは対応するシェル変数を合致するように 変更するのです (シェル
       変数が読み込み専用でない場合です)。また、その逆も 行います。ここで、cwdPWD  は同じ意味を持ちますが、
       この方法では同期は行われないということに注意してください。 また、シェルは、自動的に pathPATH の違った
       形式を 相互変換するということにも注意してください。

       addsuffix (+)
               これが設定されている場合、ファイル名が補完の際に完全に一致するときに、 一致したものがディレクトリ
               の場合には末尾に `/' を付け加え、 通常のファイルの場合には末尾にスペースを加えます。 デフォルトで
               設定されています。

       afsuser (+)
               これが設定されている場合、autologout の  autolock  機能は、  ローカルのユーザ名の代わりにこの値を
               kerberos 認証用に使います。

       ampm (+)
               これが設定されている場合、時刻が 12 時間単位の AM/PM フォーマットで すべて表示されます。

       argv    シェルへの引数です。位置パラメータは  argv から取られます。 すなわち、`$1' は `$argv[1]' に置き換
               えられるといった具合です。 デフォルトで設定されていますが、通常対話型シェルでは空です。

       autocorrect (+)
               これが設定されている場合は、補完を試みる前に 自動的に spell-word 編集コマンドが実行されます。

       autoexpand (+)
               これが設定されている場合は、補完を試みる前に自動的に expand-history 編集コマンドが実行されます。

       autolist (+)
               これが設定されている場合は、あいまいな補完を行った後、 可能性のあるものをリストします。
                `ambiguous' が設定されている場合、可能性のあるものを リストするのは、補完によって何の文字も 追加
               されなかった場合に限られます。

       autologout (+)
               1  番目の単語は、時間を分単位で表しており、 この時間以上の間、何の処理もしていなければ 自動的にロ
               グアウトされます。2 番目の単語はオプションであり、 ここで指定された時間以上の間、何の処理もしてい
               なければ  自動ロックがかかります。  シェルが自動的にログアウトする際には、 シェルは `auto-logout'
               と出力し、logout 変数を `automatic'  に  設定し、そして終了します。  シェルが自動的にロックされた
               ユーザは、作業を続けたいなら  自分のパスワードを入力することが必要になります。5 回入力に 失敗する
               と、自動的にログアウトします。 ログインシェルおよびスーパユーザのシェルでは、デフォルトで `60'(60
               分後自動的にログアウトし、ロックはかけない) に 設定されています。しかし、シェルがウインドウシステ
               ムの もとで動いていると認識した場合 (すなわち、DISPLAY 環境変数が設定されている) や、 tty  が疑似
               tty(pty)  である場合、あるいは、シェルがそのようには コンパイルされていない場合 (version シェル変
               数を参照) には設定されません。 afsuser および logout シェル変数も 参照してください。

       backslash_quote (+)
               これが設定されている場合、バックスラッシュ (`\') は 常に `\', `'',  および  `"'  でクォートされま
               す。これによって、 複雑なクォートをする手間が緩和されますが、 csh(1) スクリプト中で文法エラーをひ
               き起こす 可能性が出てきます。

       catalog メッセージカタログのファイル名です。  これが設定されている場合、  デフォルトの  `tcsh'   の代りに
               `tcsh.${catalog}' を、 メッセージカタログとして tcsh は使用します。

       cdpath  カレントディレクトリ中にサブディレクトリが見つからなかった場合に、  cd が探索すべきディレクトリの
               リストです。

       color   これが設定されている場合、組み込みコマンド ls-F 用の カラー表示を有効にし、--color=autols  に
               渡します。あるいは、ただ 1 つのコマンドに 対してカラー表示を有効にするため、ls-F または ls のみに
               設定することができます。 何に対しても設定しない場合は、(ls-F ls) に対して 設定したのと等価です。

       colorcat
               これが設定されている場合は、NLS メッセージファイルに対して カラー用エスケープシーケンスを有効にし
               ます。これによって、 色のついた NLS メッセージが表示されます。

       command (+)
               これが設定されている場合、シェルに渡されたコマンドは、 -c フラグ (そちらも参照) をつけたものに な
               ります。

       complete (+)
               これが  `enhance'  に設定されている場合、補完は、  1)  大文字小文字を無視し、2)  ピリオド、ハイフ
               ン、および アンダスコア (`.', `-', `_') を単語の区切り文字と みなし、ハイフンとアンダスコアを等価
               なものとみなします。

       continue (+)
               コマンドリストに対してこれが設定されている場合、シェルは リストされているコマンドを継続実行し、新
               たにコマンドを 開始しません。

       continue_args (+)
               continue と同じですが、シェルは次のコマンドを実行します:

                   echo `pwd` $argv > ~/.<cmd>_pause; %<cmd>

       correct (+)
               `cmd'  に設定されている場合、コマンドは自動的にスペル訂正されます。 `complete' に設定されている場
               合、コマンドは自動的に補完されます。  `all'  に設定されている場合、コマンドライン全体が訂正されま
               す。

       cwd     カレントディレクトリのフルパス名です。 シェル変数 dirstack および owd も参照してください。

       dextract (+)
               これが設定されている場合、`pushd  +n' はディレクトリを先頭に 持っていくのではなく、ディレクトリス
               タックから n 番目の ディレクトリを取り出します。

       dirsfile (+)
               `dirs -S'  および  `dirs  -L'  がヒストリファイルを探すデフォルトの  場所です。設定していない場合
               は、~/.cshdirs が使われます。 通常、~/.tcshrc の方が ~/.cshdirs よりも先に ソースとして使われるた
               め、dirsfile は、~/.login ではなく ~/.tcshrc 中で設定すべきです。

       dirstack (+)
               ディレクトリスタック上の全ディレクトリの配列です。   `$dirstack[1]'    はカレントディレクトリであ
               り、`$dirstack[2]'   は  スタック上の最初のディレクトリといった具合です。  カレントディレクトリは
               `$dirstack[1]' ですが、 ディレクトリスタックの置換では `=0' であるなどということに 注意してくださ
               い。dirstack を設定することでスタックを 任意に変更することができますが、最初の要素 (カレント ディ
               レクトリ) は常に正しいものになります。 シェル変数 cwd および owd も参照してください。

       dspmbyte (+)
               `euc' に設定されている場合、EUC-kanji(Japanese)  コードで  表示および編集ができるようになります。
               `sjis'  に設定されている場合、Shift-JIS(Japanese) コードで 表示および編集ができるようになります。
               `big5' に設定されている場合、Big5(Chinese) コードで 表示および編集ができるようになります。 次のよ
               うなフォーマットに設定されている場合、  独自のマルチバイトコードフォーマットで 表示および編集がで
               きるようになります:

                   > set dspmbyte = 0000....(256 bytes)....0000

               テーブルにはちょうど 256 バイト必要です。 256 文字それぞれは、ASCII コード 0x00, 0x01,  ...  0xff
               に  (左から右に向かって) 対応しています。 各キャラクタは、 数値 0, 1, 2, 3 に設定されます。各数字
               には次のような意味があります:
                 0 ... マルチバイト文字に対しては使われません。
                 1 ... マルチバイト文字の最初の 1 バイトに対して使われます。
                 2 ... マルチバイト文字の 2 バイト目に対して使われます。
                 3 ... マルチバイト文字の 1, 2 バイト両方に対して使われます。

                 使用例:
               `001322' に設定した場合、最初の文字 (すなわち、ASCII  コードで  0x00)  と  2  番目の文字  (すなわ
               ち、ASCII コードで 0x01) は `0' に設定されます。 つまり、マルチバイト文字に対してはこれらの文字は
               使用しません。 3 番目の文字 (0x02) は `2' に設定されます。これは、マルチバイト文字の 最初の 1  バ
               イトにこの文字が使用されることを表しています。  4 番目の文字 (0x03) は `3' に設定されます。この文
               字は、 マルチバイト文字の 1 バイト目にも 2 バイト目にも使用されます。 5 番目および  6  番目の文字
               (0x04,  0x05) は `2' に設定されます。 これは、これらの文字がマルチバイト文字の 2 バイト目に使用さ
               れることを 表しています。

               GNU fileutils バージョンの ls では、-N ( --literal ) オプションが  ついていないとマルチバイト文字
               のファイル名を表示できません。 もし、fileutils バージョンを使っている場合は、dspmbyte の 2 番目の
               文字を "ls" に設定してください。そうしないと、 たとえば "ls-F -l"  でマルチバイト文字のファイル名
               が表示できません。

       dunique (+)
               これが設定されている場合、pushd は、ディレクトリ名を スタックに置く前に name である任意の要素をス
               タックから削除します。

       echo    これが設定されている場合、各コマンドは、実行される直前に 引数と一緒にエコーされます。組み込みコマ
               ンド以外のコマンドについては、   展開がすべて行われた後にエコーされます。組み込みコマンドについて
               は、 コマンドおよびファイル名の置換が行われるよりも前にエコーされます。  これは、置換がユーザの選
               択によって行われるものだからです。 このシェル変数は、コマンドラインオプション -x で設定されます。

       echo_style (+)
               echo 組み込みコマンドのスタイルです。次のように設定できます。

               bsd     第 1 引数が `-n' である場合、改行をエコーしません。
               sysv    echo 中の文字列のバックスラッシュで始まるエスケープシーケンスを 認識します。
               both    `-n'  フラグとバックスラッシュで始まるエスケープシーケンスの 両方ともを認識します。これが
                       デフォルトです。
               none    どちらも認識しません。

               デフォルトでは、ローカルシステムのデフォルトに設定されます。 BSD  ならびに  System  V  オプション
               は、適当なシステムの echo(1) マニュアルページに解説があります。

       edit (+)
               これが設定されている場合、コマンドラインエディタが使われます。 対話型シェルではデフォルトで設定さ
               れています。

       ellipsis (+)
               これが設定されている場合、`%c'/`%.' および `%C'  プロンプトシーケンス  (prompt  シェル変数を参照)
               は、`/<skipped>' の代わりに 省略記号 (`...') つきのスキップディレクトリを示すようになります。

       fignore (+)
               補完する際に無視されるファイル名のサフィックスリストです。

       filec   tcsh  では補完は常に行われますので、この変数は無視されます。 csh で設定されている場合は、ファイル
               名の補完が使われる ようになります。

       gid (+) ユーザの実グループ ID です。

       group (+)
               ユーザのグループ名です。

       histchars
               ヒストリ置換 (そちらも参照) で使われる文字を 決定する文字列です。この値の最初の文字は、デフォルト
               の  `!'  の 代わりにヒストリ置換文字として使われます。2 番目の文字は、 クイック置換の際の文字 `^'
               の代わりをします。

       histdup (+)
               ヒストリリスト中の重複エントリの扱いを制御します。 この値が `all'  に設定されている場合、単一のヒ
               ストリイベントが ヒストリリストに入力されます。`prev' に設定されている場合、 最後のヒストリイベン
               トは現在のコマンドと同じとなり、そのため、 現在のコマンドはヒストリには入力されません。`erase' に
               設定されて  いる場合、ヒストリリスト中に同じイベントが見つかったときには、 古い方のイベントは消去
               され、現在のものが挿入されます。 `prev' および `all' オプションはヒストリイベントの番号づけを  や
               り直しますので、すき間はあかないのだということに注意してください。

       histfile (+)
               `history  -S' および `history -L' が探すヒストリファイルの デフォルトの場所です。これが設定されて
               いない場合、~/.history が 使われます。別々のマシン間で同じホームディレクトリを共有していたり、 端
               末ごとにヒストリを分けて保存していたりする場合、histfile は 便利なものです。通常、~/.history ファ
               イルよりも前に読み込まれる のは ~/.tcshrc だけなので、histfile~/.login ではなく、~/.tcshrc  で
               設定してください。

       histlit (+)
               これが設定されている場合、組み込みコマンド、編集コマンド および savehist 機構はヒストリリスト中の
               コマンド行を 文字通りの (展開しない) 形式で使用します。toggle-literal-history  編集コマンドも参照
               してください。

       history 最初の単語は、記録しておくべきヒストリイベント数を表します。  オプションである  2  番目の単語 (+)
               は、ヒストリが      どういう形式で表示されるかを示しています。       これが与えられていなければ、
               `%h\t%T\t%R\n'   が使われます。   フォーマットシーケンスは、prompt   下に記述されており、  そこで
               は、`%R' の意味が変わることの注意がされています。 デフォルトでは `100' です。

       home    起動したユーザのホームディレクトリに初期化されます。 ファイル名での `~ の展開には、この変数が参照
               されています。

       ignoreeof
               これが空文字列あるいは `0' に設定されており、 入力デバイスが端末である場合には、 end-of-file コマ
               ンド (通常は、ユーザが空行に `~D' を打つことで 生成されます) を入力すると、シェルは終了してしまう
               代わりに  `Use "exit" to leave tcsh.' と表示します。 これによって、シェルがうっかり kill されてし
               まうのを防ぐことができます。 番号 n を設定している場合には、 シェルは n -  1  回連続した  end-of-
               file を無視し、 n 回目の end-of-file があればそのときに終了します。(+) これが設定されていない場合
               には、`1' が使われます。 つまり、シェルは `^D' 1 回で終了します。

       implicitcd (+)
               これが設定されている場合、シェルは、コマンドとして入力された ディレクトリ名を、あたかもそのディレ
               クトリへ移動する要求であるものと  解釈します。verbose  に設定されている場合、ディレクトリの移動が
               行われることが標準出力にエコーされるようになります。     この振る舞いは、非対話的なシェルスクリプ
               ト、あるいは  2 語以上あるコマンド行では禁止されています。 ディレクトリを移動するのは、ディレクト
               リ名のような名前を持ったコマンドを 実行するよりも優先されますが、エイリアスの置換よりは後になりま
               す。 チルダおよび変数の展開も動作します。

       inputmode (+)
               `insert' あるいは `overwrite' に設定されている場合、 各行の先頭でエディタが入力モードに入るように
               なります。

       killdup (+)
               キルリング中の重複エントリの扱いを制御します。 `all' にセットすると、一意なエントリのみがキルリン
               グに登録されます。 `prev' にセットすると、 最後にキルされた文字列が現在のキル文字列にマッチする場
               合、 現在の文字列はリングに登録されません。 `erase'  にセットすると、同じ文字列がキルリング中に見
               付かった場合、 古い文字列が削除されて現在の文字列が挿入されます。

       killring (+)
               何個のキルされた字列をメモリ中に保持するかを示します。  デフォルトで `30' にセットされます。 セッ
               トしないか、`2' より小さい値を設定すると、 最近キルした文字列のみをシェルは保持します。

       listflags (+)
               `x', `a', `A' あるいはこれらの組合せ (たとえば、`xA')  に設定されている場合、  これらの値は、ls-F
               へのフラグとして使われ、`ls -xF', `ls -Fa', `ls -FA' あるいはこれらの組合せ (たとえば、`ls -FxA')
               のように振る舞うようになります。 `a' はすべてのファイルを表示します (たとえ、`.' で始まるファイル
               で  あっても)。`A' は `.' および `..' 以外のファイルすべてを表示し、 `x' は上から下に向かってでは
               なく、左から右に向かってソートします。  listflags  に  2  番目の単語が設定されていれば、   それは
               `ls(1)' へのパスとして使われます。

       listjobs (+)
               これが設定されていれば、ジョブが一時停止したときにすべての  ジョブがリストされます。`long' に設定
               されていれば、 リストは長い形式のものになります。

       listlinks (+)
               これが設定されていれば、組み込みコマンド ls-F は 各シンボリックリンクが指しているファイルの種類を
               表示します。

       listmax (+)
               list-choices 編集コマンドがユーザに最初に尋ねてこないで リストする最大要素数です。

       listmaxrows (+)
               list-choices 編集コマンドがユーザに最初に尋ねてこないで リストする要素の最大行数です。

       loginsh (+)
               シェルがログインシェルである場合に設定されます。 シェル中でこの変数を設定したり設定を解除したりし
               ても 何の効力もありません。shlvl も参照してください。

       logout (+)
               通常のログアウトの前には、シェルによって `normal' が、 自動ログアウトの前には `automatic'  が、そ
               して、    シェルがハングアップシグナルによって終了させられた場合    (シグナルの扱いを参照)   には
               `hangup' が設定されます。 autologout シェル変数も参照してください。

       mail    届けられるメールをチェックするためのファイルあるいは ディレクトリ名です。これは、スペースで区切ら
               れ、  オプションで数字を前につけます。 プロンプトを出す前に、最後にメールチェックをしてから 10 分
               経っていた場合、シェルは各ファイルをチェックし、 もしファイルサイズが 0  より大きいか、あるいはア
               クセス時刻よりも  変更時刻の方が大きかった場合には `You have new mail.'  (あるいは、mail に複数の
               ファイルが含まれていた場合、 `You have new mail in name.') と表示します。

               ログインシェルにいる場合には、シェルの起動時刻後にファイルが 変更されない限り、どのメールファイル
               も報告されません。 これは、余計に通知しないようにするためです。 大部分の login プログラムでは、ロ
               グイン時にメールが届いているかどうかを 教えてくれるものです。

               mail で指定されたファイルがディレクトリである場合、  シェルは、ディレクトリ中の各ファイルを別々の
               メッセージとして計算し、 `You have n mails.' とか `You have n mails in name.'  とかと適切に報告し
               ます。この機能は、主に Andrew Mail System のように、 メールをこの方式で保存するシステム用に提供さ
               れたものです。

               mail    の最初の単語が数値である場合、それはメールチェックの   間隔を変えるものとして受け取られま
               す。秒単位です。

               とても稀な状況下ですが、シェルが `You have new mail.' ではなく `You have mail.'  と報告することが
               あります。

       matchbeep (+)
               これが `never' に設定されている場合、補完が行われてもビープ音は 鳴りません。 `nomatch' に設定され
               ている場合、マッチするものがないときにのみ  ビープ音が鳴ります。  `ambiguous'  に設定されている場
               合、マッチするものが複数あるときに  ビープ音が鳴ります。 `notunique' に設定されている場合、完全に
               マッチするものが 1 つあり、 また、それとは別にもっと長くマッチするものがあったときにビープ音が 鳴
               ります。 これが設定されていない場合、`ambiguous' が使われます。

       nobeep (+)
               これが設定されている場合、ビープ音は完全に無効になります。 visiblebell も参照してください。

       noclobber
               これが設定されている場合、出力リダイレクションに制限がおかれるようになり、 入出力セクションで述べ
               ているように、 ファイルをうっかり壊さないように、また、`>>' リダイレクションが存在する ファイルを
               指すように保証できます。

       noding  prompt の時刻指定子において、時間の変わり目に `DING!' と 表示するのを無効にします。

       noglob  これが設定されている場合、ファイル名置換および、  ディレクトリスタック置換 (そちらも参照) が 禁止
               されます。この機能は、ファイル名を扱わないシェルスクリプトや、 ファイル名のリストを取得した後、さ
               らに展開をされたくない スクリプトには最も有効なものです。

       nokanji (+)
               これが設定されており、シェルが漢字をサポートしている場合  (シェル変数  version  を参照)、漢字のサ
               ポートを無効にし、 メタキーが使えるようにします。

       nonomatch
               これが設定されている場合、ファイル名置換および ディレクトリスタック置換  (そちらも参照)  の際に、
               存在するファイルにマッチしなかったときに、エラーを出さずに そのまま放置するようになります。置換が
               機能しないときには 相変わらずエラーになります。 たとえば、`echo [' は相変わらずエラーとなります。

       nostat (+)
               補完処理が行われている間に stat(2) をかけるべきではない ディレクトリのリスト  (あるいは、ディレク
               トリにマッチする  グロブパターンです。ファイル名置換を参照) です。 この機能は、stat(2) を実行する
               ととてつもない時間が かかってしまうようなディレクトリ、 たとえば /afs  などを除外するのに通常使わ
               れます。

       notify  これが設定されている場合、シェルはジョブが完了したことを非同期に 通知します。デフォルトは、プロン
               プトが表示される直前に ジョブの完了を提示します。

       oid (+) ユーザの実組織 ID です (Domain/OS のみです)。

       owd (+) 前の作業ディレクトリで、cd が使う `-' および pushd と等価です。 cwd および dirstack  シェル変数も
               参照してください。

       path    実行可能なコマンドを探すディレクトリのリストです。   null  文字はカレントディレクトリを示します。
               path 変数がない場合、フルパス名での指定のみ実行されます。 path は、起動時にシェルが環境変数  PATH
               から設定するか、   あるいは  PATH  が存在しなかった場合には、システム依存の  デフォルト、たとえば
               `(/usr/local/bin /usr/bsd /bin /usr/bin .)' のようなものに 設定します。 シェルは、`.' を path  の
               先頭あるいは末尾に置くことができ、  また、コンパイルの仕方に依存しますが、 `.' を完全に省いてしま
               うことも できます。-c, -t オプションのどちらも与えられていない シェルは、~/.tcshrc を読み込んだ後
               および  path が リセットされるたびにディレクトリの中身をハッシュに格納します。 シェルがアクティブ
               である間に、ユーザが path 中の ディレクトリに新しいコマンドを追加した場合、  シェルがそのコマンド
               を見つけられるように rehash を実行する必要があるかもしれません。

       printexitvalue (+)
               これが設定されており、対話型のプログラムが   0  以外のステータスで  終了した場合、シェルは  `Exit
               status' と表示します。

       prompt  端末からコマンドを読み込む前に表示される文字列です。 prompt には、次のフォーマット列 (+) のどれを
               含んでも構いません。 このフォーマット列は、与えられた情報で書き換えられます。

               %/  カレント作業ディレクトリです。
               %~  カレント作業ディレクトリですが、`~'  で表現される ユーザのホームディレクトリおよび `~user' で
                   表現される 他のユーザのホームディレクトリを ファイル名置換します。  `~user'  の置換は、現在の
                   セッションにおいて、 シェルがパス名に `~user' を使っている場合にのみ起こります。
               %c[[0]n], %.[[0]n]
                   現在の作業ディレクトリの、末尾の要素です。  数字  n が指定されている場合、末尾の n 個の要素で
                   す。 n が `0'  で開始する場合、スキップされた要素数が  末尾要素の前に付き、次の書式となります
                   `/<スキップされた数>末尾要素'。 シェル変数 ellipsis が設定されている場合、 スキップされた要素
                   は省略記号で置換されますので、 全体的には `...末尾要素' となります。 `~' 置換は、前述の  `%~'
                   と同様に行われますが、 `~' 要素は、末尾要素数を数える対象からは除外されます。
               %C  %c に似ていますが、`~' の置換を行いません。
               %h, %!, !
                   現在のヒストリイベント番号です。
               %M  完全なホスト名です。
               %m  最初の `.' までのホスト名です。
               %S (%s)
                   強調表示モードを開始 (終了) します。
               %B (%b)
                   ボールド体表示モードを開始 (終了) します。
               %U (%u)
                   アンダラインモードを開始 (終了) します。
               %t, %@
                   AM/PM の 12 時間表記での時刻です。
               %T  `%t' に似ていますが、こちらは 24 時間表記です (ただし、シェル変数 ampm も参照)。
               %p  秒まで含めた、AM/PM の 12 時間表記での `正確な' 時刻です。
               %P  `%p' に似ていますが、こちらは 24 時間表記です (ただし、シェル変数 ampm も参照)。
               \c  cbindkey 中にあるものとしてパースされます。
               ^c  cbindkey 中にあるものとしてパースされます。
               %%  `%' 1 つです。
               %n  ユーザ名です。
               %d  `Day' 形式の曜日。
               %D  `dd' 形式の日にち。
               %w  `Mon' 形式の月。
               %W  `mm' 形式の月。
               %y  `yy' 形式の年。
               %Y  `yyyy' 形式の年。
               %l  シェルの tty。
               %L  プロンプトの終わりから、 ディスプレイの終わりまたは行末までクリアします。
               %$  `$' の直後のシェル変数または環境変数を展開します。
               %#  普通のユーザは `>' (または promptchars シェル変数の最初の文字)、 スーパーユーザは `#' (または
                   promptchars の 2 番目の文字)。
               %{string%}
                   string を文字通りのエスケープシーケンスとして取り込みます。  これは端末属性を変更するためにの
                   み使うべきで、  カーソル位置の移動をこれで行ってはいけません。 これは prompt の最後のシーケン
                   スであってはいけません。
               %?  プロンプトの直前で実行されたコマンドの戻り値。
               %R  prompt2 の中ではパーザの状態。 prompt3  の中では修正された文字列。  history  の中では履歴文字
                   列。

               `%B',  `%S', `%U', `%{string%}' は、 8bit クリーンなシェルでのみ利用できます。 version シェル変数
               を参照してください。

               ボールド、スタンドアウト、下線といったシーケンスは、 スーパーユーザのシェルを区別するために使われ
               ることが多いです。 たとえば、

                   > set prompt = "%m [%h] %B[%@]%b [%/] you rang? "
                   tut [37] [2:54pm] [/usr/accts/sys] you rang? _

               `%t', `%@', `%T', `%p', `%P' のどれかが使われていて、 かつ noding が設定されていなければ、 毎正時
               (`:00' 分) には実際の時刻の代わりに `DING!' を表示します。

               対話的シェルでのデフォルトは `%# ' です。

       prompt2 (+)
               while ループや foreach ループの中で、 また `\' で終った行の次の行で、  プロンプトとして用いられる
               文字列。  prompt (そちらも参照) と同じ フォーマットシーケンスが使えます。 `%R' の意味が変わること
               に注意してください。 対話的シェルでのデフォルトは `%R?' です。

       prompt3 (+)
               自動スペル訂正の確定時のプロンプト文字列。 prompt (そちらも参照) と同じ  フォーマットシーケンスが
               使えます。  `%R'  の意味が変わることに注意してください。 対話的シェルでのデフォルトは `CORRECT>%R
               (y|n|e|a)?' です。

       promptchars (+)
               (2 文字の文字列に) 設定すると、prompt シェル変数中の `%#'  フォーマットシーケンスが、普通のユーザ
               では最初の文字で、 スーパーユーザでは 2 番目の文字で置き換えられます。

       pushdtohome (+)
               設定すると、引数をとらない pushd は、 cd のように `pushd ~' を実行します。

       pushdsilent (+)
               設定すると、pushdpopd の際に ディレクトリスタックが表示されなくなります。

       recexact (+)
               設定すると、補完の際に正確なマッチがあれば、 より長いマッチが可能な場合でも、正確なほうに補完しま
               す。

       recognize_only_executables (+)
               設定すると、コマンドリストは パス中にある実行可能なファイルのみを表示します。遅いです。

       rmstar (+)
               設定すると、ユーザは `rm *' を実行する前に確認を受けます。

       rprompt (+)
               (コマンド入力後) prompt が左に表示される際に、 スクリーンの右側 (コマンド入力の後ろ側) に表示され
               る文字列。 prompt と同じフォーマット文字列が使えます。 この文字列は、コマンド入力を邪魔しないよう
               に自動的に隠れたり、 また再度現れたりします。 (左側の) プロンプト、コマンド入力、この文字列が  最
               初の  1 行に収まる場合に限り、この文字列は表示されます。 edit が設定されていなければ、 rprompt は
               プロンプトの後、コマンド入力の前に表示されます。

       savedirs (+)
               設定すると、シェルは終了する前に `dirs -S' を行います。 最初の単語を数字に設定すると、 その個数ま
               でディレクトリスタックのエントリを保存します。

       savehist
               設定すると、シェルは終了する前に `history -S' を行います。 最初の単語を数字に設定すると、その個数
               までの行が保存されます。 (個数は history 以下でなければなりません。) 2 番目の単語を `merge'  にす
               ると、   履歴ファイルが存在する場合に、置換ではなく追加を行います。  そしてタイムスタンプによって
               ソートを行い、 最近のイベントを残します。(+)

       sched (+)
               sched 組み込みコマンドがスケジュールイベントを表示する書式。 特に指定しなければ `%h\t%T\t%R\n' が
               使われます。 フォーマットシーケンスは上記の prompt 以下に書いてあります。 `%R' の意味が変わること
               に注意してください。

       shell   シェルのファイル。これはシェルをフォークして、 実行ビットが設定されているがシステムによる実行が不
               可能なファイルを  実行するために用いられます (組み込みコマンド、非組み込みコマンドの実行を参照)。
               初期値は、(システム依存の) シェルの置き場所です。

       shlvl (+)
               入れ子になったシェルの数。ログインシェルでは 1 にリセットされます。 loginsh も参照してください。

       status  最後のコマンドによって返された状態。 コマンドが異常終了した場合には 0200 が加えられます。  組み込
               みコマンドは、失敗すると終了状態  `1' を返します。 その他の場合は、すべての組み込みコマンドは状態
               `0' を返します。

       symlinks (+)
               いくつか異なった値に設定でき、 シンボリックリンク (`symlink') の解決を制御できます。

               `chase' に設定すると、 カレントディレクトリがシンボリックリンクを含むディレクトリになったら、  リ
               ンクをそれが指しているディレクトリの実名に展開します。 この機能はユーザのホームディレクトリでは働
               きません。これはバグです。

               `ignore' にすると、 このシェルはリンクを通ってカレントディレクトリを移動する場合、 移動先のディレ
               クトリを現在のディレクトリに対する  相対位置として構築しようとします。 これはすなわち、シンボリッ
               クリンクを通して cd を行い、 続いて `cd ..' を行うと、 元のディレクトリに戻る、ということを意味し
               ます。 これは組み込みコマンドとファイル名補完にのみ影響します。

               `expand'  に設定すると、シェルはパス名のように見える引き数を 実際に展開して、シンボリックリンクを
               元に戻そうとします。  これは組み込みコマンドのみならず、すべてのコマンドに影響します。   残念なが
               ら、これは認識しにくいファイル名  (たとえばコマンドオプションに埋めこまれたものなど) には動作しま
               せん。 クォートすれば展開は行われません。 たいていの場合はこの設定が便利ですが、 展開すべき引き数
               を認識できないと、誤解や混乱の元になるかもしれません。  妥協案として、 `ignore' にしておいて、 必
               要な場合には編集コマンド normalize-path (デフォルトでは ^X-n にバインドされています) を使うのがい
               いかもしれません。

               順にいくつか例を示します。 まずは遊び場となるディレクトリを準備しましょう。

                   > cd /tmp
                   > mkdir from from/src to
                   > ln -s from/src to/dst

               symlinks が設定されていない場合の動作:

                   > cd /tmp/to/dst; echo $cwd
                   /tmp/to/dst
                   > cd ..; echo $cwd
                   /tmp/from

               symlinks が `chase' に設定されている場合の動作:

                   > cd /tmp/to/dst; echo $cwd
                   /tmp/from/src
                   > cd ..; echo $cwd
                   /tmp/from

               symlinks が `ignore' に設定されている場合の動作:

                   > cd /tmp/to/dst; echo $cwd
                   /tmp/to/dst
                   > cd ..; echo $cwd
                   /tmp/to

               symlinks が `expand' に設定されている場合の動作:

                   > cd /tmp/to/dst; echo $cwd
                   /tmp/to/dst
                   > cd ..; echo $cwd
                   /tmp/to
                   > cd /tmp/to/dst; echo $cwd
                   /tmp/to/dst
                   > cd ".."; echo $cwd
                   /tmp/from
                   > /bin/echo ..
                   /tmp/to
                   > /bin/echo ".."
                   ..

               いくつか注意しますと、`expand'  による展開は、  1) cd のような組み込みコマンドに対しては `ignore'
               のように働きます。 2) クォートすれば行われません。 3)  非組み込みコマンドの場合は、ファイル名を渡
               す前に行われます。

       tcsh (+)
               `R.VV.PP' 形式のシェルのバージョン番号です。 `R' はメジャーリリース番号、 `VV' はカレントバージョ
               ン、 `PP' はパッチレベルです。

       term    端末の種類。 スタートアップとシャットダウン で述べているように、通常は ~/.login で設定されます。

       time    数値を設定すると、それ以上の CPU 時間 (秒) を消費したコマンドの実行後に、  自動的に組み込みコマン
               ド time (そちらも参照) を実行します。2 番目の単語があれば、 time 組み込みコマンドの出力フォーマッ
               ト文字列として 使われます。 (u) 以下のシーケンスがフォーマット文字列で使えます。

               %U  プロセスがユーザモードで消費した CPU 時間 (秒)。
               %S  プロセスがカーネルモードで消費した CPU 時間 (秒)。
               %E  (壁時計での) 経過時間 (秒)。
               %P  (%U + %S) / %E として計算される CPU 使用率。
               %W  プロセスがスワップされた回数。
               %X  (共有) テキスト空間の平均使用量。 Kbyte 単位。
               %D  (非共有) データ/スタック空間の平均使用量。 Kbyte 単位。
               %K  (%X + %D) の総使用量。 Kbyte 単位。
               %M  プロセスが使用したメモリの瞬間最大値。 Kbyte 単位。
               %F  メジャーページフォールトの回数 (ディスクから取って来る必要があったページ数)。
               %R  マイナーページフォールトの回数。
               %I  入力操作の回数。
               %O  出力操作の回数。
               %r  ソケットメッセージを受け取った回数。
               %s  ソケットメッセージを送った回数。
               %k  シグナルを受け取った回数。
               %w  自発的なコンテキストスイッチの回数 (wait の回数)。
               %c  非自発的なコンテキストスイッチの回数。

               BSD 資源制限機能の無いシステムでは、 最初の 4 つのシーケンスだけがサポートされています。 デフォル
               トの時間フォーマットは、 資源使用報告をサポートしているシステムでは `%Uu %Ss %E %P %X+%Dk %I+%Oio
               %Fpf+%Ww' で、 そうでないシステムでは `%Uu %Ss %E %P' です。

               Sequent の DYNIX/ptx では、 %X, %D, %K, %r, %s が使えませんが、  以下の追加シーケンスが利用できま
               す。

               %Y  システムコールが実行された回数。
               %Z  要求に応じてゼロで埋められたページ数。
               %i  プロセスの常駐サイズがカーネルによって増加させられた回数。
               %d  プロセスの常駐サイズがカーネルによって減少させられた回数。
               %l  read システムコールが実行された回数。
               %m  write システムコールが実行された回数。
               %p  raw ディスク装置から読み込んだ回数。
               %q  raw ディスク装置へ書き込んだ回数。

               デフォルトの時間フォーマットは  `%Uu  %Ss $E %P %I+%Oio %Fpf+%Ww' です。 マルチプロセッサでは CPU
               使用率が 100% より高くなることがあります。

       tperiod (+)
               特別なエイリアス periodic の実行される周期 (分単位)。

       tty (+) tty の名前。端末にアタッチされていない場合は空。

       uid (+) ユーザの実ユーザ ID。

       user    ユーザのログイン名。

       verbose 設定すると、ヒストリ置換後に、 各コマンドの単語を (あれば) 表示します。  コマンドラインオプション
               -v によって設定されます。

       version (+)
               バージョン ID スタンプ。 シェルのバージョン番号 (tcsh を参照) 、 配布元、リリース日、ベンダー、オ
               ペレーティングシステム、 マシン (VENDOR, OSTYPE, MACHTYPE を参照)、  コンパイル時に設定されたオプ
               ションをカンマで区切ったリストからなります。  ディストリビューションのデフォルトとして セットされ
               たオプションが記録されています。

               8b  シェルは 8bit クリーン。デフォルト。
               7b  シェルは 8bit クリーンでない。
               nls システムの NLS を使う。 NLS のあるシステムではデフォルト。
               lf  ログインシェルは  /etc/csh.cshrc  の後ではなく先に  /etc/csh.login  を実行し、  ~/.tcshrc~/.history の後ではなく先に ~/.login を実行する。
               dl  セキュリティ上の理由から `.' を path の最後に置く。デフォルト。
               nd  セキュリティ上の理由から `.' を path に含めない。
               vi  emacs-形式ではなく vi-形式の編集をデフォルトにする。
               dtr ログインシェルは終了時に DTR を落とす。
               bye byelogout の同義語とし、 logwatchlog の別名として扱う。
               al  autologout を有効にする。デフォルト。
               kan nokanji シェル変数が設定されない限り、 ロケール設定が適切であれば、漢字を使う。
               sm  システムの malloc(3) を使う。
               hb  シェルスクリプトの実行時に `#!<program> <args>' 方式をエミュレートする。
               ng  newgrp 組み込みコマンドが利用可能。
               rh  シェルは REMOTEHOST 環境変数を設定しようとする。
               afs シェルはもしローカルな認証が失敗したら、 kerberos サーバにパスワードを確認する。 afsuser シェ
                   ル変数か AFSUSER 環境変数が 設定されていたら、その内容でローカルユーザ名を上書きする。

               システム管理者は、文字列を追加して ローカルバージョンでの違いを示すようにできます。

       visiblebell (+)
               設定すると、音声ベルの代わりに画面をフラッシュします。 nobeep も参照してください。

       watch (+)
               ログイン / ログアウトの監視対象とする、「ユーザ / 端末」ペアのリスト。 ユーザに対する端末が `any'
               なら、指定したユーザをすべての端末で監視します。  逆にユーザが `any' なら、指定した端末ですべての
               ユーザを監視します。 watch を `(any any)' に設定すると、 すべてのユーザと端末を監視します。  たと
               えば、

                   set watch = (george ttyd1 any console $user any)

               は、ユーザ `george' の ttyd1 での行動を、 そしてあらゆるユーザのコンソールでの行動を、 そして自分
               自身 (または不法侵入者) のすべての端末での行動を報告します。

               デフォルトでは、ログインとログアウトは 10 分毎に調べられますが、 watch の最初の単語に、調べる間隔
               を分単位で書くこともできます。 たとえば、

                   set watch = (1 any any)

               は 1 分おきにあらゆるログイン / ログアウトを報告します。 我慢の効かない人は、log 組み込みコマンド
               を用いれば、 いつでも watch のレポートを見ることができます。 watch が最初に設定された時には、  現
               在ログインしているユーザリストが (log 組み込みコマンドによって) 報告されます。

               watch の報告形式は who シェル変数で制御します。

       who (+) watch メッセージのフォーマット文字列。 以下のシーケンスが得られた情報で置換されます。

               %n  ログイン / ログアウトしたユーザの名前。
               %a  観察された行動: `logged on', `logged off', `replaced olduser on' のいずれか。
               %l  ユーザがログイン / ログアウトした端末 (tty)。
               %M  リモートホストの完全なホスト名。 ローカルホストでのログイン / ログアウトの場合は `local'。
               %m  リモートホストの、最初の  `.' までのホスト名。 IP アドレスや X Window System ディスプレイの場
                   合は名前全体。

               %M と %m は /etc/utmp  にリモートホスト名を  格納するシステムでのみ利用できます。  設定しなければ
               `%n  has  %a %l from %m.' が用いられます。 ただしリモートホスト名を格納しないシステムでは `%n has
               %a %l.' が用いられます。

       wordchars (+)
               forward-word, backward-word 等の編集コマンドで、 単語の一部とみなされる非英数文字のリスト。  設定
               されなければ `*?_-.[]~=' が使われます。

環境変数

       AFSUSER (+)
               afsuser シェル変数と同じです。

       COLUMNS 端末の桁数です (端末管理 を参照)。

       DISPLAY X  Window System によって使われます (X(1) を参照)。 設定されると、このシェルは autologout (そちら
               も参照) を設定しません。

       EDITOR  デフォルトのエディタのパス名です。 VISUAL 環境変数と  run-fg-editor  編集コマンドも参照してくださ
               い。

       GROUP (+)
               group シェル変数と同じです。

       HOME    home シェル変数と同じです。

       HOST (+)
               シェルが実行されているマシンの名前で初期化されます。 これは gethostname(2) システムコールで決定さ
               れます。

       HOSTTYPE (+)
               シェルが実行されているマシンのタイプで初期化されます。 これはコンパイル時に決定されます。  この変
               数は廃止される予定であり、将来のバージョンで削除されるでしょう。

       HPATH (+)
               run-help   編集コマンドがコマンドの解説文書を探す  ディレクトリのリストです。区切り文字はコロンで
               す。

       LANG    優先的に使用される文字環境を与えます。 固有言語システムのサポートを参照してください。

       LC_CTYPE
               設定されていると、ctype キャラクタの扱いだけが変更されます。 固有言語システムのサポートを参照して
               ください。

       LINES   端末の行数です。 端末管理を参照してください。

       LS_COLORS
               この変数のフォーマットは termcap(5) ファイルのフォーマットと 似ています。"xx=string" の形をした式
               をコロンで区切って並べた リストです。"xx" は 2 文字の変数名です。  変数とそれらのデフォルト値は以
               下の通りです。

                   no      0   Normal (non-filename) text: ファイル名を除く通常のテキスト
                   fi      0   Regular file: 通常のファイル
                   di      01;34
                               Directory: ディレクトリ
                   ln      01;36
                               Symbolic link: シンボリックリンク
                   pi      33  Named pipe (FIFO): 名前付きパイプ
                   so      01;35
                               Socket: ソケット
                   bd      01;33
                               Block device: ブロック型デバイス
                   cd      01;32
                               Character device: キャラクタ型デバイス
                   ex      01;32
                               Executable file: 実行可能ファイル
                   mi      (none)
                               Missing file (defaults to fi): 行方不明のファイル
                   or      (none)
                               Orphaned symbolic link (defaults to ln): リンク先のないシンボリックリンク
                   lc      ^[[ Left code: 色指定シーケンス開始コード
                   rc      m   Right code: 色指定シーケンス終了コード
                   ec      (none)
                               End code (replaces lc+no+rc): 色出力を終えるシーケンス

               デフォルトから変更したい変数だけを指定すれば OK です。

               ファイルの名前を、ファイル名の拡張子をもとに色づけすることもできます。 これの指定は、LS_COLORS 変
               数に "*ext=string" のシンタックスを用いて行います。 たとえば、ISO 6429  のコードを使いすべての  C
               言語のソースファイルを  ブルーに色づけするには "*.c=34" と指定すればよいでしょう。 これは .c で終
               わるすべてのファイルをブルー (34) に色づけします。

               コントロールキャラクタは C スタイルのエスケープ表記か stty のような ^- 表記のどちらかで書くことが
               できます。C  スタイルの表記では  エスケープコードの記述に  ^[, スペースコードの記述に _, デリート
               コードの記述に ? を追加します。 さらに、^[ エスケープキャラクタを用いると、 ^[, ^, :, =  のデフォ
               ルトの解釈を 変更することができます。

               それぞれのファイルは  <lc> <color-code> <rc> <filename> <ec> のように書かれます。 <ec> が未定義な
               らば、<lc> <no> <rc> のシーケンスが代わりに使われます。  こちらの方が通常便利に使えますが、あまり
               一般的ではありません。 left, right, end のコードを用意した理由は、 同じシーケンスを繰り返し入力し
               なくてもいいように、また、 妙な端末に対応できるようにするためです。 通常は、ISO 6429 カラーシーケ
               ンスと異なるシステムを使っていない 限り、これらを変更する必要はほとんどありません。

               端末が  ISO 6429 color コードを使っていれば、(lc, rc, ec コードを全く使わずに) セミコロンで区切ら
               れた数字のコマンドで タイプコードを構成することができます。  良く用いられるコマンドは以下の通りで
               す。

                       0   デフォルトの色に戻します。
                       1   高輝度色
                       4   アンダライン付きテキスト
                       5   点滅テキスト
                       30  前景色黒
                       31  前景色赤
                       32  前景色グリーン
                       33  前景色黄 (ブラウン)
                       34  前景色ブルー
                       35  前景色紫
                       36  前景色シアン
                       37  前景色白 (グレー)
                       40  背景色黒
                       41  背景色赤
                       42  背景色グリーン
                       43  背景色黄 (ブラウン)
                       44  背景色ブルー
                       45  背景色紫
                       46  背景色シアン
                       47  背景色白 (グレー)

               すべてのコマンドがすべてのシステムや表示装置で 動作するわけではありません。

               少なからぬ端末プログラムではデフォルトの終了コードを正しく 認識しません。ディレクトリのリストをし
               た後ですべてのテキストに 色を付けるためには、no コードと fi コードを、 それぞれ 0  から前景色、背
               景色の数値コードへ変更してみてください。

       MACHTYPE (+)
               コンパイル時に決定されたマシンタイプ (マイクロプロセッサまたは、 マシンモデル) です。

       NOREBIND (+)
               設定されていると、印刷可能文字は self-insert-command を 繰り返し実行されません。 固有言語システム
               のサポートを参照してください。

       OSTYPE (+)
               コンパイル時に決定されたオペレーションシステムです。

       PATH    実行可能ファイルを探すディレクトリの、コロン区切り形式のリスト。 シェル変数 path によく似ています
               がフォーマットに違いがあります。

       PWD (+) シェル変数  cwd に似ていますが、シェル変数とは同期していません。 実際のディレクトリ変更が行われた
               あとでだけアップデートされます。

       REMOTEHOST (+)
               ユーザがどのホストからログインしているかを示します (リモートからのログインで、 かつこのシェルがこ
               れらの情報を決定できる場合)。      シェルがそのようにコンパイルされている場合だけに設定されます。
               version シェル変数を参照してください。

       SHLVL (+)
               shlvl と同じです。

       SYSTYPE (+)
               現在のシステムタイプです。 (Domain/OS のみ)

       TERM    term シェル変数と同じです。

       TERMCAP 端末のケーパビリティ文字列です。 端末管理を参照してください。

       USER    user シェル変数と同じです。

       VENDOR (+)
               コンパイル時に決定されたベンダ名です。

       VISUAL  デフォルトのフルスクリーンエディタへのパス名です。 EDITOR 環境変数と run-fg-editor 編集コマンドも
               参照してください。

関連ファイル

       /etc/csh.cshrc  すべてのシェルで最初に読み込まれます。  ConvexOS, Stellix, Intel では /etc/cshrc を使いま
                       す。 NeXTs では /etc/cshrc.std を使います。 A/UX, AMIX, Cray, IRIX の csh(1) はこのファイ
                       ルを読みませんが、  いずれにせよ tcsh ではこのファイルが読み込まれます。 Solaris 2.x もこ
                       のファイルを持ちませんが、tcsh/etc/.cshrc を読み込みます。(+)
       /etc/csh.login  /etc/csh.cshrc の後にログインシェルによって読み込まれます。 ConvexOS, Stellix, Intel では
                       /etc/login  を使います。  NeXTs  では  /etc/login.std  を使用します。  Solaris  2.x  では
                       /etc/.login を使います。 A/UX, AMIX, Cray, IRIX では /etc/cshrc を使います。
       ~/.tcshrc (+)   /etc/csh.cshrc かそれに相当するファイルの後に、 すべてのシェルで読み込まれます。
       ~/.cshrc        ~/.tcshrc が存在しなければ、 /etc/csh.cshrc かそれに相当するファイルの後に、 すべてのシェ
                       ルで読み込まれます。  このマニュアルでは `~/.tcshrc' を 「`~/.tcshrc' か `~/.tcshrc' が見
                       つからなかった場合の ~/.cshrc'」 の意味で使用します。
       ~/.history      savehist が設定されている場合は ~/.tcshrc の後にログインシェルによって読み込まれます。 た
                       だし histfile の部分も参照してください。
       ~/.login        ~/.tcshrc または ~/.history の後にログインシェルによって 読み込まれます。シェルは~/.login~/.tcshrc~/.history の後にではなく、前に読み込むように  コンパイルされているかもし
                       れません。 version シェル変数を参照してください。
       ~/.cshdirs (+)  savedirs が設定されている場合には、 ~/.login の後にログインシェルによって読み込まれます。
                       ただし dirsfile も参照してください。
       /etc/csh.logout ログアウト時にログインシェルによって読み込まれます。  ConvexOS,  Stellix,  Intel   では、
                       /etc/logout  を使います。 A/UX, AMIX, Cray, IRIX では、 csh(1) はこれに対応するファイルを
                       持ちませんが、 いずれにしても tcsh はこのファイルを読みます。 Solaris 2.x も  /etc/logout
                       を持っていませんが、 tcsh/etc/.logout を読み込みます。 (+)
       ~/.logout       /etc/csh.logout またはその相当ファイルが実行された後に、 ログインシェルによって読み込まれ
                       ます。
       /bin/sh         `#' で始まらないシェルスクリプトを解釈実行するために使われます。
       /tmp/sh*        `<<' 用の一時ファイルです。
       /etc/passwd     ホームディレクトリ `~name' を代入するための情報源です。

       スタートアップファイルの読み込みの順番は、 シェルのコンパイル時に変更されているかもしれません。  スタート
       アップとシャットダウンversion を参照してください。

新規機能 (+)

       このマニュアルでは、tcsh  をひとつの対象として記述してきました。 しかし csh(1) の経験者は、 tcsh の新しい
       機能に特に興味があるでしょう。

       コマンド行編集: GNU Emacs スタイルや vi(1)-スタイルの キーバインディングをサポートしています。 コマンド行
       エディタ編集コマンドを参照してください。

       プログラマブルで対話的な単語補完と一覧表示。 補完と一覧と、組み込みコマンド complete, uncomplete の記述を
       見てください。

       ファイル名、コマンド、変数名のスペル訂正 (そちらも参照)。

       エディタ編集コマンド (そちらも参照) で、 コマンドのタイプ中に他の便利な機能を実行できます。  ヘルプファイ
       ルの参照してください  (run-help)、  手軽にエディタの再起動 (run-fg-editor)、 コマンド解決 (which-command)
       などができます。

       高性能化されたヒストリ機能。 ヒストリリストのイベントにタイムスタンプをつけられます。 history  コマンドお
       よびそれに関連するシェル変数、 ヒストリ置換に記述されている、 以前には文書化されていなかった `#' イベント
       記述子と新しい修正子、 *-history, history-search-*, i-search-*, vi-search-*, toggle-literal-history  各編
       集コマンド、 シェル変数 histlit なども参照してください。

       高性能化されたディレクトリ解釈 (parsing) とディレクトリスタック操作。 cd, pushd, popd and dirs コマンドと
       それらに  関連するシェル変数、ディレクトリスタック置換での説明、  dirstack,  owd,  symlinks  シェル変数、
       normalize-command, normalize-path 編集コマンドなどを参照してください。

       グロブパターンの否定。 ファイル名置換を見てください。

       新しいファイル問い合わせ演算子 (そちらも参照) とそれらを用いる組み込みコマンド filetest。

       スケージューリングされたイベント、特別なエイリアス、自動ログアウト、 端末のロック、コマンド待ち、ログイン
       とログアウトの監視などなどを含む、 各種の自動イベント、定期イベント、時刻指定イベント (それぞれの項目を参
       照)。

       固有言語システムのサポート  (固有言語システムのサポートを見てください)、  OS 固有の各種機能のサポート (OS
       固有機能のサポートecho_style シェル変数を参照)、 システム依存のファイル配置 (関連ファイルを参照)

       拡張された端末管理能力 (端末管理を参照)。

       builtins, hup, ls-F, newgrp, printenv, which,  where  などの新しい  組み込みコマンド  (それぞれの項目を参
       照)。

       新しい変数。シェルから便利な情報を簡単に入手できます。  gid, loginsh, oid, shlvl, tcsh, tty, uid, version
       シェル変数と、 HOST, REMOTEHOST, VENDOR, OSTYPE, MACHTYPE 環境変数。 それぞれの説明を見てください。

       有用な情報をプロンプト文字列に埋めこむための新しいシンタックス (prompt を参照)。 ループとスペル訂正用の特
       別なプロンプト (prompt2prompt3 を参照)。

       読み取り専用の変数 (変数置換を参照)。

バグ

       サスペンドされたコマンドが再開されたときに、   カレントディレクトリが起動されたときと違っている場合には、
       起動時のディレクトリを表示します。 ジョブが内部でディレクトリを変更することもあり得るので、  これは間違っ
       た情報を与えてしまうかもしれません。

       シェルの組み込み機能は停止、再開できません。  `a  ; b ; c' のような形のコマンド列を停止させるときの処理も
       あまり上品なものではありません。 `b' コマンドをサスペンドさせると、 シェルは即座に `c' コマンドを実行して
       しまいます。 alias での展開結果を実行しているときには、 特にこの点に注意が必要です。 コマンド列を () の中
       に入れて、 サブシェルに押し込めてしまうのがいいでしょう。 つまり `( a ; b ; c )' のようにするのです。

       プロセス開始後の端末出力の制御が原始的です。 誰かが仮想端末の良いインタフェースを作ってくれるといいのです
       が。 仮想端末インターフェースの分野では、 出力制御に関して面白いことがたくさん行えるはずです。

       エイリアス置換がシェル手続きのシミュレートに大変良く用いられますが、 これはあまり気のきいたものではありま
       せん。 エイリアスよりもシェル手続きを提供すべきです。

       ループの中のコマンドは、ヒストリリストに追加されません。     制御構造は、組み込みコマンドとしては認識され
       ず、単に解釈されます。 したがって制御コマンドはどこにでも置くことができ、 パイプ `|' といっしょにも、 `&'
       と `;' のようなメタシンタックスといっしょにも使えます。

       foreachend を探しているとき ヒアドキュメントを無視しません。

       `:' 修飾子は、 コマンド置換の出力に使えるべきです。

       ダム端末のように、端末がカーソルを上に移動できない場合には、 スクリーン幅より長い行の更新が大変貧弱です。

       HPATHNOREBIND は環境変数である必要はありません。

       `?' や `*' や `[]' を使わないグロブパターンや、 `{}' や `~'  を使うグロブパターンは、否定が正しく扱われま
       せん。

       if  の単一コマンド形式では、たとえ式が偽で、 コマンドが実行されなかったとしても、リダイレクト出力をしてし
       まいます。

       ls-F はファイル名をソートするとき、 ファイル識別キャラクタを勘定に入れてしまいます。 またファイル名の中の
       制御文字を正しく扱うことができません。 中断させることもできません。

       バグレポートは  tcsh-bugs@mx.gw.com  まで送ってください。  修正もいっしょに送っていただけるとありがたいで
       す。 もし tcsh のメンテナンスとテストを手伝って下さる場合には、 本文に "subscribe tcsh <your name>"  と一
       行書いたメールを  listserv@mx.gw.com に送ってください。 "subscribe tcsh-bugs <your name>" を講読すれば す
       べてのバグレポートが取得できます。 "subscribe tcsh-diffs <your name>" を講読すれば 開発 ML に参加でき、各
       パッチレベルでの diff を入手できます。

tcsh T の由来

       1964 年 DEC は PDP-6 を開発しました。 のちに PDP-10 が再実装されました。 1970 年前後に DEC がそのセカンド
       モデル KI10 を発表したとき、 これには DECsystem-10 という新しい名前がつけられました。

       TENEX は 1972 年に Bolt, Beranek & Newman (Massachusetts 州 Cambridge のシンクタンク) において、 実験的な
       デマンドページ型仮想記憶  OS  として作られました。  彼らは DEC PDP-10 用の新しいページャを構築し、 それを
       使った OS を作りました。 これは学術分野で非常に大きな成功を収めました。

       1975 年 DEC  は PDP-10 の新しいモデル KL10 を発表しました。 DEC は BBN  から  TENEX  のライセンスを受け、
       KL10  は TENEX 版のみにするつもりでした。 DEC はそれらのバージョンを TOPS-20 と呼んでいました (大文字化は
       商標です)。 多くの TOPS-10 ("The OPerating System for PDP-10" の頭文字です) ユーザが これに反対しました。
       こうして  DEC は同じハードウエアにふたつの互換性のないシステムを サポートしなければならないことになりまし
       た。 --でもそのとき PDP-11 には 6 つの OS があったのですが!

       TENEX の TOPS-20 はバージョン 3 までに、 ULTCMD  と呼ばれるユーザコードレベルのコマンド補完機能サブルーチ
       ンを 備えていました。バージョン 3 で DEC は、 これらの機能すべてと、さらにそれ以上とをモニタ (Unix でいう
       ところのカーネル) に追加し、 COMND& JSYS (`Jump to SYStem' 命令; スーパーバイザーを呼び出す機能 [私が IBM
       上がりだってバレちゃった?])  でアクセスできるようにしました

       tcsh の作者たちは TENEX と TOPS-20 における これらの機能に影響を受け、これを模倣した版の csh を作成したの
       です。

制限

       単語は 1024 文字より長くできません。

       システムは引数並びを 10240 文字までに制限しています。

       コマンドに与える引き数の数 (ファイル名展開を含む) は、 引き数リストに許された文字数の 1/6  までに制限され
       ています。

       コマンド置換では、 引数リストに許された文字数より多くの文字数に置換できません。

       シェルはループを検出するために、 alias 置換の回数を 1 行当たり 20 に制限しています。

関連項目

       csh(1),  emacs(1),  ls(1), newgrp(1), sh(1), setpath(1), stty(1), su(1), tset(1), vi(1), x(1), access(2),
       execve(2), fork(2), killpg(2), pipe(2), setrlimit(2), sigvec(2), stat(2),  umask(2),  vfork(2),  wait(2),
       malloc(3), setlocale(3), tty(4), a.out(5), termcap(5), environ(7), termio(7), Introduction to the C Shell

バージョン

       このマニュアルは tcsh 6.11.00 (Astron) 2001-09-02 に関するドキュメントです。

作者

       William Joy
         csh(1) のオリジナル作者
       J.E. Kulp, IIASA, Laxenburg, Austria
         ジョブコントロールとディレクトリスタック機能
       Ken Greer, HP Labs, 1981
         ファイル名補完
       Mike Ellis, Fairchild, 1983
         コマンド名認識 / 補完
       Paul Placeway, Ohio State CIS Dept., 1983-1993
         コマンドラインエディタ、プロンプトルーチン、新しいグロブの文法、 たくさんの修正とスピードアップ
       Karl Kleinpaste, CCI 1983-4
         特別なエイリアス、ディレクトリスタックの取出し機能、  ログイン / ログアウト監視、スケジュールイベント、
         新しいプロンプト書式のアイデア
       Rayan Zachariassen, University of Toronto, 1984
         ls-Fwhich の組み込み、たくさんのバクフィックス、 修正とスピードアップ
       Chris Kingsley, Caltech
         高速ストレージアロケータルーチン
       Chris Grevstad, TRW, 1987
         4.3BSD cshtcsh へのマージ
       Christos S. Zoulas, Cornell U. EE Dept., 1987-94
         HPUX, SVR2, SVR3 に移植、SysV 版 getwd.c, SHORT_STRINGS をサポート、 sh.glob.c の新バージョン
       James J Dempsey, BBN, and Paul Placeway, OSU, 1988
         A/UX に移植
       Daniel Long, NNSC, 1988
         wordchars
       Patrick Wolfe, Kuck and Associates, Inc., 1988
         vi モードのクリーンアップ
       David C Lawrence, Rensselaer Polytechnic Institute, 1989
         autolist と、あいまい補完の一覧
       Alec Wolman, DEC, 1989
         プロンプト中の改行
       Matt Landau, BBN, 1989
         ファイル ~/.tcshrc
       Ray Moody, Purdue Physics, 1989
         スペースバーの魔法によるヒストリ展開
       Mordechai ????, Intel, 1989
         printprompt() の修正と追加
       Kazuhiro Honda, Dept. of Computer Science, Keio University, 1989
         自動スペル訂正と prompt3
       Per Hedeland, Ellemtel, Sweden, 1990-
         さまざまなバグフィックス、改良とマニュアルのアップデート
       Hans J. Albertsson (Sun Sweden)
         ampm, settc, telltc
       Michael Bloom
         割り込みハンドリングの修正
       Michael Fine, Digital Equipment Corp
         拡張キーのサポート
       Eric Schnoebelen, Convex, 1990
         Convex サポート、csh の多数のバグフィックス、 ディレクトリスタックの保存と復帰
       Ron Flax, Apple, 1990
         A/UX 2.0 への (再) 移植
       Dan Oscarsson, LTH Sweden, 1990
         NLS サポートと非 NLS サイト用の NLS シミュレート機能、修正
       Johan Widen, SICS Sweden, 1990
         shlvl, Mach サポート、correct-line, 8 ビット表示
       Matt Day, Sanyo Icon, 1990
         POSIX termio サポート、SysV limit 修正
       Jaap Vermeulen, Sequent, 1990-91
         vi モード修正、expand-line, ウインドウ変更の修正、Symmetry 移植
       Martin Boyer, Institut de recherche d'Hydro-Quebec, 1991
         autolist beeping オプション、 行の先頭からカーソルまでのすべてを対象とするヒストリ検索の修正
       Scott Krotz, Motorola, 1991
         Minix に移植
       David Dawes, Sydney U. Australia, Physics Dept., 1991
         SVR4 ジョブコントロールの修正
       Jose Sousa, Interactive Systems Corp., 1991
         拡張 vi の修正、vi デリートコマンド
       Marc Horowitz, MIT, 1991
         ANSIfication の修正、新しい exec ハッシュコード、 imake の修正、where
       Bruce Sterling Woodcock, sterling@netcom.com, 1991-1995
         ETA と Pyramid への移植、 Makefile と lint の修正、ignoreeof=n 追加、  その他のさまざまな移植性向上のた
         めの変更、およびバグ修正
       Jeff Fink, 1992
         complete-word-fwdcomplete-word-back
       Harry C. Pulley, 1992
         Coherent に移植
       Andy Phillips, Mullard Space Science Lab U.K., 1992
         VMS-POSIX に移植
       Beto Appleton, IBM Corp., 1992
         移動プロセスグループの修正、csh バグ修正、 POSIX file tests, POSIX SIGHUP
       Scott Bolte, Cray Computer Corp., 1992
         CSOS に移植
       Kaveh R. Ghazi, Rutgers University, 1992
         Tek, m88k, Titan と Masscomp への移植と修正、 autoconf サポートの追加
       Mark Linderman, Cornell University, 1992
         OS/2 に移植
       Mika Liljeberg, liljeber@kruuna.Helsinki.FI, 1992
         Linux に移植
       Tim P. Starrin, NASA Langley Research Center Operations, 1993
         読み取り専用変数
       Dave Schweisguth, Yale University, 1993-4
         新しいマニュアルページと tcsh.man2html
       Larry Schwimmer, Stanford University, 1993
         AFS と HESIOD パッチ
       Luke Mewburn, RMIT University, 1994-6
         プロンプトの中でのディレクトリ表示の拡張、 ellipsisrprompt
       Edward Hutchins, Silicon Graphics Inc., 1996
         暗黙的な cd の追加。
       Martin Kraemer, 1997
         Siemens Nixdorf EBCDIC machine に移植
       Amol Deshpande, Microsoft, 1997
         WIN32  (Windows/95 and Windows/NT) に移植、 足りないライブラリすべてと、 メッセージカタログコードのすべ
         てを作成し、 Windows と通信できるようにした
       Taga Nayuta, 1998
         色つき ls の追加

謝辞

       以下のみなさんに感謝します。
       Bryan Dunlap, Clayton Elwell, Karl Kleinpaste, Bob Manson, Steve Romig, Diana Smetters, Bob  Sutterfield,
       Mark Verber, Elizabeth Zwicky そして提案と応援をしてくれたオハイオ州のすべてのみなさん。

       あらゆるバージョンに耐え、バグレポートを送ってくれ、   提案と新規追加をしてくれたネット上のすべてのみなさ
       ん。

       "tcsh の T の由来" の章を執筆してくれた Richard M. Alderson III。

翻訳

       t_ogawa <BYH06106@nifty.ne.jp>
       おさな <yasu@via2000.net>
       ゆ〜こ <yuko@veltec.co.jp>
       森浩二 <mori@tri.asanuma.co.jp>
       NOKUBI Hirotaka <nokubi@ff.iij4u.or.jp>
       中野武雄 <nakano@apm.seikei.ac.jp> (JM プロジェクト)
       蔭山 <yt-kage@cb3.so-net.ne.jp>
       中村和志@神戸 <kaz@kobe1995.net>
       大澤千敏@岐阜 <ohsawa@catv1.ccn-net.ne.jp>
       熊谷典大 <kumagai@home.com>
       (順不同)

       翻訳にあたり、JM プロジェクトの方々の御協力を頂きました。