Zend_Console_Getopt-Fetching.xml 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 15617 -->
  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 Getopt</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 Getopt</title>
  36. <programlisting language="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 getOption()</title>
  73. <programlisting language="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>Utiliser les méthodes magiques __get() et __isset()</title>
  87. <programlisting language="php"><![CDATA[
  88. $opts = new Zend_Console_Getopt('abp:');
  89. if (isset($opts->b)) {
  90. echo "J'ai recu l'option b.\n";
  91. }
  92. $p_parameter = $opts->p; // null si non fourni
  93. ]]></programlisting>
  94. </example>
  95. <para>
  96. Si vos options sont déclarées avec des alias, vous pouvez employer n'importe quel
  97. alias de l'option dans les méthodes ci-dessus.
  98. </para>
  99. </sect2>
  100. <sect2 id="zend.console.getopt.fetching.reporting">
  101. <title>Extraire les options</title>
  102. <para>
  103. Il y a plusieurs méthodes pour extraire l'ensemble complet des options fournies
  104. par l'utilisateur dans la ligne de commande courante.
  105. </para>
  106. <itemizedlist>
  107. <listitem>
  108. <para>
  109. Comme pour une chaîne de caractères&#160;: employez la méthode
  110. <code>toString()</code>. Les options sont retournées sous la forme d'une chaîne
  111. de caractère où les paires "<code>drapeau=valeur</code>" sont séparées par des
  112. espaces. La valeur d'une option qui n'a pas de paramètre est la chaîne
  113. "<code>true</code>".
  114. </para>
  115. </listitem>
  116. <listitem>
  117. <para>
  118. Comme un tableau&#160;: employez la méthode <code>toArray()</code>. Les
  119. options sont retournées dans un tableau de chaînes de caractères indexé par des
  120. nombres, les chaînes de drapeau sont suivies par les chaînes de paramètres
  121. éventuels.
  122. </para>
  123. </listitem>
  124. <listitem>
  125. <para>
  126. Comme une chaîne au format JSON&#160;: employez la méthode
  127. <code>toJson()</code>.
  128. </para>
  129. </listitem>
  130. <listitem>
  131. <para>
  132. Comme une chaîne au format XML&#160;: employez la méthode <code>toXml()</code>.
  133. </para>
  134. </listitem>
  135. </itemizedlist>
  136. <para>
  137. Dans toutes les méthodes de déchargement ci-dessus, la chaîne du drapeau est la
  138. première chaîne dans la liste des alias correspondants. Par exemple, si les noms
  139. d'alias d'option étaient déclarés comme "<code>verbose|v</code>", alors la première
  140. chaîne, "<code>verbose</code>", est employé comme nom de l'option. Le nom du drapeau
  141. d'option n'inclut pas le tiret précédent.
  142. </para>
  143. </sect2>
  144. <sect2 id="zend.console.getopt.fetching.remainingargs">
  145. <title>Extraction des arguments sans option</title>
  146. <para>
  147. Après que les arguments d'option et ainsi que les paramètres de la ligne de
  148. commande ont été analysés, il peut exister des arguments additionnels restants. Vous
  149. pouvez interroger ces arguments en utilisant la méthode
  150. <code>getRemainingArgs()</code>. Cette méthode renvoie un tableau de chaîne qui ne fait
  151. partie d'aucune option.
  152. </para>
  153. <example id="zend.console.getopt.fetching.remainingargs.example">
  154. <title>Utiliser getRemainingArgs()</title>
  155. <programlisting language="php"><![CDATA[
  156. $opts = new Zend_Console_Getopt('abp:');
  157. $opts->setArguments(array('-p', 'p_parameter', 'nomdefichier'));
  158. $args = $opts->getRemainingArgs(); // retourne array('nomdefichier')
  159. ]]></programlisting>
  160. </example>
  161. <para>
  162. <classname>Zend_Console_Getopt</classname> supporte la convention GNU selon laquelle un
  163. argument se composant d'un double-tiret signifie la fin des options. Tous les arguments
  164. suivant celui-ci doivent être traités en tant qu'arguments sans options. C'est utile si
  165. vous avez un argument sans options qui commence par un tiret. Par exemple : "
  166. <command>rm -- -nomdefichier-avec-tiret</command>".
  167. </para>
  168. </sect2>
  169. </sect1>