Zend_Console_Getopt-Fetching.xml 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 15103 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.console.getopt.fetching">
  5. <title>Extraire les options et les arguments</title>
  6. <para>
  7. Après avoir déclaré les options que l'objet <classname>Zend_Console_Getopt</classname> doit
  8. identifier, et fourni les arguments de la ligne de commande ou un tableau, vous pouvez
  9. interroger l'objet pour connaître les options indiquées par un utilisateur lors d'un appel
  10. à votre programme en ligne de commande. La classe implémente les méthodes magiques ainsi
  11. vous pouvez interroger directement par les noms d'options.
  12. </para>
  13. <para>
  14. L'analyse des données est reportée jusqu'à ce que vous invoquiez pour la première
  15. fois l'objet <classname>Zend_Console_Getopt</classname> pour découvrir si une option était
  16. renseignée, l'objet exécute alors son analyse. Ceci permet plusieurs appels de méthode pour
  17. configurer les options, arguments, messages d'aide, et les options de configuration, avant
  18. que l'analyse ne soit lancée.
  19. </para>
  20. <sect2 id="zend.console.getopt.fetching.exceptions">
  21. <title>Manipuler les exceptions <code>Getopt</code></title>
  22. <para>
  23. Si l'utilisateur a donné des options invalides sur la ligne de commande, la
  24. fonction d'analyse syntaxique lève une
  25. <classname>Zend_Console_Getopt_Exception</classname>. Vous devrez récupérer cette
  26. exception dans votre code d'application. Vous pouvez utiliser la méthode
  27. <code>parse()</code> pour forcer l'objet à analyser les arguments. C'est utile
  28. parce que vous pouvez invoquer <code>parse()</code> dans un bloc <code>try</code>. S'il
  29. passe, vous pouvez être sûrs que l'analyse syntaxique ne lèvera pas d'exception de
  30. nouveau. L'exception est lancée via une méthode personnalisée
  31. <code>getUsageMessage()</code>, qui retourne comme une chaîne de caractère l'ensemble
  32. formaté des messages d'utilisation pour toutes les options déclarées.
  33. </para>
  34. <example id="zend.console.getopt.fetching.exceptions.example">
  35. <title>Récupérer une exception <code>Getopt</code></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. ]]></programlisting>
  45. </example>
  46. <para>Les cas, où l'analyse syntaxique lève une exception, incluent&#160;:</para>
  47. <itemizedlist>
  48. <listitem>
  49. <para>L'option passée n'est pas reconnue.</para>
  50. </listitem>
  51. <listitem>
  52. <para>L'option nécessite un paramètre mais aucun n'est fourni.</para>
  53. </listitem>
  54. <listitem>
  55. <para>
  56. Le paramètre d'option n'a pas le bon type. Par exemple, une chaîne de
  57. caractères non-numérique quand un nombre entier a été exigé.
  58. </para>
  59. </listitem>
  60. </itemizedlist>
  61. </sect2>
  62. <sect2 id="zend.console.getopt.fetching.byname">
  63. <title>Extraire les options par nom</title>
  64. <para>
  65. Vous pouvez employer la méthode <code>getOption()</code> pour connaître la valeur
  66. d'une option. Si l'option avait un paramètre, cette méthode retourne la valeur du
  67. paramètre. Si l'option n'avait aucun paramètre mais que l'utilisateur en indiquait sur
  68. dans la ligne de commande, la méthode retournerait <code>true</code>. Sinon la méthode
  69. retournerait <code>null</code>.
  70. </para>
  71. <example id="zend.console.getopt.fetching.byname.example.setoption">
  72. <title>Utiliser <code>getOption()</code></title>
  73. <programlisting role="php"><![CDATA[
  74. $opts = new Zend_Console_Getopt('abp:');
  75. $b = $opts->getOption('b');
  76. $p_parameter = $opts->getOption('p');
  77. ]]></programlisting>
  78. </example>
  79. <para>
  80. De manière alternative, vous pouvez employer la fonction magique
  81. <code>__get()</code> pour rechercher la valeur d'une option comme si c'était une
  82. variable de membre de classe. La méthode magique <code>__isset()</code> est également
  83. implémentée.
  84. </para>
  85. <example id="zend.console.getopt.fetching.byname.example.magic">
  86. <title>
  87. Utiliser les méthodes magiques <code>__get()</code> and
  88. <code>__isset()</code>
  89. </title>
  90. <programlisting role="php"><![CDATA[
  91. $opts = new Zend_Console_Getopt('abp:');
  92. if (isset($opts->b)) {
  93. echo "J'ai recu l'option b.\n";
  94. }
  95. $p_parameter = $opts->p; // null si non fourni
  96. ]]></programlisting>
  97. </example>
  98. <para>
  99. Si vos options sont déclarées avec des alias, vous pouvez employer n'importe quel
  100. alias de l'option dans les méthodes ci-dessus.
  101. </para>
  102. </sect2>
  103. <sect2 id="zend.console.getopt.fetching.reporting">
  104. <title>Extraire les options</title>
  105. <para>
  106. Il y a plusieurs méthodes pour extraire l'ensemble complet des options fournies
  107. par l'utilisateur dans la ligne de commande courante.
  108. </para>
  109. <itemizedlist>
  110. <listitem>
  111. <para>
  112. Comme pour une chaîne de caractères&#160;: employez la méthode
  113. <code>toString()</code>. Les options sont retournées sous la forme d'une chaîne
  114. de caractère où les paires "<code>drapeau=valeur</code>" sont séparées par des
  115. espaces. La valeur d'une option qui n'a pas de paramètre est la chaîne
  116. "<code>true</code>".
  117. </para>
  118. </listitem>
  119. <listitem>
  120. <para>
  121. Comme un tableau&#160;: employez la méthode <code>toArray()</code>. Les
  122. options sont retournées dans un tableau de chaînes de caractères indexé par des
  123. nombres, les chaînes de drapeau sont suivies par les chaînes de paramètres
  124. éventuels.
  125. </para>
  126. </listitem>
  127. <listitem>
  128. <para>
  129. Comme une chaîne au format JSON&#160;: employez la méthode
  130. <code>toJson()</code>.
  131. </para>
  132. </listitem>
  133. <listitem>
  134. <para>
  135. Comme une chaîne au format XML&#160;: employez la méthode <code>toXml()</code>.
  136. </para>
  137. </listitem>
  138. </itemizedlist>
  139. <para>
  140. Dans toutes les méthodes de déchargement ci-dessus, la chaîne du drapeau est la
  141. première chaîne dans la liste des alias correspondants. Par exemple, si les noms
  142. d'alias d'option étaient déclarés comme "<code>verbose|v</code>", alors la première
  143. chaîne, "<code>verbose</code>", est employé comme nom de l'option. Le nom du drapeau
  144. d'option n'inclut pas le tiret précédent.
  145. </para>
  146. </sect2>
  147. <sect2 id="zend.console.getopt.fetching.remainingargs">
  148. <title>Extraction des arguments sans option</title>
  149. <para>
  150. Après que les arguments d'option et ainsi que les paramètres de la ligne de
  151. commande ont été analysés, il peut exister des arguments additionnels restants. Vous
  152. pouvez interroger ces arguments en utilisant la méthode
  153. <code>getRemainingArgs()</code>. Cette méthode renvoie un tableau de chaîne qui ne fait
  154. partie d'aucune option.
  155. </para>
  156. <example id="zend.console.getopt.fetching.remainingargs.example">
  157. <title>Utiliser <code>getRemainingArgs()</code></title>
  158. <programlisting role="php"><![CDATA[
  159. $opts = new Zend_Console_Getopt('abp:');
  160. $opts->setArguments(array('-p', 'p_parameter', 'nomdefichier'));
  161. $args = $opts->getRemainingArgs(); // retourne array('nomdefichier')
  162. ]]></programlisting>
  163. </example>
  164. <para>
  165. <classname>Zend_Console_Getopt</classname> supporte la convention GNU selon laquelle un
  166. argument se composant d'un double-tiret signifie la fin des options. Tous les arguments
  167. suivant celui-ci doivent être traités en tant qu'arguments sans options. C'est utile si
  168. vous avez un argument sans options qui commence par un tiret. Par exemple : "
  169. <command>rm -- -nomdefichier-avec-tiret</command>".
  170. </para>
  171. </sect2>
  172. </sect1>