Zend_Markup-Parsers.xml 7.2 KB

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