1 <?xml version="1.0" encoding="UTF-8"?>
2 <!-- EN-Revision: 20827 -->
4 <sect1 id="zend.markup.parsers">
5 <title>Analyseurs Zend_Markup (parsers)</title>
8 <classname>Zend_Markup</classname> est fourni avec deux analyseurs, BBCode et
12 <sect2 id="zend.markup.parsers.theory">
13 <title>Theorie de l'analyse</title>
16 Les analyseurs syntaxiques de <classname>Zend_Markup</classname> sont des classes
17 qui convertissent du texte balisé en un arbre d'identifiants d'analyses, appelées 'tokens'.
18 Même si nous utilisons par la suite l'analyseur BBCode, le principe de l'arbre à
19 tokens est le même pour tous les analyseurs syntaxiques. Essayons avec un morceau
20 de BBCode par exemple:
23 <programlisting><![CDATA[
24 [b]foo[i]bar[/i][/b]baz
28 L'analyseur BBCode va analyser syntaxiquement ce code et en déduire l'arbre suivant:
58 Notez que les tags de fermeture n'existent plus dans l'arbre généré. Ceci car ils
59 n'ont pas de valeur particulière pour la sémantique, ils ne sont pas perdus mais stockés
60 grâce au seul tag d'ouverture. Notez aussi que ceci n'est qu'une vue simplifiée de l'arbre
61 réel qui contient en réalité bien plus d'informations comme les attributs éventuels du tag
66 <sect2 id="zend.markup.parsers.bbcode">
67 <title>L'analyseur BBCode</title>
70 L'analyseur BBCode est un analyseur de <classname>Zend_Markup</classname> qui
71 transforme un code BBCode en arbres à tokens. La syntaxe des tags BBCode est:
74 <programlisting language="text"><![CDATA[
75 [name(=(value|"value"))( attribute=(value|"value"))*]
79 Des exemples de tags BBCode valides:
82 <programlisting><![CDATA[
85 [code file=Zend/Markup.php]
86 [url="http://framework.zend.com/" title="Zend Framework!"]
90 Par défaut, tous les tags sont fermés avec la syntaxe '[/tagname]'.
94 <sect2 id="zend.markup.parsers.textile">
95 <title>L'analyseur Textile</title>
98 L'analyseur Textile de <classname>Zend_Markup</classname> convertit du texte au format Textile
99 en un arbre à tokens. Textile n'ayant pas de structure à base de tags, la liste suivante est un
103 <table id="zend.markup.parsers.textile.tags">
104 <title>Liste de tags Textile basiques</title>
106 <tgroup cols="2" align="left" colsep="1" rowsep="1">
109 <entry>Entrée</entry>
111 <entry>Sortie</entry>
119 <entry><![CDATA[<strong>foo</strong>]]></entry>
125 <entry><![CDATA[<em>foo</em>]]></entry>
129 <entry>??foo??</entry>
131 <entry><![CDATA[<cite>foo</cite>]]></entry>
137 <entry><![CDATA[<del>foo</del>]]></entry>
143 <entry><![CDATA[<ins>foo</ins>]]></entry>
149 <entry><![CDATA[<sup>foo</sup>]]></entry>
155 <entry><![CDATA[<sub>foo</sub>]]></entry>
161 <entry><![CDATA[<span>foo</span>]]></entry>
165 <entry>PHP(PHP Hypertext Preprocessor)</entry>
167 <entry><![CDATA[<acronym title="PHP Hypertext Preprocessor">PHP</acronym>]]></entry>
171 <entry>"Zend Framework":http://framework.zend.com/</entry>
173 <entry><![CDATA[<a href="http://framework.zend.com/">Zend Framework</a>]]></entry>
177 <entry>h1. foobar</entry>
179 <entry><![CDATA[<h1>foobar</h1>]]></entry>
183 <entry>h6. foobar</entry>
185 <entry><![CDATA[<h6>foobar</h6>]]></entry>
189 <entry>!http://framework.zend.com/images/logo.gif!</entry>
191 <entry><![CDATA[<img src="http://framework.zend.com/images/logo.gif" />]]></entry>
198 L'analyseur Textile encapsule tous les tags dans des paragraphes; un paragraphe se termine par
199 deux nouvelles lignes, et s'il y a des tags supplémentaires, un nouveau paragraphe sera ajouté.
202 <sect3 id="zend.markup.parsers.textile.lists">
203 <title>Listes</title>
206 L'analyseur Textile supporte aussi deux types de listes. Le type numérique, utilisant
207 le caractère "#" et le type anonyme qui utilise lui l'étoile "*".
208 Exemple des deux listes:
211 <programlisting><![CDATA[
220 Le code ci-dessus génèrera deux listes, la première, numérique; et la seconde, anonyme.
221 Dans les éléments des listes, vous pouvez utiliser des tags classiques comme le gras
222 (*), et l'emphase(italique) (_). Les tags ayant besoin de créer une nouvelle ligne
223 (comme 'h1' etc.) ne peuvent être utilisés au sein des listes.