3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
6 * Copyright (c) 2001-2019 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
9 * Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
10 * Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
11 \***************************************************************************/
15 * Ce fichier definit les boucles standard de SPIP
17 * @package SPIP\Core\Compilateur\Boucles
20 if (!defined('_ECRIRE_INC_VERSION')) {
26 * Compile une boucle standard, sans condition rajoutée
28 * @param string $id_boucle
29 * Identifiant de la boucle
30 * @param array $boucles
33 * Code PHP compilé de la boucle
35 function boucle_DEFAUT_dist($id_boucle, &$boucles) {
36 return calculer_boucle($id_boucle, $boucles);
41 * Compile une boucle récursive
45 * @link http://www.spip.net/914
47 * @param string $id_boucle
48 * Identifiant de la boucle
49 * @param array $boucles
52 * Code PHP compilé de la boucle
54 function boucle_BOUCLE_dist($id_boucle, &$boucles) {
55 return calculer_boucle($id_boucle, $boucles);
60 * Compile une boucle HIERARCHIE
62 * La boucle `<BOUCLE(HIERARCHIE)>` retourne la liste des RUBRIQUES
63 * qui mènent de la racine du site à la rubrique ou à l’article en cours.
65 * Cette boucle (aliasée sur la table RUBRIQUES)
67 * - recherche un id_rubrique dans les boucles parentes,
68 * - extrait sa hiérarchie, en prenant ou non la rubrique en cours en fonction du critère {tout}
69 * - crée une condition WHERE avec ces identifiants ansi qu'une clause ORDER
70 * - compile la boucle.
72 * Le code compilé calculant la hierarchie est ajouté au tout début de la
73 * fonction de boucle et quitte la boucle si aucune rubrique n'est trouvée.
75 * @link http://www.spip.net/913
77 * @param string $id_boucle
78 * Identifiant de la boucle
79 * @param array $boucles
82 * Code PHP compilé de la boucle
84 function boucle_HIERARCHIE_dist($id_boucle, &$boucles) {
85 $boucle = &$boucles[$id_boucle];
86 $id_table = $boucle->id_table
. ".id_rubrique";
88 // Si la boucle mere est une boucle RUBRIQUES il faut ignorer la feuille
89 // sauf en presence du critere {tout} (vu par phraser_html)
90 // ou {id_article} qui positionne aussi le {tout}
92 $boucle->hierarchie
= 'if (!($id_rubrique = intval('
93 . calculer_argument_precedent($boucle->id_boucle
, 'id_rubrique', $boucles)
94 . ")))\n\t\treturn '';\n\t"
95 . "include_spip('inc/rubriques');\n\t"
96 . '$hierarchie = calcul_hierarchie_in($id_rubrique,'
97 . (isset($boucle->modificateur
['tout']) ?
'true' : 'false')
99 . 'if (!$hierarchie) return "";' . "\n\t";
101 $boucle->where
[] = array("'IN'", "'$id_table'", '"($hierarchie)"');
103 $order = "FIELD($id_table, \$hierarchie)";
104 if (!isset($boucle->default_order
[0]) or $boucle->default_order
[0] != " DESC") {
105 $boucle->default_order
[] = "\"$order\"";
107 $boucle->default_order
[0] = "\"$order DESC\"";
110 return calculer_boucle($id_boucle, $boucles);