<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html lang="ja"> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <meta http-equiv="Content-Script-Type" content="text/javascript"> <meta http-equiv="Content-Style-Type" content="text/css"> <meta name="author" content="magicant"> <meta name="description" content="Yash の typeset 組込みコマンドについて"> <title>Yash マニュアル: typeset 組込みコマンド</title> <link rel="Contents" href="../index.html" title="目次"> <link rel="Prev" href="type.html" title="Type 組込みコマンド"> <link rel="Next" href="ulimit.html" title="Ulimit 組込みコマンド"> <link rel="Stylesheet" href="../style.css"> <div class="breadcrumb"><a href="../index.html">目次</a> > <a rel="Up" href="index.html">組込みコマンド一覧</a></div> <h1>Typeset 組込みコマンド</h1> <p><dfn>Typeset 組込みコマンド</dfn>は<a href="../params.html#variables">変数</a>または<a href="../exec.html#function">関数</a>を表示・設定します。 <h2 id="syntax">構文</h2> <ul> <li><code>typeset [-gprxX] [<var>変数</var>…] [<var>変数</var>=<var>値</var>…]</code> <li><code>typeset -f[pr] [<var>関数</var>…]</code> </ul> <h2 id="description">説明</h2> <p><code>-f</code> (<code>--functions</code>) オプションを付けずに実行すると、typeset コマンドは<a href="../params.html#variables">変数</a>を出力または設定します。<code>-f</code> (<code>--functions</code>) オプションを付けて実行すると、typeset コマンドは<a href="../exec.html#function">関数</a>を出力または設定します。 <p><code>-p</code> (<code>--print</code>) オプションを付けて実行すると、typeset コマンドはオペランドで指定した変数または関数を標準出力に出力します。<code>-p</code> (<code>--print</code>) オプションを付けずに実行すると、typeset コマンドはオペランドで指定した変数または関数を設定します。オペランドを一つも与えずに実行すると、<code>-p</code> (<code>--print</code>) オプションの有無にかかわらず typeset コマンドは全ての変数または関数を出力します (このとき <code>-g</code> (<code>--global</code>) オプションがあれば本当にすべての変数を、そうでないときはローカル変数だけを出力します)。 <h2 id="options">オプション</h2> <dl> <dt><code>-f</code>, <code>--functions</code> <dd>変数ではなく関数を表示または設定します。 <dt><code>-g</code>, <code>--global</code> <dd>このオプションを指定すると、新しく変数を作成する場合その変数をグローバル変数とします。すなわち変数は関数の実行が終わっても残ります。このオプションを指定しない場合、設定する変数は<a href="../exec.html#localvar">ローカル変数</a>になります。 <dd>オペランドがない場合は、このオプションを指定していると全ての変数を出力します。このオプションを指定していないとローカル変数だけ出力します。 <dt><code>-p</code>, <code>--print</code> <dd>変数または関数の定義を (コマンドとして解釈可能な形式で) 出力します。 <dt><code>-r</code>, <code>--readonly</code> <dd>設定する変数・関数を<dfn>読み取り専用</dfn>にします。読み取り専用の変数・関数は、値を変更したり削除したりできなくなります。 <dd>読み取り専用の変数・関数だけ出力します。 <dt><code>-x</code>, <code>--export</code> <dd>設定する変数を<a href="../params.html#variables">エクスポート対象</a>にします。 <dd>エクスポート対象の変数だけ出力します。 <dt><code>-x</code>, <code>--unexport</code> <dd>設定する変数をエクスポート対象から外します。 </dl> <h2 id="operands">オペランド</h2> <dl> <dt><var>変数</var> <dd>出力または設定する変数の名前です。変数が既に存在する場合、変数の値は変わりません。存在しない変数を指定した場合、<q>変数は存在するがその値は存在しない</q>状態になります (このような変数は<a href="../expand.html#params">パラメータ展開</a>では存在しない変数として扱います)。 <dt><var>変数</var>=<var>値</var> <dd>設定する変数の名前とその値です。指定した<var>値</var>が変数の値として設定されます。この形式のオペランドでは、<code>-p</code> (<code>--print</code>) オプションを指定したときでもこの変数は出力ではなく設定されます。 <dt><var>関数</var> <dd>出力または設定する関数の名前です。存在しない関数を指定することはできません。 </dl> <h2 id="exitstatus">終了ステータス</h2> <p>エラーがない限り typeset コマンドの終了ステータスは 0 です。 <h2 id="notes">補足</h2> <p>既にローカル変数が存在する場合、それを無視してグローバル変数を新しく作ることはできません (<code>-g</code> (<code>--global</code>) オプションを指定していても既存のローカル変数が再設定されます)。 <p>POSIX には typeset コマンドに関する規定はありません。</p> <p><a href="export.html">Export コマンド</a>は typeset コマンドに <code>-gx</code> オプションを付けたものと同じです。<a href="readonly.html">Readonly コマンド</a>は typeset コマンドに <code>-gr</code> オプションを付けたものと同じです。