Zend_Console_Getopt-Fetching.xml 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.console.getopt.fetching">
  5. <title>オプションおよび引数の取得</title>
  6. <para>
  7. <classname>Zend_Console_Getopt</classname> オブジェクトでオプションを宣言し、
  8. コマンドラインあるいは配列から引数を受け取ったら、
  9. このオブジェクトを使用して、ユーザがプログラムを起動した際に
  10. 指定したオプションを取得することができます。
  11. このクラスはマジックメソッドを実装しているので、
  12. オプションの名前を指定して問い合わせることができます。
  13. </para>
  14. <para>
  15. 実際にデータをパースするのは、<classname>Zend_Console_Getopt</classname>
  16. に対する最初の問い合わせを行ったときです。
  17. つまり、パースを行う前にいくつかのメソッドで
  18. オプションや引数、ヘルプ文字列や設定項目を変更することができるということです。
  19. </para>
  20. <sect2 id="zend.console.getopt.fetching.exceptions">
  21. <title>Getopt の例外処理</title>
  22. <para>
  23. ユーザがコマンドラインで無効な引数を指定すると、
  24. パース関数は <classname>Zend_Console_Getopt_Exception</classname>
  25. をスローします。この例外を、アプリケーションのコードで処理する必要があります。
  26. <code>parse()</code> メソッドを使用して、オブジェクトに引数をパースさせます。
  27. <code>try</code> ブロック内で <code>parse()</code>
  28. を実行できるので、便利です。
  29. パースに成功すると、それ以降で再度例外がスローされることはありません。
  30. スローされた例外オブジェクトで、独自のメソッド <code>getUsageMessage()</code>
  31. が使用できます。これは、宣言されているすべてのオプションについての
  32. 使用法を説明した文字列を返します。
  33. </para>
  34. <example id="zend.console.getopt.fetching.exceptions.example">
  35. <title>Getopt の例外処理</title>
  36. <programlisting role="php"><![CDATA[
  37. try {
  38. $opts = new Zend_Console_Getopt('abp:');
  39. $opts->parse();
  40. } catch (Zend_Console_Getopt_Exception $e) {
  41. echo $e->getUsageMessage();
  42. exit;
  43. }
  44. ]]>
  45. </programlisting>
  46. </example>
  47. <para>
  48. 例外が発生するのは、次のような場合です。
  49. </para>
  50. <itemizedlist>
  51. <listitem>
  52. <para>
  53. 指定したオプションが認識できない場合。
  54. </para>
  55. </listitem>
  56. <listitem>
  57. <para>
  58. パラメータが必要なオプションで、パラメータが指定されていない場合。
  59. </para>
  60. </listitem>
  61. <listitem>
  62. <para>
  63. オプションのパラメータの型が不正な場合。
  64. たとえば整数型を要求するオプションで非数値文字列が渡された場合など。
  65. </para>
  66. </listitem>
  67. </itemizedlist>
  68. </sect2>
  69. <sect2 id="zend.console.getopt.fetching.byname">
  70. <title>名前によるオプションの取得</title>
  71. <para>
  72. <code>getOption()</code> メソッドを使用すると、
  73. オプションの値を問い合わせることができます。
  74. そのオプションがパラメータを持っている場合は、
  75. このメソッドはパラメータの値を返します。
  76. パラメータを持っていないオプションでユーザがパラメータを指定した場合は、
  77. このメソッドは <code>true</code> を返します。
  78. それ以外の場合は、このメソッドは <code>null</code> を返します。
  79. </para>
  80. <example id="zend.console.getopt.fetching.byname.example.setoption">
  81. <title>getOption() の使用法</title>
  82. <programlisting role="php"><![CDATA[
  83. $opts = new Zend_Console_Getopt('abp:');
  84. $b = $opts->getOption('b');
  85. $p_parameter = $opts->getOption('p');
  86. ]]>
  87. </programlisting>
  88. </example>
  89. <para>
  90. あるいは、マジックメソッド <code>__get()</code> を使用して、
  91. まるでクラスのメンバ変数であるかのようにオプションの値を取得することもできます。
  92. また、マジックメソッド <code>__isset()</code> も実装しています。
  93. </para>
  94. <example id="zend.console.getopt.fetching.byname.example.magic">
  95. <title>マジックメソッド __get() および __isset() の使用例</title>
  96. <programlisting role="php"><![CDATA[
  97. $opts = new Zend_Console_Getopt('abp:');
  98. if (isset($opts->b)) {
  99. echo "オプション b を取得しました。\n";
  100. }
  101. $p_parameter = $opts->p; // 設定されていない場合は null となります
  102. ]]>
  103. </programlisting>
  104. </example>
  105. <para>
  106. オプションにエイリアスが指定されている場合は、
  107. 上の方法でそのエイリアスを使用することもできます。
  108. </para>
  109. </sect2>
  110. <sect2 id="zend.console.getopt.fetching.reporting">
  111. <title>オプションの取得</title>
  112. <para>
  113. ユーザがコマンドラインで入力したオプションの全一覧を取得するには、
  114. いくつかの方法があります。
  115. </para>
  116. <itemizedlist>
  117. <listitem>
  118. <para>
  119. 文字列で取得: <code>toString()</code> メソッドを使用します。
  120. オプションの内容が、空白で区切られた "<code>flag=value</code>"
  121. 形式の文字列で返されます。パラメータを持たないオプションの場合、
  122. value の部分はリテラル文字列 "<code>true</code>" となります。
  123. </para>
  124. </listitem>
  125. <listitem>
  126. <para>
  127. 配列で取得: <code>toArray()</code> メソッドを使用します。
  128. オプションは、数値インデックスの配列で返されます。
  129. 配列の各要素の値は文字列で、フラグの後に
  130. (もしあれば) パラメータが続きます。
  131. </para>
  132. </listitem>
  133. <listitem>
  134. <para>
  135. JSON データを含む文字列として取得: <code>toJson()</code> メソッドを使用します。
  136. </para>
  137. </listitem>
  138. <listitem>
  139. <para>
  140. XML データを含む文字列として取得: <code>toXml()</code> メソッドを使用します。
  141. </para>
  142. </listitem>
  143. </itemizedlist>
  144. <para>
  145. これらのすべての出力メソッドで、フラグ文字列として使用するのは
  146. エイリアスリストの先頭にあるものです。たとえば
  147. あるオプションのエイリアスが "<code>verbose|v</code>"
  148. のように宣言されていたとすると、最初の文字列である "<code>verbose</code>"
  149. をオプション名として使用します。
  150. オプションフラグ名には、先頭のダッシュは含みません。
  151. </para>
  152. </sect2>
  153. <sect2 id="zend.console.getopt.fetching.remainingargs">
  154. <title>非オプション引数の取得</title>
  155. <para>
  156. オプション引数およびそのパラメータをコマンドラインからパースした後も、
  157. まだ追加の引数が残っているかも知れません。これらの引数を取得するには
  158. <code>getRemainingArgs()</code> メソッドを使用します。このメソッドは、
  159. どのオプションにも属さない文字列の配列を返します。
  160. </para>
  161. <example id="zend.console.getopt.fetching.remainingargs.example">
  162. <title>getRemainingArgs() の使用法</title>
  163. <programlisting role="php"><![CDATA[
  164. $opts = new Zend_Console_Getopt('abp:');
  165. $opts->setArguments(array('-p', 'p_parameter', 'filename'));
  166. $args = $opts->getRemainingArgs(); // array('filename') を返します
  167. ]]>
  168. </programlisting>
  169. </example>
  170. <para>
  171. <classname>Zend_Console_Getopt</classname> は、GNU
  172. の慣習である「ダッシュふたつだけの引数があったら、
  173. オプションはそこで終わりとみなす」をサポートしています。
  174. その後に続く引数は、非オプション引数として扱わなければなりません。
  175. これは、オプションではない引数がダッシュで始まる場合などに有用です。
  176. たとえば "<command>rm -- -filename-with-dash</command>"
  177. のような場合です。
  178. </para>
  179. </sect2>
  180. </sect1>