Zend_Console_Getopt-Introduction.xml 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <sect1 id="zend.console.getopt.introduction">
  2. <title> Getopt 简介 </title>
  3. <para>
  4. <code>Zend_Console_Getopt</code> 类帮助命令行程序解析它们的选项和参数。
  5. </para>
  6. <para>
  7. 当执行你的程序时,用户可以指定命令行参数。这些参数对程序时有意义的,或改变程序的行为,或选择资源,或详细说明参数。许多选项有传统的意义,例如 "<code>--verbose</code>" 对大多数的程序都是允许输出执行细节。一些选项可能对不同的程序有不同的意义。例如 "<code>-c</code>" 在 <command>grep</command>、 <command>ls</command> 和 <command>tar</command> 里有不同的功能。
  8. </para>
  9. <para>
  10. 下面时一些术语的定义。术语的基本用法变化多样,但本文档使用下面的定义。
  11. </para>
  12. <itemizedlist>
  13. <listitem>
  14. <para>
  15. "argument":在命令之后的字符串。Arguments 可以时选项或其它不带选项的形式,在命令操作时指出资源。
  16. </para>
  17. </listitem>
  18. <listitem>
  19. <para>
  20. "option":表示命令应该改变其缺省行为的参数。
  21. </para>
  22. </listitem>
  23. <listitem>
  24. <para>
  25. "flag":选项的第一部分,确定选项的意图。传统上 flag 前面有一个或两个短横线 ("<code>-</code>" 或 "<code>--</code>")。一个单个的短横引导一个单字符的 flag 或 一组单字符的 flags。双横线引导一个多字符的 flag。长的 flags 不能组合。
  26. </para>
  27. </listitem>
  28. <listitem>
  29. <para>
  30. "parameter":选项的第二部分,如果它适用于给定的选项,就是随 flag 带的数据值。例如,许多命令接受 "<code>--verbose</code>" 选项,但一般这个选项没有参数(parameter)。但象 "<code>--user</code>" 的选项几乎总是有一个参数( parameter )。
  31. </para>
  32. <para>
  33. parameter 可以作为在 flag 参数之后的分离的参数,或作为同一参数串的一部分,从 flag 里用等号("<code>=</code>")分开。后者只被长的 flags 支持。例如,<code>-u username</code>、 <code>--user username</code> 和 <code>--user=username</code> 是被 <code>Zend_Console_Getopt</code> 支持的格式。
  34. </para>
  35. </listitem>
  36. <listitem>
  37. <para>
  38. "cluster":在一个单字串参数里的多个单字符 flags 组合,由单个短横线引导。例如,"<command>ls -1str</command>" 使用一组四个短 flags 。这个命令和 "<command>ls -1 -s -t -r</command>" 相同。只有单个字符 flags 可以被组成组,对长的 flags 不可以组合。
  39. </para>
  40. </listitem>
  41. </itemizedlist>
  42. <para>
  43. 例如,在 "<code>mysql --user=root mydatabase</code>" 里,"<code>mysql</code>" 是<emphasis> 命令 </emphasis>,"<code>--user=root</code>" 是 <emphasis>option</emphasis>,"<code>--user</code>" 是 <emphasis>flag</emphasis>,"<code>root</code>" 是 option 的 <emphasis>parameter</emphasis>,根据我们的定义 "<code>mydatabase</code>" 是 argument 而不是 option 。
  44. </para>
  45. <para>
  46. <code>Zend_Console_Getopt</code> 提供了接口来声明哪个 flags 对你的程序有效,如果使用了无效的flag,则输出错误和用法信息,并报告给你的程序代码。
  47. </para>
  48. <note>
  49. <title>Getopt 不是应用程序框架 </title>
  50. <para>
  51. <code>Zend_Console_Getopt</code> <emphasis> 不 </emphasis> 不翻译 flags 和 parameters 的意思,这个类也不实现程序流程或调用程序代码。你必需在你自己的程序代码中实现这些动作。你可以使用 <code>Zend_Console_Getopt</code> 来解析命令行和提供面向对象的方法来查询由用户给定的 options ,但使用这些信息去调用程序的部分应当在其它 PHP 类里。
  52. </para>
  53. </note>
  54. <para>
  55. 后面的章节描述 <code>Zend_Console_Getopt</code> 的用法。
  56. </para>
  57. </sect1>