<?xml
version="1.0" encoding="utf-8"?>
<rss version="2.0" 
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:atom="http://www.w3.org/2005/Atom"
>

<channel xml:lang="fr">
	<title>Geekographie Ma&#239;eulesque</title>
	<link>https://geekographie.maieul.net/</link>
	<description>Ce site est consacr&#233; &#224; quelques unes des mes geekeries. J'y donne des conseils, des r&#233;flexions, sur les logiciels et les langages que je connais ou que j'apprends.
J'y parle notamment de l'usage de LaTeX en sciences humaines et sociales, en particulier pour la gestion de la bibliographie.
Le contenu peut &#234;tre sous la forme d'articles d&#233;taill&#233;s ou de simples notes.
L'ensemble du contenu est, sauf pr&#233;cision contraire, sous licence Cr&#233;ative Commons Paternit&#233;-Partage des Conditions Initiales &#224; l'identique France.</description>
	<language>fr</language>
	<generator>SPIP - www.spip.net</generator>
	<atom:link href="https://geekographie.maieul.net/spip.php?id_rubrique=8&amp;page=backend" rel="self" type="application/rss+xml" />




<item xml:lang="fr">
		<title>G&#233;rer le statut des articles directement depuis le site public sous SPIP 3</title>
		<link>https://geekographie.maieul.net/97</link>
		<guid isPermaLink="true">https://geekographie.maieul.net/97</guid>
		<dc:date>2012-08-12T19:43:32Z</dc:date>
		<dc:format>text/html</dc:format>
		<dc:language>fr</dc:language>
		<dc:creator>Ma&#239;eul</dc:creator>



		<description>
&lt;p&gt;J'avais publi&#233; il y a plus d'un an et demi un article sur la mani&#232;re de g&#233;rer directement le statut des articles depuis le site public. Voici son adaptation pour &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; 3. Comme vous pourrez le voir, le code est beaucoup plus simple. Il suffit en effet de mettre dans son squelette, dans la boucle (&lt;span class=&#034;caps&#034;&gt;ARTICLES&lt;/span&gt;)&#160;: [(#AUTORISERpublier,article,#ID_ARTICLE|oui) #FORMULAIRE_INSTITUER_OBJETarticle,#ID_ARTICLE,#&lt;span class=&#034;caps&#034;&gt;SELF&lt;/span&gt;|parametre_urlvar_mode,preview ] L. 1 et 3&#160;: On v&#233;rifie que la personne connect&#233;e&#160;(&#8230;)&lt;/p&gt;


