Carnet Wiki

Erreurs du parseur SPIP

Version 10 — Novembre 2014 — Nicolas Hoizey

Erreurs du lexer ou du parser SPIP, non détection d’erreur, erreurs d’interprétation du source par spip, en amont de l’exécution.

1) Erreurs SPIP2.1 ( à tester SPIP3 )

SPIP3}

  • JLuc : Il semble y avoir un problème dans :
    #SET{tel,[(#TEL|oui) £pucetel£ #TEL]}
    #SET{web,[(#WEB|oui) web £puceweb£  #WEB]}
    #SET{mel,[(#WEB|non) [(#EMAIL|oui) mel £pucemel£  #EMAIL]]}
    	

    Le résultat n’est pas bon.

Erreurs non détectées

Les erreurs suivantes ne sont pas détectées ni signalées.
C’est probablement difficile à changer car tout ce qui n’est pas compris comme code SPIP est compris comme texte. Faudrait il que SPIP détecte « ce qui ressemble presque à un code mais n’en est pas un » pour le signaler et inviter à vérifier si c’est ya en fait une erreur dans ce qui devrait être un code ?

  • JLuc : Dans <INCLURE{fond=sla/main_head_fin.sla}}/> aucune erreur n’est signalée mais ça comprend pas ce qu’il faut (il y a un } en trop à la fin).
    Indice : SPIP pourrait signaler l’erreur vu qu’il y a <INCLURE au début
  • JLuc : [avant (#VAL{arg}|unfiltre|#NOM_SITE_SPIP) après]] aucune erreur signalée mais il manque un |sinon. SPIP pourrait éventuellement détecter que le résultat est ignoré et remplacé par une constante et présumer qu’il y a une erreur ?
  • JLuc :[(#BALISE|filtre{texte1,texte2})] pose problème si il y a des virgules dans texte1 ou texte2 : cette virgule est considérée comme séparatrice des arguments du filtre. Même si on entoure les arguments avec #VAL{...}, le problème persiste.

2) Erreurs constatées dans SPIP3

Habon :

<blockquote class="spip">

#ID_ANNONCE n’est pas interprété :

#URL_ACTION_AUTEUR{
                ajouter_lien,
              annonce-#ID_ANNONCE-auteur-#SESSION{id_auteur}-candidater,
                #SELF}

#ID_ANNONCE est interprété :

#URL_ACTION_AUTEUR{
               ajouter_lien,
               auteur-#SESSION{id_auteur}-annonce-#ID_ANNONCE-candidater,
               #SELF},
               '

Si le #SESSION{id_auteur} est un #NOM,#ID_ANNONCE est bien interprété. On dirait donc que c’est les arguments des balises :
-  2 balises avec des arguments, c’est bon.
-  2 balises sans arguments, c’est bon.
-  Mais une balise avec et une balise sans, c’est pas bon.

Astuce trouvée : remplacer mon #ID_ANNONCE par un #ENV{id_annonce}, mais ça marche pas avec tous les contextes.

</blockquote>

Rq sur ce dernier signalement : C’est une difficulté pour le créateur de squelette SPIP, mais cette difficulté ne peut elles pas être normalement contournées en utilisant la syntaxe complète des balises, à savoir avec les crochets + parenthèses ?
Normalement, c’est possible. Mais permettre l’écriture sans crochets parenthèses faciliterait l’écriture.