Carnet Wiki

Erreurs du parseur SPIP

Version 13 — December 2014 JLuc

1 ) Erreurs du lexer ou du parser SPIP 2 ou 3 2 ) Erreurs non détectées , non signalées détection d’erreur, erreurs d’interprétation du source par spip , en amont de l’exécution .

1) Erreurs SPIP2.1 et SPIP3)

  • JLuc : les codes suivants provoquent une erreur du compilateur :
    #SET{tel,[(#TEL|oui) telephone #TEL]}
    #SET{web,[(#WEB|oui) web #WEB]}
    #SET{mel,[(#WEB|non) [(#EMAIL|oui) mel #EMAIL]]}
            

    Le résultat n’est pas bon.
    L’erreur affichée est “Argument manquant dans la balise SET”.

_
-----------------------------------------

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.


Erreurs de syntaxes non signalées

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.