2
0

Zend_Console_Getopt-Rules.xml 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.console.getopt.rules">
  5. <title>Déclarer les règles Getopt</title>
  6. <para>
  7. Le constructeur de la classe <classname>Zend_Console_Getopt</classname> prend un à trois
  8. arguments. Le premier argument déclare quelles options sont supportées par votre
  9. application. Cette classe supporte des formes de syntaxe alternatives pour déclarer les
  10. options. Voir les sections ci-dessous pour le format et l'utilisation de ces formes de
  11. syntaxe.
  12. </para>
  13. <para>
  14. Le constructeur prend deux arguments supplémentaires, qui sont facultatifs. Le
  15. deuxième argument peut contenir les arguments de la ligne de commande. La valeur par défaut
  16. est <code>$_SERVER['argv']</code>.
  17. </para>
  18. <para>
  19. Le troisième argument du constructeur peut contenir des options de configuration pour
  20. adapter le comportement de <classname>Zend_Console_Getopt</classname>. Voir la section
  21. <link linkend="zend.console.getopt.configuration.config">Ajouter une
  22. configuration</link> pour la référence des options disponibles.
  23. </para>
  24. <sect2 id="zend.console.getopt.rules.short">
  25. <title>Déclarer des options avec la syntaxe courte</title>
  26. <para>
  27. <classname>Zend_Console_Getopt</classname> supporte une syntaxe compacte semblable à
  28. cela employée par GNU Getopt (voir
  29. <ulink url="http://www.gnu.org/software/libc/manual/html_node/Getopt.html">
  30. http://www.gnu.org/software/libc/manual/html_node/Getopt.html</ulink>). Cette syntaxe
  31. supporte seulement des drapeaux courts (1 seul caractère). Dans une chaîne de caractère
  32. unique, vous entrez chacune des lettres qui correspondent aux drapeaux supportés par
  33. votre application. Une lettre suivie d'un caractère deux points ("<code>:</code>")
  34. indique un drapeau qui exige un paramètre.
  35. </para>
  36. <example id="zend.console.getopt.rules.short.example">
  37. <title>Utiliser la syntaxe courte</title>
  38. <programlisting language="php"><![CDATA[
  39. $opts = new Zend_Console_Getopt('abp:');
  40. ]]></programlisting>
  41. </example>
  42. <para>
  43. L'exemple ci-dessus montre l'utilisation de <classname>Zend_Console_Getopt</classname>
  44. pour déclarer que des options peuvent être données en tant que "<code>-a</code>",
  45. "<code>-b</code>" ou "<code>-p</code>". Le dernier drapeau exige un paramètre.
  46. </para>
  47. <para>
  48. La syntaxe courte est limitée aux drapeaux courts (1 seul caractère). Les alias, les
  49. types des paramètres, et les messages d'aide ne sont pas supportés dans la syntaxe
  50. courte.
  51. </para>
  52. </sect2>
  53. <sect2 id="zend.console.getopt.rules.long">
  54. <title>Déclarer des options avec la syntaxe longue</title>
  55. <para>
  56. Une syntaxe différente avec plus de possibilités est également disponible. Cette
  57. syntaxe permet d'indiquer des alias pour les drapeaux, les types de paramètres
  58. d'option, et aussi des messages d'aide pour décrire l'utilisation à l'utilisateur. Au
  59. lieu d'utiliser une chaîne de caractère unique comme pour la syntaxe courte, la syntaxe
  60. longue emploie un tableau associatif comme premier argument du constructeur pour
  61. déclarer les options.
  62. </para>
  63. <para>
  64. La clé de chaque élément du tableau associatif est une chaîne avec un format qui
  65. nomme le drapeau, avec tous ses alias, séparés par le symbole "<code>|</code>". Après
  66. la série des alias, si l'option exige un paramètre, il y a un symbole égal
  67. ("<code>=</code>") avec une lettre qui représente le <emphasis>type</emphasis> du
  68. paramètre :
  69. </para>
  70. <itemizedlist>
  71. <listitem>
  72. <para>"<code>=s</code>" pour un paramètre de type chaîne de caractère.</para>
  73. </listitem>
  74. <listitem>
  75. <para>
  76. "<code>=w</code>" pour un paramètre de type mot (une chaîne de caractère
  77. qui ne contient pas d'espace).
  78. </para>
  79. </listitem>
  80. <listitem>
  81. <para>"<code>=i</code>" pour un paramètre de type entier (integer).</para>
  82. </listitem>
  83. </itemizedlist>
  84. <para>
  85. Si le paramètre est optionnel, on utilise le tiret ("<code>-</code>") au lieu du
  86. symbole égal.
  87. </para>
  88. <para>
  89. La valeur de chaque élément dans le tableau associatif est un message d'aide pour
  90. décrire à l'utilisateur comment employer votre programme.
  91. </para>
  92. <example id="zend.console.getopt.rules.long.example">
  93. <title>Utiliser la syntaxe longue</title>
  94. <programlisting language="php"><![CDATA[
  95. $opts = new Zend_Console_Getopt(
  96. array(
  97. 'abricot|a' => 'option abricot, sans parametres',
  98. 'banane|b=i' => 'option banane, avec un parametre entier obligatoire',
  99. 'pear|p-s' => 'option pear, avec un parametre chaîne optionel'
  100. )
  101. );
  102. ]]></programlisting>
  103. </example>
  104. <para>
  105. Dans l'exemple ci-dessus, il y a trois options. "<code>--abricot</code>" et
  106. "<code>-a</code>" sont des alias l'un pour l'autre et l'option ne prend pas de
  107. paramètres. "<code>--banane</code>" et "<code>-b</code>" sont des alias l'un pour
  108. l'autre et l'option prend un paramètre obligatoire de type entier. Enfin,
  109. "<code>--pear</code>" et "<code>-p</code>" sont des alias l'un pour l'autre et l'option
  110. prend un paramètre optionnel de type chaîne de caractère.
  111. </para>
  112. </sect2>
  113. </sect1>