en: You might want to know how I made the logo for yesod in my preceding post.
fr: Dans mon précédent article j'ai fait un logo pour yesod. En faisant celà j'ai aussi découvert une technique efficace pour contourner les problèmes de langages déficients.
en: First, I hate with passion most XML based languages.
en: Because XML wasn't created to be exposed to developer.
en: XML should be read and generated by some software.
en: But you should _never_ read or edit it manually.
fr: Tout d'abord, je déteste la plupart des langages basés sur XML.
fr: XML n'a pas été créé pour être vu par des êtres humains.
fr: XML devrait être lu et généré par des programmes.
fr: May on ne devrait _jamais_ le lire ou l'éditer directement.
en: ## The XSLT Example
fr: ## Un exemple avec XSLT
en: The main language where XML fail terribly is XSLT.
en: XPath is very good, but XSLT use one of the worst syntax I ever crossed in my life of developer.
fr: Le principale langage qui démontre l'incroyable inéfficacité d'XML.
fr: XPath est très bon, mais XSLT utilise la plus horrible syntaxe que j'ai croisée dans ma vie de développeur.
fr: En tout cas pour un langage utilisé réellement (brainfuck est pas mal non plus).
en: In order to reduce the verbosity of such so bad languages, there is a way.
en: **`m4`**. Yes, the preprocessor you use when you program in `C` and `C++`.
fr: Pour réduire la "verbosité" de tels langages, il y a un moyen.
fr: **`m4`**.
fr: Oui, le préprocesseur utilisé par `C` et `C++`.
en: Here are some example:
fr: Voici certains exemples :
en: - Variable, instead of writing the natural `myvar = value`, here is the <sc>xslt</sc> way of doing this:
fr: - Les variables, au lieu d'écrire `myvar = value`, voici la version <sc>xslt</sc> :
en: SVG is a format to display vector graphics, it even support animations.
en: At its beginning some people believed it would be the new Flash. Apparently, it will be more canvas + js.
fr: SVG est un format pour afficher des images vectorielles. Le fomat supporte même les animations.
fr: À ses débuts, beaucoup pensaient que ce serait le nouveau Flash. Apparemment, ce devrait plutôt être `canvas` avec du javascript qui occupera cette place.
<objectdata="<%= blogimagedir %>main.svg"type="image/svg+xml"height="512"width="512"><%= blogimage("main.png","Yesod logo made in SVG and m4") %></object>
en: The positionning of the "esod" text with regards to the reversed "λ" was done by changing position in firebug. I didn't had to manually regenerate to test.
fr: Le positionnement du texte "esod" par rapport au "λ" renversé a été en jouant avec firebug. De cette façon je n'avais pas à regénérer pour tester.
en: If I had to do this for each step, I had make a lot of copy/paste in my SVG, because the transformation is always the same, but I cannot say, use transformation named "titi". Then instead of manually copying some XML, I used m4
fr: Si j'avais dû faire ça manuellement, il m'aurait fallu faire beaucoup de copier/coller dans mon SVG.
fr: Simplement parce que la transformation est toujours la même, mais je ne pouvais pas dire, utiliser la transformation appelée "titi".
en: It was fun to make a fractal in <sc>svg</sc>, but the interesting part is how to augment the power of a language using this preprocessor method.
en: I used the <sc>xslt</sc> trick at work for example.
fr: Ce fut très amusant de faire une fractale en <sc>svg</sc>, mais la partie la plus intéressante était d'augmenter la puissance d'expressivité du langage en utilise un préprocesseur.
fr: J'ai utilisé cette méthode avec <sc>xslt</sc> pour une vrai application par exemple.