Zend_Markup-Parsers.xml 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.markup.parsers">
  5. <title>Analyseurs Zend_Markup (parsers)</title>
  6. <para>
  7. <classname>Zend_Markup</classname> est fourni avec deux analyseurs, BBCode et
  8. Textile.
  9. </para>
  10. <sect2 id="zend.markup.parsers.theory">
  11. <title>Theorie de l'analyse</title>
  12. <para>
  13. Les analyseurs syntaxiques de <classname>Zend_Markup</classname> sont des classes
  14. qui convertissent du texte balisé en un arbre d'identifiants d'analyses, appelées 'tokens'.
  15. Même si nous utilisons par la suite l'analyseur BBCode, le principe de l'arbre à
  16. tokens est le même pour tous les analyseurs syntaxiques. Essayons avec un morceau
  17. de BBCode par exemple:
  18. </para>
  19. <programlisting><![CDATA[
  20. [b]foo[i]bar[/i][/b]baz
  21. ]]></programlisting>
  22. <para>
  23. L'analyseur BBCode va analyser syntaxiquement ce code et en déduire l'arbre suivant:
  24. </para>
  25. <itemizedlist>
  26. <listitem>
  27. <para>[b]</para>
  28. <itemizedlist>
  29. <listitem>
  30. <para>foo</para>
  31. </listitem>
  32. <listitem>
  33. <para>[i]</para>
  34. <itemizedlist>
  35. <listitem>
  36. <para>bar</para>
  37. </listitem>
  38. </itemizedlist>
  39. </listitem>
  40. </itemizedlist>
  41. </listitem>
  42. <listitem>
  43. <para>baz</para>
  44. </listitem>
  45. </itemizedlist>
  46. <para>
  47. Notez que les tags de fermeture n'existent plus dans l'arbre généré. Ceci car ils
  48. n'ont pas de valeur particulière pour la sémantique, ils ne sont pas perdus mais stockés
  49. grâce au seul tag d'ouverture. Notez aussi que ceci n'est qu'une vue simplifiée de l'arbre
  50. réel qui contient en réalité bien plus d'informations comme les attributs éventuels du tag
  51. et son nom.
  52. </para>
  53. </sect2>
  54. <sect2 id="zend.markup.parsers.bbcode">
  55. <title>L'analyseur BBCode</title>
  56. <para>
  57. L'analyseur BBCode est un analyseur de <classname>Zend_Markup</classname> qui
  58. transforme un code BBCode en arbres à tokens. La syntaxe des tags BBCode est:
  59. </para>
  60. <programlisting language="text"><![CDATA[
  61. [name(=(value|"value"))( attribute=(value|"value"))*]
  62. ]]></programlisting>
  63. <para>
  64. Des exemples de tags BBCode valides:
  65. </para>
  66. <programlisting><![CDATA[
  67. [b]
  68. [list=1]
  69. [code file=Zend/Markup.php]
  70. [url="http://framework.zend.com/" title="Zend Framework!"]
  71. ]]></programlisting>
  72. <para>
  73. Par défaut, tous les tags sont fermés avec la syntaxe '[/tagname]'.
  74. </para>
  75. </sect2>
  76. <sect2 id="zend.markup.parsers.textile">
  77. <title>L'analyseur Textile</title>
  78. <para>
  79. L'analyseur Textile de <classname>Zend_Markup</classname> convertit du texte au format Textile
  80. en un arbre à tokens. Textile n'ayant pas de structure à base de tags, la liste suivante est un
  81. exemple de tags:
  82. </para>
  83. <table id="zend.markup.parsers.textile.tags">
  84. <title>Liste de tags Textile basiques</title>
  85. <tgroup cols="2" align="left" colsep="1" rowsep="1">
  86. <thead>
  87. <row>
  88. <entry>Entrée</entry>
  89. <entry>Sortie</entry>
  90. </row>
  91. </thead>
  92. <tbody>
  93. <row>
  94. <entry>*foo*</entry>
  95. <entry><![CDATA[<strong>foo</strong>]]></entry>
  96. </row>
  97. <row>
  98. <entry>_foo_</entry>
  99. <entry><![CDATA[<em>foo</em>]]></entry>
  100. </row>
  101. <row>
  102. <entry>??foo??</entry>
  103. <entry><![CDATA[<cite>foo</cite>]]></entry>
  104. </row>
  105. <row>
  106. <entry>-foo-</entry>
  107. <entry><![CDATA[<del>foo</del>]]></entry>
  108. </row>
  109. <row>
  110. <entry>+foo+</entry>
  111. <entry><![CDATA[<ins>foo</ins>]]></entry>
  112. </row>
  113. <row>
  114. <entry>^foo^</entry>
  115. <entry><![CDATA[<sup>foo</sup>]]></entry>
  116. </row>
  117. <row>
  118. <entry>~foo~</entry>
  119. <entry><![CDATA[<sub>foo</sub>]]></entry>
  120. </row>
  121. <row>
  122. <entry>%foo%</entry>
  123. <entry><![CDATA[<span>foo</span>]]></entry>
  124. </row>
  125. <row>
  126. <entry>PHP(PHP Hypertext Preprocessor)</entry>
  127. <entry><![CDATA[<acronym title="PHP Hypertext Preprocessor">PHP</acronym>]]></entry>
  128. </row>
  129. <row>
  130. <entry>"Zend Framework":http://framework.zend.com/</entry>
  131. <entry><![CDATA[<a href="http://framework.zend.com/">Zend Framework</a>]]></entry>
  132. </row>
  133. <row>
  134. <entry>h1. foobar</entry>
  135. <entry><![CDATA[<h1>foobar</h1>]]></entry>
  136. </row>
  137. <row>
  138. <entry>h6. foobar</entry>
  139. <entry><![CDATA[<h6>foobar</h6>]]></entry>
  140. </row>
  141. <row>
  142. <entry>!http://framework.zend.com/images/logo.gif!</entry>
  143. <entry><![CDATA[<img src="http://framework.zend.com/images/logo.gif" />]]></entry>
  144. </row>
  145. </tbody>
  146. </tgroup>
  147. </table>
  148. <para>
  149. L'analyseur Textile encapsule tous les tags dans des paragraphes; un paragraphe se termine par
  150. deux nouvelles lignes, et s'il y a des tags supplémentaires, un nouveau paragraphe sera ajouté.
  151. </para>
  152. <sect3 id="zend.markup.parsers.textile.lists">
  153. <title>Listes</title>
  154. <para>
  155. L'analyseur Textile supporte aussi deux types de listes. Le type numérique, utilisant
  156. le caractère "#" et le type anonyme qui utilise lui l'étoile "*".
  157. Exemple des deux listes:
  158. </para>
  159. <programlisting><![CDATA[
  160. # Item 1
  161. # Item 2
  162. * Item 1
  163. * Item 2
  164. ]]></programlisting>
  165. <para>
  166. Le code ci-dessus génèrera deux listes, la première, numérique; et la seconde, anonyme.
  167. Dans les éléments des listes, vous pouvez utiliser des tags classiques comme le gras
  168. (*), et l'emphase(italique) (_). Les tags ayant besoin de créer une nouvelle ligne
  169. (comme 'h1' etc.) ne peuvent être utilisés au sein des listes.
  170. </para>
  171. </sect3>
  172. </sect2>
  173. </sect1>