En fouillant un peu, je suis tombé sur Quick Highlighter, un convertisseur web qui prend le code en entrée (on doit spécifier le langage) et qui retourne le code coloré en format HTML. Avec ça, j'aurais pu simplement copier / coller le résultat dans mon blogue.
Mais comme je voulais quelque chose d'un peu plus automatisé, j'ai découvert sur Google Code un projet qui s'appele SyntaxHighlighter, complètement indépendant du serveur web puisqu'il fonctionne côté client en JavaScript et CSS. Peut-être avez-vous déjà vu le rendu du code source de Yahoo Developer Network ou Aptana ? C'est ce composant qu'ils utilisent.
Par rapport à GeSHi, SyntaxHighlighter possède trois défauts notables:
- il est plus lent que GeSHi (qui roule côté serveur)
- il est efficace pour une source comptant peu de code
- il est limité au niveau des langages supportés : C++, C#, CSS, Delphi, Java, JavaScript, PHP, Python, Ruby, SQL, VB, XML et HTML
- Dans l'onglet Layout, aller dans Edit HTML
- Juste avant la balise </head>, faire un lien vers les fichiers JavaScript de chaque langage pour lequel on veut supporter la coloration :
<script language='javascript' src='http://syntaxhighlighter.googlecode.com/svn/trunk/Scripts/shCore.js'/>
<script language='javascript' src='http://syntaxhighlighter.googlecode.com/svn/trunk/Scripts/shBrushXml.js'/>
<script language='javascript' src='http://syntaxhighlighter.googlecode.com/svn/trunk/Scripts/shBrushSql.js'/>
<script language='javascript' src='http://syntaxhighlighter.googlecode.com/svn/trunk/Scripts/shBrushPhp.js'/>
<script language='javascript' src='http://syntaxhighlighter.googlecode.com/svn/trunk/Scripts/shBrushCss.js'/>
<script language='javascript' src='http://syntaxhighlighter.googlecode.com/svn/trunk/Scripts/shBrushJScript.js'/> - Juste avant la balise </body>, copier le code suivant qui permet d'initialiser le composant. Il doit se trouver à la fin car le DOM doit être complètement chargé pour pouvoir le détecter.
<script language="javascript">
dp.SyntaxHighlighter.BloggerMode();
dp.SyntaxHighlighter.HighlightAll('code');
</script> - Comme je n'ai pas réussi à lier la feuille de style CSS par une balise <link> pour que ça fonctionne avec Firefox, il m'a fallu ouvrir le fichier http://syntaxhighlighter.googlecode.com/svn/trunk/Styles/SyntaxHighlighter.css et copier le code CSS et le coller avant la ligne ]]></b:skin>. Le mieux est de le placer à la fin des CSS définis par Blogger sinon la taille du texte sera changée (dans mon cas, le texte avait considérablement grossit).
- Placer le code source entre la balise suivante. Prenez soin d'indiquer dans l'attribut "class" le langage à colorer :
<pre name="code" class="PHP">code à placer ici</pre> - Vous devriez voir l'exemple ci-dessous avec la coloration syntaxique :
$var = 1;
if ($var == 1) {
echo 'OK';
}
je cherchai depuis un bout de temps un script php et GeSHi semble etre le bon puisque je disposerais d'un espace ftp perso.
RépondreEffacerMerci :)
Merci pour la solution, je commençait à me dire que blogger c'était pas top pour poster mon code :)
RépondreEffacerExcellent exemple. A quand ce genre de fonctions en standard sur Blogger (et autres moteurs de blogs) !
RépondreEffacerMerci pour l'astuce. 5 min montre en main pour le mettre en service.
RépondreEffacerMerci beaucoup ;)
RépondreEffacerIndispensable astuce ! 20/20
Excellent ! Je peux dorénavant m'en servir pour mon propre blog. Merci beaucoup pour cette contribution !
RépondreEffacerMerci !
RépondreEffacerSuper et indispensable !
Je me suis permis de citer cet article sur mon blog, juste sous mon insertion de code.
Si vous voulez voir un exemple en python: http://funwitharduino.blogspot.com/2011/12/domotique-temperature-thermostat-on-www.html