-
&lt;a href="https://geekographie.maieul.net/Formulaires" rel="directory"&gt;Formulaires&lt;/a&gt;


		</description>


 <content:encoded>&lt;div class='rss_chapo'&gt;&lt;p&gt;J'avais publi&#233; il y a plus d'un an et demi un article sur la mani&#232;re de &lt;a href='https://geekographie.maieul.net/10' class=&#034;spip_in&#034;&gt;g&#233;rer directement le statut des articles depuis le site public&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;Voici son adaptation pour &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; 3. Comme vous pourrez le voir, le code est beaucoup plus simple.&lt;/p&gt;&lt;/div&gt;
		&lt;div class='rss_texte'&gt;&lt;p&gt;Il suffit en effet de mettre dans son squelette, dans la boucle &lt;code&gt;(ARTICLES)&lt;/code&gt;&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;[(#AUTORISER{publier,article,#ID_ARTICLE}|oui)
#FORMULAIRE_INSTITUER_OBJET{article,#ID_ARTICLE,#SELF|parametre_url{var_mode,preview}}
]&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;ul class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; L. 1 et 3&#160;: On v&#233;rifie que la personne connect&#233;e &#224; bien le droit de publier l'article en question. Voir la documentation sur &lt;a href=&#034;http://programmer.spip.net/La-balise-AUTORISER&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;&lt;code&gt;#AUTORISER&lt;/code&gt;&lt;/a&gt;.&lt;/li&gt;&lt;li&gt; L. 2&#160;: appel du formulaire permettant de changer le statut d'un objet. Ici on pr&#233;cise que l'on veut pouvoir modifier le statut d'un article, dont l'identifiant est &lt;code&gt;#ID_ARTICLE&lt;/code&gt; Le troisi&#232;me argument &lt;code&gt;SELF|parametre_url{var_mode,preview}&lt;/code&gt; sert &#224; ne pas tomber sur une erreur 404 si on d&#233;publie l'article&#160;: il indique qu'apr&#232;s l'ex&#233;cution du formulaire on retourne sur la m&#234;me page, en mode &lt;code&gt;previsualisation&lt;/code&gt;&lt;span class=&#034;spip_note_ref&#034;&gt; [&lt;a href=&#034;#nb1&#034; class=&#034;spip_note&#034; rel=&#034;appendix&#034; title=&#034;Attention, cela ne fonctionne pas si l'on passe le statut &#224; &#171;&#160;refus&#233;&#160;&#187; ou &#171; (&#8230;)&#034; id=&#034;nh1&#034;&gt;1&lt;/a&gt;]&lt;/span&gt;.&lt;/li&gt;&lt;/ul&gt;&lt;/div&gt;
		&lt;hr /&gt;
		&lt;div class='rss_notes'&gt;&lt;div id=&#034;nb1&#034;&gt;
&lt;p&gt;&lt;span class=&#034;spip_note_ref&#034;&gt;[&lt;a href=&#034;#nh1&#034; class=&#034;spip_note&#034; title=&#034;Notes 1&#034; rev=&#034;appendix&#034;&gt;1&lt;/a&gt;] &lt;/span&gt;Attention, cela ne fonctionne pas si l'on passe le statut &#224; &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;refus&#233;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187; ou &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#224; la poubelle&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187;.&lt;/p&gt;
&lt;/div&gt;&lt;/div&gt;
		</content:encoded>


		

	</item>
<item xml:lang="fr">
		<title>Les diff&#233;rents modes d'inclusion de SPIP</title>
		<link>https://geekographie.maieul.net/81</link>
		<guid isPermaLink="true">https://geekographie.maieul.net/81</guid>
		<dc:date>2012-01-26T10:25:35Z</dc:date>
		<dc:format>text/html</dc:format>
		<dc:language>fr</dc:language>
		<dc:creator>Ma&#239;eul</dc:creator>



		<description>
&lt;p&gt;Suite &#224; une remarque de Tetue apr&#232;s mon article sur les pratiques de d&#233;veloppements avec &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; et &#224; une question d'un th&#233;ologien sur twitter, je fais ici un point sur les deux modes d'inclusion de squelettes dans &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;. Rappel&#160;: principe de l'inclusion Inclure un squelette A dans un squelette B, c'est dire &#224; B de reprendre le contenu du squelette A &#224; l'endroit de l'inclusion. L'inter&#234;t d'une telle pratique est de mettre en commun des morceaux de codes utilis&#233;s par plusieurs squelettes.&#160;(&#8230;)&lt;/p&gt;


-
&lt;a href="https://geekographie.maieul.net/Organisation-du-code-17" rel="directory"&gt;Organisation du code&lt;/a&gt;


		</description>


 <content:encoded>&lt;div class='rss_chapo'&gt;&lt;p&gt;Suite &#224; une &lt;a href='https://geekographie.maieul.net/77#comment113' class=&#034;spip_in&#034;&gt;remarque de Tetue apr&#232;s mon article sur les pratiques de d&#233;veloppements avec &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;&lt;/a&gt; et &#224; une &lt;a href=&#034;https://twitter.com/#!/NicolasFriedli/status/161470949072441345&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;question d'un th&#233;ologien sur twitter&lt;/a&gt;, je fais ici un point sur les deux modes d'inclusion de squelettes dans &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;.&lt;/p&gt;&lt;/div&gt;
		&lt;div class='rss_texte'&gt;&lt;h2 class=&#034;h2&#034;&gt;Rappel&#160;: principe de l'inclusion&lt;/h2&gt;
&lt;p&gt;Inclure un squelette A dans un squelette B, c'est dire &#224; B de reprendre le contenu du squelette A &#224; l'endroit de l'inclusion.&lt;/p&gt;
&lt;p&gt;L'inter&#234;t d'une telle pratique est de mettre en commun des morceaux de codes utilis&#233;s par plusieurs squelettes. Le cas le plus classique &#233;tant l'affichage du menu, mais plus le temps passe, plus le devellopeur &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; aguerri aura tendance &#224; multiplier les inclusions, voyant qu'il utilise beaucoup de code en commun.&lt;/p&gt;
&lt;p&gt;Le &lt;a href=&#034;http://www.spip-contrib.net/Modele-de-squelette-reutilisable&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;principe des squelettes Z&lt;/a&gt; pousse &#224; l'extr&#234;me cette id&#233;e d'inclusion / mutualisation du code.&lt;/p&gt;
&lt;p&gt;Mais attention&#160;: il ne faut pas croire qu'on imite ainsi un &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;copier-coller&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187; de B dans A.&lt;/p&gt;
&lt;p&gt;Ainsi si je met dans le squelette A&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;XXX&lt;INCLURE{fond=B}&gt;XXX&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;et dans le squelette B&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;YYY&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Cela &lt;strong&gt;ne revient pas au m&#234;me&lt;/strong&gt; que mettre dans A&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;XXXYYYXXX&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Pourquoi&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;? Parce qu'il faut consid&#233;rer que le contexte de chaque squelette est ind&#233;pendant. Par contexte, j'entend l'ensemble des param&#232;tres techniques qui lui sont pass&#233;s, par exemple un num&#233;ro d'article. Ce contexte est r&#233;cup&#233;rable via la balise &lt;code&gt;#ENV&lt;/code&gt; et sert &#224; l'interpr&#233;tation des crit&#232;res de boucles de premier niveaux. J'explique plus en d&#233;tails &lt;a href=&#034;http://www.spip-contrib.net/La-balise-ENV&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;cette notion de contexte dans un article sur contrib&lt;/a&gt;.&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;&lt;code&gt;&lt;INCLURE&gt;&lt;/code&gt; ou &lt;code&gt;#INCLURE&lt;/code&gt;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;?&lt;/h2&gt;
&lt;p&gt;Il existe deux modes principaux d'inclusion&#160;:&lt;/p&gt;
&lt;ol class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; &lt;a href=&#034;http://programmer.spip.org/Inclure-des-squelettes&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;&lt;code&gt;&lt;INCLURE{fond=B}&gt;&lt;/code&gt;&lt;/a&gt;&lt;/li&gt;&lt;li&gt; &lt;a href=&#034;http://programmer.spip.org/INCLURE&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;&lt;code&gt;#INCLURE{fond=B}&lt;/code&gt;&lt;/a&gt;&lt;/li&gt;&lt;/ol&gt;
&lt;p&gt;Historiquement, le premier mod&#232;le est apparu d'abord. Quelle est la diff&#233;rence technique entre les deux&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;? Soit un squelette A appelant un squelette B.&lt;/p&gt;
&lt;ol class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; Dans le cas d'une inclusion avec &lt;code&gt;INCLURE&lt;/code&gt; le squelette B poss&#232;de son propre cache. Lorsque le squelette A est appel&#233;, il produit son cache &#224; lui. Le r&#233;sultat du cache de A est retourn&#233; au navigateur, et c'est &#224; ce moment l&#224; que le cache du squelette B est ins&#233;r&#233;.&lt;/li&gt;&lt;li&gt; Dans le cas d'une inclusion avec &lt;code&gt;#INCLURE&lt;/code&gt;, il n'existe pas de cache du squelette &lt;code&gt;B&lt;/code&gt;. Le morceau de &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; / &lt;span class=&#034;caps&#034;&gt;HTML&lt;/span&gt; li&#233; &#224; l'interpr&#233;tation par &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; du squelette B est mis directement dans le cache du squelette A.&lt;/li&gt;&lt;/ol&gt;
&lt;p&gt;Puisqu'il para&#238;t qu'il faut mettre des sch&#233;mas, voici un sch&#233;ma qui tente d'expliquer cette diff&#233;rence&lt;span class=&#034;spip_note_ref&#034;&gt; [&lt;a href=&#034;#nb2-1&#034; class=&#034;spip_note&#034; rel=&#034;appendix&#034; title=&#034;Toute suggestion d'am&#233;lioration est la bienvenue.&#034; id=&#034;nh2-1&#034;&gt;1&lt;/a&gt;]&lt;/span&gt;.&lt;/p&gt;
&lt;div class='spip_document_47 spip_document spip_documents spip_document_image spip_documents_center spip_document_center spip_document_avec_legende' data-legende-len=&#034;75&#034; data-legende-lenx=&#034;xx&#034;
&gt;
&lt;figure class=&#034;spip_doc_inner&#034;&gt; &lt;img src='https://geekographie.maieul.net/local/cache-vignettes/L356xH513/inclusion-16b75.png?1760449034' width='356' height='513' alt='' /&gt;
&lt;figcaption class='spip_doc_legende'&gt; &lt;div class='spip_doc_titre crayon document-titre-47 '&gt;&lt;strong&gt;&lt;code&gt;&lt;INCLURE&gt;&lt;/code&gt; ou &lt;code&gt;#INCLURE&lt;/code&gt;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;?
&lt;/strong&gt;&lt;/div&gt; &lt;div class='spip_doc_descriptif crayon document-descriptif-47 '&gt;Inclusion statique ou inclusion dynamique&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;?
&lt;/div&gt; &lt;/figcaption&gt;&lt;/figure&gt;
&lt;/div&gt;&lt;h2 class=&#034;h2&#034;&gt;Cons&#233;quences techniques&lt;/h2&gt;&lt;ol class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; Du point de vue de la taille des caches&#160;:
&lt;ol class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; &lt;code&gt;&lt;INCLURE&gt;&lt;/code&gt; produit plus de fichiers de cache, mais moins gros.&lt;/li&gt;&lt;li&gt; &lt;code&gt;#INCLURE&lt;/code&gt; produit des fichiers de cache plus gros, mais en moindre quantit&#233;.&lt;/li&gt;&lt;/ol&gt;&lt;/li&gt;&lt;li&gt; Du point de vue de la dur&#233;e des caches&#160;:
&lt;ol class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt;&lt;code&gt;&lt;INCLURE&gt;&lt;/code&gt; permet d'avoir un squelette fils n'ayant pas la m&#234;me dur&#233;e de cache que le squelette p&#232;re.&lt;/li&gt;&lt;li&gt; &lt;code&gt;#INCLURE&lt;/code&gt; ne permet pas cela, puisque le squelette fils n'a pas vraiment de cache propre.&lt;/li&gt;&lt;/ol&gt;&lt;/li&gt;&lt;li&gt; Du point de vue des techniques &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; applicables&#160;:
&lt;ol class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; On peut pas filtrer le r&#233;sultat d'une inclusion par &lt;code&gt;&lt;INCLURE&gt;&lt;/code&gt;&lt;span class=&#034;spip_note_ref&#034;&gt; [&lt;a href=&#034;#nb2-2&#034; class=&#034;spip_note&#034; rel=&#034;appendix&#034; title=&#034;Une solution pour contourner ce probl&#232;me est de mettre dans le squelette (&#8230;)&#034; id=&#034;nh2-2&#034;&gt;2&lt;/a&gt;]&lt;/span&gt;.&lt;/li&gt;&lt;li&gt; Par contre avec &lt;code&gt;#INCLURE&lt;/code&gt; on peut appliquer un filtre &lt;code&gt;[(#INCLURE{fond=B}|filtre)]&lt;/code&gt;.&lt;/li&gt;&lt;li&gt; Dans tout les cas on peut utiliser &lt;span class=&#034;caps&#034;&gt;AJAX&lt;/span&gt;.&lt;/li&gt;&lt;/ol&gt;&lt;/li&gt;&lt;li&gt; Du point de vue de la performance j'avoue ne pas trop savoir. Avoir un cache propre (&lt;code&gt;&lt;INCLURE&gt;&lt;/code&gt;) permet d'avoir une vrai mutualisation des caches, dont un gain en terme de requ&#234;te &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt;, en revanche on a une perte de temps au moment o&#249; le cache de B est &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;reinject&#233;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187; dans le fichier A renvoy&#233; &#224; l'internaute. C'est donc au d&#233;veloppeur de juger au cas par cas, mais il me semble que dans 90&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;% des cas, il vaut mieux utiliser &lt;code&gt;&lt;INCLURE&gt;&lt;/code&gt;.&lt;/li&gt;&lt;/ol&gt;&lt;h2 class=&#034;h2&#034;&gt;Et &lt;code&gt;#MODELE&lt;/code&gt;&lt;/h2&gt;
&lt;p&gt;On peut aussi utiliser &lt;a href=&#034;http://programmer.spip.org/MODELE&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;&lt;code&gt;#MODELE&lt;/code&gt;&lt;/a&gt;. Pour ce faire, il faut que le fichier inclu se situe dans le dossier &lt;code&gt;modeles&lt;/code&gt;.&lt;/p&gt;
&lt;p&gt;Techniquement, faire&lt;/p&gt;
&lt;p&gt;&lt;code&gt;#MODELE{B}&lt;/code&gt;&lt;/p&gt;
&lt;p&gt;revient, &#224; peu de chose pr&#232;s, &#224; la m&#234;me chose que faire &lt;code&gt;#INCLURE{fond=modeles/B}&lt;/code&gt;. Une diff&#233;rence toutefois&#160;: dans le cas de &lt;code&gt;#MODELE&lt;/code&gt; l'identifiant de l'objet courant est automatiquement pass&#233; en param&#232;tre.&lt;/p&gt;
&lt;p&gt;Exemple, j'ai un squelette &lt;code&gt;modeles/B.html&lt;/code&gt;&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;BOUCLE_article(ARTICLES){id_article}&gt; #ID_ARTICLE #TITRE &lt;/BOUCLE_article&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Dans mon squelette A, je cherche &#224; appeler ce squelette pour tout les articles d'une rubrique.&lt;/p&gt;
&lt;p&gt;Je peux faire soit&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;BOUCLE_articles(ARTICLES){id_rubrique}&gt; #MODELE{B} &lt;/BOUCLE_articles&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;soit&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;BOUCLE_articles(ARTICLES){id_rubrique}&gt; #INCLURE{fond=modeles/B,id_article} &lt;/BOUCLE_articles&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Personnellement je n'aime pas trop &lt;code&gt;#MODELE&lt;/code&gt;, je trouve qu'il induit une confusion. Le seul cas o&#249; l'emploi de mod&#232;le est justifiable, c'est lorsque l'on souhaite permettre &#224; un auteur d'inclure un tel morceau dans son article, en utilisant&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;'&gt;&lt;code&gt;&lt;B|id_article=xxx&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Par exemple &lt;a href=&#034;http://www.spip-contrib.net/Gravatar&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;le plugin Gravatar&lt;/a&gt; propose un mod&#232;le &lt;code&gt;gravatar&lt;/code&gt;, que l'on peut appeler&#160;:&lt;/p&gt;
&lt;ol class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; soit dans un squelette &lt;code&gt;#MODELE{gravatar}{id_auteur}&lt;/code&gt;.&lt;/li&gt;&lt;li&gt; soit dans un article &lt;code&gt;&lt;gravatar|id_auteur=42&gt;&lt;/code&gt;.&lt;/li&gt;&lt;/ol&gt;
&lt;p&gt;On consultera &lt;a href=&#034;http://www.spip.net/fr_article3454.html&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;la documentation sur les mod&#232;les&lt;/a&gt; pour plus de d&#233;tails.&lt;/p&gt;&lt;/div&gt;
		&lt;hr /&gt;
		&lt;div &lt;div class='rss_ps'&gt;&lt;p&gt;Pour aider &#224; y voir plus clair dans les diff&#233;rents squelettes inclus, &lt;a href=&#034;http://www.spip.net/fr_article4453.html#var_mode_inclure&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;on utilisera la fonction &lt;code&gt;var_mode=inclure&lt;/code&gt;&lt;/a&gt;.&lt;/p&gt;&lt;/div&gt;
		&lt;hr /&gt;
		&lt;div class='rss_notes'&gt;&lt;div id=&#034;nb2-1&#034;&gt;
&lt;p&gt;&lt;span class=&#034;spip_note_ref&#034;&gt;[&lt;a href=&#034;#nh2-1&#034; class=&#034;spip_note&#034; title=&#034;Notes 2-1&#034; rev=&#034;appendix&#034;&gt;1&lt;/a&gt;] &lt;/span&gt;Toute suggestion d'am&#233;lioration est la bienvenue.&lt;/p&gt;
&lt;/div&gt;&lt;div id=&#034;nb2-2&#034;&gt;
&lt;p&gt;&lt;span class=&#034;spip_note_ref&#034;&gt;[&lt;a href=&#034;#nh2-2&#034; class=&#034;spip_note&#034; title=&#034;Notes 2-2&#034; rev=&#034;appendix&#034;&gt;2&lt;/a&gt;] &lt;/span&gt;Une solution pour contourner ce probl&#232;me est de mettre &lt;code&gt;#FILTRE{nom du filtre}&lt;/code&gt; dans le squelette inclus.&lt;/p&gt;
&lt;/div&gt;&lt;/div&gt;
		</content:encoded>


		

	</item>
<item xml:lang="fr">
		<title>Sept bonnes pratiques de d&#233;veloppement avec SPIP</title>
		<link>https://geekographie.maieul.net/77</link>
		<guid isPermaLink="true">https://geekographie.maieul.net/77</guid>
		<dc:date>2012-01-05T00:39:57Z</dc:date>
		<dc:format>text/html</dc:format>
		<dc:language>fr</dc:language>
		<dc:creator>Ma&#239;eul</dc:creator>



		<description>
&lt;p&gt;Je travaille en ce moment sur un squelette qui n'est pas de moi. Il semble que la personne qui l'a cr&#233;&#233; n'&#233;tait pas au courant des bonnes pratiques de d&#233;veloppement sous &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;. Il est vrai que ces bonnes pratiques ne sont pas n&#233;cessairement accessibles aux premiers abords de la documentation webmaster de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;. Voici sept r&#232;gles que je juge indispensables 1. Ne pas mettre de &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; dans les squelettes Le but de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; &#233;tait de permettre de ne pas avoir &#224; conna&#238;tre le &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; pour concevoir un&#160;(&#8230;)&lt;/p&gt;


-
&lt;a href="https://geekographie.maieul.net/Organisation-du-code-17" rel="directory"&gt;Organisation du code&lt;/a&gt;


		</description>


 <content:encoded>&lt;div class='rss_chapo'&gt;&lt;p&gt;Je travaille en ce moment sur un squelette qui n'est pas de moi. Il semble que la personne qui l'a cr&#233;&#233; n'&#233;tait pas au courant des bonnes pratiques de d&#233;veloppement sous &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;. Il est vrai que ces bonnes pratiques ne sont pas n&#233;cessairement accessibles aux premiers abords de la documentation webmaster de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;.&lt;/p&gt;
&lt;p&gt;Voici sept r&#232;gles que je juge indispensables&lt;/p&gt;&lt;/div&gt;
		&lt;div class='rss_texte'&gt;&lt;h2 class=&#034;h2&#034;&gt;1. Ne pas mettre de &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; dans les squelettes&lt;/h2&gt;
&lt;p&gt;Le but de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; &#233;tait de permettre de ne pas avoir &#224; conna&#238;tre le &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; pour concevoir un site. Tout un syst&#232;me sp&#233;cifique a &#233;t&#233; pr&#233;vu, pour faire des requ&#234;tes &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt;, mais aussi des tests. C'est parfois perturbant pour les utilisateurs venant du monde &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt;.&lt;/p&gt;
&lt;p&gt;Mais pour autant, c'est une &lt;a href='https://geekographie.maieul.net/13' class=&#034;spip_in&#034;&gt;tr&#232;s bonne pratique de ne quasiment-jamais mettre de &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; dans un squelette&lt;/a&gt;. En r&#233;alit&#233;, c'est une mauvaise pratique d'en mettre.&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;2. Ne rien mettre dans le dossier &lt;span class=&#034;caps&#034;&gt;IMG&lt;/span&gt;&lt;/h2&gt;
&lt;p&gt;Le dossier &lt;span class=&#034;caps&#034;&gt;IMG&lt;/span&gt; ne doit contenir que les images et documents ajout&#233;s par l'utilisateur depuis l'interface priv&#233;. En aucun cas il ne doit contenir des images propres aux squelettes, qui doivent se trouver dans le m&#234;me dossier que les squelettes.&lt;/p&gt;
&lt;p&gt;Choisir de mettre les images dans &lt;span class=&#034;caps&#034;&gt;IMG&lt;/span&gt; (comme je l'ai vu dans ce squelette), c'est compliquer les r&#233;utilisations des squelettes, et m&#233;langer les couches utilisateurs et webmestres de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;.&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;3. Utiliser &lt;code&gt;#CHEMIN&lt;/code&gt;&lt;/h2&gt;
&lt;p&gt;La balise &lt;code&gt;#CHEMIN&lt;/code&gt; est une balise indispensable de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;. Elle permet d'indiquer l'adresse d'un fichier sans se pr&#233;occuper du nom du dossier parent. En effet, &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; va cherche le fichier pass&#233; en argument dans l'ordre suivant&lt;span class=&#034;spip_note_ref&#034;&gt; [&lt;a href=&#034;#nb3-1&#034; class=&#034;spip_note&#034; rel=&#034;appendix&#034; title=&#034;Liste tir&#233;e du site Programmer avec SPIP.&#034; id=&#034;nh3-1&#034;&gt;1&lt;/a&gt;]&lt;/span&gt;&#160;:&lt;/p&gt;
&lt;ul class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; squelettes&lt;/li&gt;&lt;li&gt; plugin B d&#233;pendant du plugin A&lt;/li&gt;&lt;li&gt; plugin A&lt;/li&gt;&lt;li&gt; squelettes-dist&lt;/li&gt;&lt;li&gt; prive&lt;/li&gt;&lt;li&gt; ecrire&lt;/li&gt;&lt;/ul&gt;
&lt;p&gt;Exemple&#160;: j'ai une image dans le dossier &lt;code&gt;squelettes&lt;/code&gt;, je ne fais pas&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='html'&gt;&lt;code&gt;&lt;img src='squelettes/toto.png' /&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;mais bien&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;img src='#CHEMIN{toto.png}' /&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;mieux, je met mon image &lt;code&gt;toto.png&lt;/code&gt; dans le dossier &lt;code&gt;img&lt;/code&gt; du dossier &lt;code&gt;squelettes&lt;/code&gt;.&lt;/p&gt;
&lt;p&gt;Je peux alors faire&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;img src='#CHEMIN{img/toto.png}' /&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;L'avantage d'un tel syst&#232;me est &#233;vident&#160;: permettre d'avoir un dossier squelettes qui ne s'appelle pas squelettes, par exemple lorsqu'on utilise &lt;a href=&#034;#plugin&#034; class=&#034;spip_ancre&#034;&gt;ma sixi&#232;me recommandation&#160;: les squelettes sous forme de plugins&lt;/a&gt;. Mais aussi permettre &#224; &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; de g&#233;rer correctement les &lt;span class=&#034;caps&#034;&gt;URLS&lt;/span&gt; arborescentes (le cas &#233;ch&#233;ant).&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;4. Utiliser &lt;code&gt;|balise_img&lt;/code&gt;&lt;/h2&gt;
&lt;p&gt;Il est recommand&#233; lorsqu'on ins&#232;re une balise &lt;code&gt;&lt;img&gt;&lt;/code&gt; de lui mettre des attributs &lt;code&gt;height&lt;/code&gt; et &lt;code&gt;with&lt;/code&gt; pour am&#233;liorer les performances du navigateur lors de l'affichage de la page.&lt;/p&gt;
&lt;p&gt;On peut bien s&#251;r indiquer cela manuellement&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;img src='#CHEMIN{toto.png}' width='largeur' height='hauteur' /&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Mais supposons que je r&#233;duise la taille de &lt;code&gt;toto.png&lt;/code&gt;&#160;: je dois dans ce cas modifier les attributs &lt;code&gt;height&lt;/code&gt; et &lt;code&gt;width&lt;/code&gt; &#224; chaque fois que je l'utilise.&lt;/p&gt;
&lt;p&gt;Pour &#233;viter cela, &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; pr&#233;voit le filtre &lt;code&gt;|balise_img&lt;/code&gt; qui, lorsqu'il est appliqu&#233; au chemin d'un fichier image, cr&#233;e automatiquement la balise &lt;code&gt;&lt;img&gt;&lt;/code&gt;, avec la hauteur et la largeur du fichier. Ainsi, pas besoin de corriger si on r&#233;duit la taille du fichier.&lt;/p&gt;
&lt;p&gt;Le filtre s'utilise de mani&#232;re tr&#232;s simple&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;[(#CHEMIN{toto.png}|balise_img)]&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;On peut m&#234;me mettre en argument le contenu de l'attribut &lt;code&gt;alt&lt;/code&gt;&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;[(#CHEMIN{toto.png}|balise_img{0+0})]&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Voir en deuxi&#232;me argument la valeur de l'attribut &lt;code&gt;class&lt;/code&gt;&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;[(#CHEMIN{toto.png}|balise_img{0+0,blague_pour_enfants})]&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Ce code au final me produit&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='html'&gt;&lt;code&gt;&lt;img src='squelettes/toto.png' width='largeur_du_fichier_toto.png' height='hauteur_du_fichier_toto.png' alt='0+0' class='blague_pour_enfants' /&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h2 class=&#034;h2&#034;&gt;5. Utiliser les cha&#238;nes de langues&lt;/h2&gt;
&lt;p&gt;Bien que cela puisse para&#238;tre inutile et fastidieux pour un site monolingue, &lt;a href=&#034;http://programmer.spip.org/-Elements-linguistiques-&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;utiliser les cha&#238;nes de langue&lt;/a&gt; est quand m&#234;me utile pour trois raisons&#160;:&lt;/p&gt;
&lt;ul class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; on ne sait jamais&#160;: si le site devient multilingue, c'est toujours cela de fait.&lt;/li&gt;&lt;li&gt; il est plus facile d'uniformiser les textes.&lt;/li&gt;&lt;li&gt; il est plus facile de corriger en cas de faute ou de changement d'avis.&lt;/li&gt;&lt;/ul&gt;&lt;h2 class=&#034;h2&#034;&gt;6. Utiliser &lt;code&gt;&lt;INCLURE&gt;&lt;/code&gt;&lt;/h2&gt;
&lt;p&gt;C'est un principe de base de l'informatique&#160;: d&#232;s qu'une s&#233;quence d'instructions est utilis&#233;e plusieurs fois, il faut non pas la dupliquer, mais la mettre dans un morceau qu'on appelle plusieurs fois.&lt;/p&gt;
&lt;p&gt;En &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; ce morceau, c'est un &lt;a href=&#034;http://programmer.spip.org/Inclure-des-squelettes&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;fichier inclus&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;Typiquement supposons que j'affiche sur toutes les pages de mon site les sites amis.&lt;/p&gt;
&lt;p&gt;Au lieux de copier-coller le code suivant dans les squelettes&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;B&gt; &lt;ul&gt; &lt;BOUCLE_sites(SITES){par titre}&gt; &lt;li&gt;&lt;a href='#URL_SITE'&gt;#NOM&lt;/a&gt;&lt;/li&gt; &lt;/BOUCLE&gt; &lt;/ul&gt; &lt;/B&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Je le met dans un fichier &lt;code&gt;sites-amis.html&lt;/code&gt;, situ&#233; dans un dossier &lt;code&gt;inclure&lt;/code&gt; du dossier contenant les squelettes.&lt;/p&gt;
&lt;p&gt;Et je met le code suivant l&#224; o&#249; je souhaite afficher les sites amis&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;INCLURE{fond=inclure/sites-amis}&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Cela me permet si je dois modifier les crit&#232;res de cette liste de ne les modifier qu'&#224; un endroit&lt;span class=&#034;spip_note_ref&#034;&gt; [&lt;a href=&#034;#nb3-2&#034; class=&#034;spip_note&#034; rel=&#034;appendix&#034; title=&#034;En outre, cela diminue les requ&#234;tes SQL et donc la charge du serveur SQL, (&#8230;)&#034; id=&#034;nh3-2&#034;&gt;2&lt;/a&gt;]&lt;/span&gt;.&lt;/p&gt;
&lt;p&gt;La logique est donc&#160;: diviser son site en briques r&#233;utilisables. Chaque brique correspondant &#224; fichier et &#224; un morceau logique de page. Ensuite assembler ces briques dans des fichiers plus globaux&lt;span class=&#034;spip_note_ref&#034;&gt; [&lt;a href=&#034;#nb3-3&#034; class=&#034;spip_note&#034; rel=&#034;appendix&#034; title=&#034;Pour comprendre comment passer des param&#232;tres lors de ces inclusions, pour (&#8230;)&#034; id=&#034;nh3-3&#034;&gt;3&lt;/a&gt;]&lt;/span&gt;.&lt;/p&gt;
&lt;p&gt;&lt;a href=&#034;http://www.spip-contrib.net/Modele-de-squelette-reutilisable&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;Le mod&#232;le de squelettes Z pousse &#224; l'extr&#234;me cette logique des inclusions&lt;/a&gt;. Je conseille de le suivre&#160;: on gagne largement en maintenance ce qu'on perd en temps d'apprentissage initial.&lt;/p&gt;
&lt;p&gt;Une r&#232;gle importante dans les inclusions&#160;: les balises html qui s'ouvrent dans un fichier doivent se fermer dans le m&#234;me fichier. Il est tr&#232;s mauvais d'ouvrir une balise dans un fichier puis de la fermer dans un autre&#160;: on y est perd en lisibilit&#233; du code, et donc en maintenance&lt;span class=&#034;spip_note_ref&#034;&gt; [&lt;a href=&#034;#nb3-4&#034; class=&#034;spip_note&#034; rel=&#034;appendix&#034; title=&#034;J'ai cr&#251; &#224; un moment qu'une structure html &#233;tait incorrecte du fait qu'un (&#8230;)&#034; id=&#034;nh3-4&#034;&gt;4&lt;/a&gt;]&lt;/span&gt;.&lt;/p&gt;
&lt;p&gt;&lt;a id=&#034;plugin&#034;&gt;&lt;/a&gt;&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;7. Mettre ses squelettes sous formes de plugins&lt;/h2&gt;
&lt;p&gt;Cela peut para&#238;tre un luxe ou coquetterie, mais cela facilite &#233;norm&#233;ment le d&#233;ploiement d'un m&#234;me squelette sur plusieurs sites ou le d&#233;m&#233;nagement depuis la version locale vers la version en ligne&#160;:&lt;/p&gt;
&lt;ul class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; en indiquant les d&#233;pendances aux plugins.&lt;/li&gt;&lt;li&gt; en incluant le fichier &lt;code&gt;mes_options.php&lt;/code&gt; dans le m&#234;me dossier.&lt;/li&gt;&lt;li&gt; en permettant m&#234;me le cas &#233;ch&#233;ant d'ajouter automatiquement un contenu pr&#233;-d&#233;fini.&lt;/li&gt;&lt;/ul&gt;
&lt;p&gt;Un pr&#233;c&#233;dent article d&#233;taille &lt;a href='https://geekographie.maieul.net/3' class=&#034;spip_in&#034;&gt;comment fabriquer ces squelettes-plugins&lt;/a&gt;.&lt;/p&gt;&lt;/div&gt;
		&lt;hr /&gt;
		&lt;div &lt;div class='rss_ps'&gt;&lt;p&gt;Amis SPIPeurs, j'attends vos remarques et ajouts&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;!&lt;/p&gt;&lt;/div&gt;
		&lt;hr /&gt;
		&lt;div class='rss_notes'&gt;&lt;div id=&#034;nb3-1&#034;&gt;
&lt;p&gt;&lt;span class=&#034;spip_note_ref&#034;&gt;[&lt;a href=&#034;#nh3-1&#034; class=&#034;spip_note&#034; title=&#034;Notes 3-1&#034; rev=&#034;appendix&#034;&gt;1&lt;/a&gt;] &lt;/span&gt;&lt;a href=&#034;http://programmer.spip.org/La-notion-de-chemin&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;Liste tir&#233;e du site Programmer avec &lt;span class=&#034;caps&#034;&gt;&lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;&lt;/span&gt;&lt;/a&gt;.&lt;/p&gt;
&lt;/div&gt;&lt;div id=&#034;nb3-2&#034;&gt;
&lt;p&gt;&lt;span class=&#034;spip_note_ref&#034;&gt;[&lt;a href=&#034;#nh3-2&#034; class=&#034;spip_note&#034; title=&#034;Notes 3-2&#034; rev=&#034;appendix&#034;&gt;2&lt;/a&gt;] &lt;/span&gt;En outre, cela diminue les requ&#234;tes &lt;span class=&#034;caps&#034;&gt;&lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt;&lt;/span&gt; et donc la charge du serveur &lt;span class=&#034;caps&#034;&gt;&lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt;&lt;/span&gt;, mais la contrepartie est de multiplier les fichiers de caches ainsi que les inclusions &lt;span class=&#034;caps&#034;&gt;&lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt;&lt;/span&gt;.&lt;/p&gt;
&lt;/div&gt;&lt;div id=&#034;nb3-3&#034;&gt;
&lt;p&gt;&lt;span class=&#034;spip_note_ref&#034;&gt;[&lt;a href=&#034;#nh3-3&#034; class=&#034;spip_note&#034; title=&#034;Notes 3-3&#034; rev=&#034;appendix&#034;&gt;3&lt;/a&gt;] &lt;/span&gt;Pour comprendre comment passer des param&#232;tres lors de ces inclusions, pour par exemple conna&#238;tre l'article courant, &lt;a href=&#034;http://www.spip-contrib.net/La-balise-ENV&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;je renvoie &#224; mon article sur la balise #&lt;span class=&#034;caps&#034;&gt;&lt;span class=&#034;caps&#034;&gt;ENV&lt;/span&gt;&lt;/span&gt;&lt;/a&gt;. Cet article devrais &#234;tre mis &#224; jour pour parler des derni&#232;res nouveaut&#233;s. Mais l'essentiel est l&#224;.&lt;/p&gt;
&lt;/div&gt;&lt;div id=&#034;nb3-4&#034;&gt;
&lt;p&gt;&lt;span class=&#034;spip_note_ref&#034;&gt;[&lt;a href=&#034;#nh3-4&#034; class=&#034;spip_note&#034; title=&#034;Notes 3-4&#034; rev=&#034;appendix&#034;&gt;4&lt;/a&gt;] &lt;/span&gt;J'ai cr&#251; &#224; un moment qu'une structure html &#233;tait incorrecte du fait qu'un fichier avait plus de &lt;code&gt;&lt;div&gt;&lt;/code&gt; ouvrantes que fermantes. En r&#233;alit&#233;, le dernier &lt;code&gt;&lt;/div&gt;&lt;/code&gt; manquant se trouvait ailleurs.&lt;/p&gt;
&lt;/div&gt;&lt;/div&gt;
		</content:encoded>


		

	</item>
<item xml:lang="fr">
		<title>Notifications sur un forum plat</title>
		<link>https://geekographie.maieul.net/15</link>
		<guid isPermaLink="true">https://geekographie.maieul.net/15</guid>
		<dc:date>2010-12-17T10:17:40Z</dc:date>
		<dc:format>text/html</dc:format>
		<dc:language>fr</dc:language>
		<dc:creator>Ma&#239;eul</dc:creator>



		<description>
&lt;p&gt;Sur ce site j'utilise le plugin Notifications, pour que les personnes re&#231;oivent les r&#233;ponses &#224; leurs r&#233;actions. J'ai coch&#233; dans la configuration &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;Fil de discussion&#160;: les participants au m&#234;me fil de discussion re&#231;oivent les notifications des forums (publics).&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187;. Mais les personnes ne recevaient pas les notifications. Voil&#224; comment j'ai r&#233;solu le probl&#232;me. Le probl&#232;me, c'est que mes forums sont en mode plat. Donc il n'y a pas vraiment de fil de discussion, mais seulement des messages&#160;(&#8230;)&lt;/p&gt;


-
&lt;a href="https://geekographie.maieul.net/Plugin" rel="directory"&gt;Plugin&lt;/a&gt;


		</description>


 <content:encoded>&lt;div class='rss_chapo'&gt;&lt;p&gt;Sur ce site j'utilise le plugin &lt;a href=&#034;http://www.spip-contrib.net/Notifications,2360&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;Notifications&lt;/a&gt;, pour que les personnes re&#231;oivent les r&#233;ponses &#224; leurs r&#233;actions.&lt;/p&gt;
&lt;p&gt;J'ai coch&#233; dans la configuration &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;Fil de discussion&#160;: les participants au m&#234;me fil de discussion re&#231;oivent les notifications des forums (publics).&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187;. Mais les personnes ne recevaient pas les notifications. Voil&#224; comment j'ai r&#233;solu le probl&#232;me.&lt;/p&gt;&lt;/div&gt;
		&lt;div class='rss_texte'&gt;&lt;p&gt;Le probl&#232;me, c'est que mes forums sont en mode &lt;code&gt;{plat}&lt;/code&gt;&lt;span class=&#034;spip_note_ref&#034;&gt; [&lt;a href=&#034;#nb4-1&#034; class=&#034;spip_note&#034; rel=&#034;appendix&#034; title=&#034;En fait j'utilise le plugin de Romy&#160;: Comments, qui met ce mode&#034; id=&#034;nh4-1&#034;&gt;1&lt;/a&gt;]&lt;/span&gt;. Donc il n'y a pas vraiment de fil de discussion, mais seulement des messages individuels sans liens, du coup notification ne peut fonctionner.&lt;/p&gt;
&lt;p&gt;La solution est de s'arranger pour avoir un fil de discussion unique.&lt;/p&gt;
&lt;p&gt;Pour cela, j'appel de la mani&#232;re suivante le formulaire de r&#233;action&#160;:&lt;/p&gt;
&lt;div class='precode'&gt;&lt;pre dir='ltr' style='text-align: left;' class='spip'&gt;&lt;code&gt;&lt;BOUCLE_forum(FORUMS){!par date}{id_article}{0,1}&gt;
#FORMULAIRE_FORUM
&lt;/BOUCLE_forum&gt;
#FORMULAIRE_FORUM
&lt;//B_forum&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
&lt;p&gt;Ainsi, le message est syst&#233;matiquement post&#233; en r&#233;action au dernier message, et s'il n'y a pas de message, il est post&#233; directement en r&#233;action &#224; l'article, et un fil de discussion est ouvert.&lt;/p&gt;&lt;/div&gt;
		&lt;hr /&gt;
		&lt;div class='rss_notes'&gt;&lt;div id=&#034;nb4-1&#034;&gt;
&lt;p&gt;&lt;span class=&#034;spip_note_ref&#034;&gt;[&lt;a href=&#034;#nh4-1&#034; class=&#034;spip_note&#034; title=&#034;Notes 4-1&#034; rev=&#034;appendix&#034;&gt;1&lt;/a&gt;] &lt;/span&gt;En fait j'utilise le plugin de Romy&#160;: &lt;a href=&#034;http://www.spip-contrib.net/Comments-2-pour-SPIP-2&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;Comments&lt;/a&gt;, qui met ce mode &lt;code&gt;{plat}&lt;/code&gt;&lt;/p&gt;
&lt;/div&gt;&lt;/div&gt;
		</content:encoded>


		

	</item>
<item xml:lang="fr">
		<title>Pourquoi ne pas mettre de PHP dans un squelette, sauf exception</title>
		<link>https://geekographie.maieul.net/13</link>
		<guid isPermaLink="true">https://geekographie.maieul.net/13</guid>
		<dc:date>2010-12-10T00:16:19Z</dc:date>
		<dc:format>text/html</dc:format>
		<dc:language>fr</dc:language>
		<dc:creator>Ma&#239;eul</dc:creator>



		<description>
&lt;p&gt;Je tombe r&#233;guli&#232;rement sur des squelettes, faits par des gens venant du monde &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt;, qui sont pleins de &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt;. Voici quelques bonnes raisons de ne pas faire cela. Et puis aussi des pistes sur comment s'en passer. Raison 1&#160;: On ne profite pas du cache de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; dispose d'un syst&#232;me de cache, qui &#233;vite de refaire trop souvent des calculs, et donc acc&#233;l&#232;re les pages. Les parties &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; d'un squelette &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; ne sont pas soumis &#224; ce syst&#232;me, du coup on perd un des avantages de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;. Raison 2&#160;:&#160;(&#8230;)&lt;/p&gt;


-
&lt;a href="https://geekographie.maieul.net/Squelette" rel="directory"&gt;Squelette&lt;/a&gt;


		</description>


 <content:encoded>&lt;div class='rss_chapo'&gt;&lt;p&gt;Je tombe r&#233;guli&#232;rement sur des squelettes, faits par des gens venant du monde &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt;, qui sont pleins de &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt;.&lt;/p&gt;
&lt;p&gt;Voici quelques bonnes raisons de ne pas faire cela. Et puis aussi des pistes sur comment s'en passer.&lt;/p&gt;&lt;/div&gt;
		&lt;div class='rss_texte'&gt;&lt;h2 class=&#034;h2&#034;&gt;Raison 1&#160;: On ne profite pas du cache de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;&lt;/h2&gt;
&lt;p&gt;&lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; dispose d'un syst&#232;me de cache, qui &#233;vite de refaire trop souvent des calculs, et donc acc&#233;l&#232;re les pages. Les parties &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; d'un squelette &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; ne sont pas soumis &#224; ce syst&#232;me, du coup on perd un des avantages de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;.&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;Raison 2&#160;: C'est illisible&lt;/h2&gt;
&lt;p&gt;Bien souvent, pas toujours, ces &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;squelettes&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187; sont illisibles, car le code &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; n'est pas bien structur&#233;. Ce n'est pas toujours le cas, mais tr&#232;s souvent. Je pense que les personnes qui utilisent cela &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;bidouillent&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187; car ils n'arrivent pas &#224; faire ce qu'ils veulent en &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;. Bien s&#251;r, on pourrait imaginer un squelette &lt;span class=&#034;caps&#034;&gt;SPIPHP&lt;/span&gt; lisible, mais je n'en ai jamais vu.&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;Raison 3&#160;: Ce n'est pas optimis&#233;&lt;/h2&gt;
&lt;p&gt;Il m'est arriv&#233; de voir des requ&#234;tes &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt; directement dans un squelette &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;! Alors m&#234;me que &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; est un m&#233;ta-langage de requ&#234;tes &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt;, qui les optimise automatiquement. J'ai vu par exemple des appels via &lt;code&gt;mysql_query()&lt;/code&gt; &#224; des champs qui ne seront jamais utilis&#233;s dans la page. &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; lui n'appel que les champs r&#233;ellement utiles (ceux qu'on ins&#232;re dans la page avec #&lt;span class=&#034;caps&#034;&gt;CHAMP&lt;/span&gt;).&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;Raison 4&#160;: On ne profite pas de la souplesse des boucles de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; &lt;/h2&gt;
&lt;p&gt;Les boucles de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; poss&#232;dent des ressources insoup&#231;onn&#233;es&#160;: r&#233;cursivit&#233; des requ&#234;tes, requ&#234;tes imbriqu&#233;es. Certe il est possible de faire cela en &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt; / &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt;, mais pourquoi r&#233;-invent&#233; la roue, d'autant plus que &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;, la lecture sera plus claire.&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;Raison 5&#160;: On ne profite pas de &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;&lt;/h2&gt;
&lt;p&gt;Et oui, &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; c'est pr&#233;vu pour pouvoir faire directement les requ&#234;tes &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt; dans la &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;trame&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187;, dans le &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;moule&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187; de l'affichage souhait&#233;. Si on en profite pas, alors pourquoi prendre &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; et pas un autre &lt;span class=&#034;caps&#034;&gt;CMS&lt;/span&gt;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;?&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;Une exception&#160;: pour g&#233;rer certains &#233;l&#232;ments de session&lt;/h2&gt;
&lt;p&gt;Toute r&#232;gle &#224; ses exceptions. C'est le cas de la pr&#233;sente r&#232;gle. On lira un article qui explique &lt;a href=&#034;http://contrib.spip.net/du-php-dans-le-squelette-a-la-place-de-SESSION&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;pourquoi, pour g&#233;rer les sessions, mettre du &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; dans certains squelettes peut-&#234;tre une solution&lt;/a&gt;.&lt;/p&gt;
&lt;h2 class=&#034;h2&#034;&gt;Comment faire&lt;/h2&gt;
&lt;p&gt;Ceci n'est pas exhaustif, mais je tenterai de donner quelques indications pour les gens venant du monde &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; pour se &#171;&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;convertir&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;&#187; en &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;.&lt;/p&gt;
&lt;ul class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; Une requ&#234;te &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt; = Une Boucle &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;. Pour ceux qui ont besoin d'une explication formaliste, grammaticale de ce qu'est une boucle &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt;&#160;: &lt;a href=&#034;http://programmer.spip.org/-Les-boucles-&#034; class=&#034;spip_url spip_out auto&#034; rel=&#034;nofollow external&#034;&gt;http://programmer.spip.org/-Les-boucles-&lt;/a&gt;&lt;/li&gt;&lt;li&gt; Pour modifier le r&#233;sultat d'une balise &lt;span class=&#034;caps&#034;&gt;SPIP&lt;/span&gt; = d'un champ &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt;&#160;: un filtre = une fonction &#224; d&#233;finir dans mes_fonctions.php. D&#233;finition formelle d'une balise&#160;: &lt;a href=&#034;http://programmer.spip.org/-Les-balises-&#034; class=&#034;spip_url spip_out auto&#034; rel=&#034;nofollow external&#034;&gt;http://programmer.spip.org/-Les-balises-&lt;/a&gt;, d&#233;finition formelle d'un filtre&#160;: &lt;a href=&#034;http://programmer.spip.org/-Les-filtres-de-balises-&#034; class=&#034;spip_url spip_out auto&#034; rel=&#034;nofollow external&#034;&gt;http://programmer.spip.org/-Les-filtres-de-balises-&lt;/a&gt;&lt;/li&gt;&lt;li&gt; Une variable de compteur&#160;:
&lt;ul class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; Si c'est pour compter les r&#233;sultats d'une requ&#234;te &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt;&#160;: &lt;code&gt;#COMPTEUR_BOUCLE&lt;/code&gt;. Ex&#160;: &lt;code&gt;&lt;BOUCLE_a(ARTICLES)&gt;it&#233;ration #COMPTEUR_BOUCLE &lt;/BOUCLE_a&gt;&lt;/code&gt;&lt;/li&gt;&lt;li&gt; Si la variable est plus compliqu&#233;e&#160;: &lt;code&gt;#SET{variable,valeur}&lt;/code&gt;, &lt;code&gt;#GET{variable}&lt;/code&gt; et les &lt;a href=&#034;http://www.spip.net/fr_article901.html#math&#034; class=&#034;spip_out&#034; rel=&#034;external&#034;&gt;filtres math&#233;matiques&lt;/a&gt;&#160;: &lt;code&gt;|plus&lt;/code&gt;, &lt;code&gt;|mult&lt;/code&gt; etc. &lt;a href=&#034;http://www.spip.net/fr_article901.html&#034; class=&#034;spip_url spip_out auto&#034; rel=&#034;nofollow external&#034;&gt;http://www.spip.net/fr_article901.html&lt;/a&gt;&lt;/li&gt;&lt;li&gt; Une variable tout court&#160;: voir ci dessus.&lt;/li&gt;&lt;/ul&gt;&lt;/li&gt;&lt;li&gt; Des tests conditionnels&#160;:
&lt;ul class=&#034;spip&#034; role=&#034;list&#034;&gt;&lt;li&gt; filtres de comparaison et filtres de test&#160;: &lt;a href=&#034;http://programmer.spip.org/Filtres-de-comparaison&#034; class=&#034;spip_url spip_out auto&#034; rel=&#034;nofollow external&#034;&gt;http://programmer.spip.org/Filtres-de-comparaison&lt;/a&gt; &lt;a href=&#034;http://programmer.spip.org/Les-filtres-de-tests&#034; class=&#034;spip_url spip_out auto&#034; rel=&#034;nofollow external&#034;&gt;http://programmer.spip.org/Les-filtres-de-tests&lt;/a&gt;.&lt;/li&gt;&lt;li&gt; Et pour conditionner en fonction du r&#233;sultat de la requ&#234;te &lt;span class=&#034;caps&#034;&gt;SQL&lt;/span&gt;&#160;: la syntaxe compl&#232;te des boucles&#160;: &lt;a href=&#034;http://programmer.spip.org/Syntaxe-complete-des-boucles&#034; class=&#034;spip_url spip_out auto&#034; rel=&#034;nofollow external&#034;&gt;http://programmer.spip.org/Syntaxe-complete-des-boucles&lt;/a&gt;&lt;/li&gt;&lt;li&gt; Des tableaux&#160;: la balise &lt;code&gt;#ARRAY&lt;/code&gt;&#160;: &lt;a href=&#034;http://www.spip.net/fr_article4009.html&#034; class=&#034;spip_url spip_out auto&#034; rel=&#034;nofollow external&#034;&gt;http://www.spip.net/fr_article4009.html&lt;/a&gt;&lt;/li&gt;&lt;/ul&gt;&lt;/li&gt;&lt;/ul&gt;
&lt;p&gt;Voil&#224;, avec &#231;a vous avez les bases pour ne plus mettre de &lt;span class=&#034;caps&#034;&gt;PHP&lt;/span&gt; dans vos squelettes (bien s&#251;r, il faut lire les liens&lt;small class=&#034;fine d-inline&#034;&gt;&#160;&lt;/small&gt;! Ceci n'est pas un tutoriel).&lt;/p&gt;&lt;/div&gt;
		&lt;hr /&gt;
		&lt;div &lt;div class='rss_ps'&gt;&lt;p&gt;Si d'autres SPIPeurs voient des bonnes raisons, ne pas h&#233;siter &#224; les signaler.&lt;/p&gt;&lt;/div&gt;
		
		</content:encoded>


		

	</item>



</channel>

</rss>
