Completed
Push — master ( b8912c...e2d4e4 )
by cam
06:14
created
ecrire/public/criteres.php 2 patches
Indentation   +1656 added lines, -1656 removed lines patch added patch discarded remove patch
@@ -17,7 +17,7 @@  discard block
 block discarded – undo
17 17
  **/
18 18
 
19 19
 if (!defined('_ECRIRE_INC_VERSION')) {
20
-	return;
20
+    return;
21 21
 }
22 22
 
23 23
 /**
@@ -43,14 +43,14 @@  discard block
 block discarded – undo
43 43
  **/
44 44
 function critere_racine_dist($idb, &$boucles, $crit) {
45 45
 
46
-	$not = $crit->not;
47
-	$boucle = &$boucles[$idb];
48
-	$id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
49
-		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
50
-		'id_parent';
46
+    $not = $crit->not;
47
+    $boucle = &$boucles[$idb];
48
+    $id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
49
+        $GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
50
+        'id_parent';
51 51
 
52
-	$c = array("'='", "'$boucle->id_table." . "$id_parent'", 0);
53
-	$boucle->where[] = ($crit->not ? array("'NOT'", $c) : $c);
52
+    $c = array("'='", "'$boucle->id_table." . "$id_parent'", 0);
53
+    $boucle->where[] = ($crit->not ? array("'NOT'", $c) : $c);
54 54
 }
55 55
 
56 56
 
@@ -67,15 +67,15 @@  discard block
 block discarded – undo
67 67
  * @return void
68 68
  **/
69 69
 function critere_exclus_dist($idb, &$boucles, $crit) {
70
-	$not = $crit->not;
71
-	$boucle = &$boucles[$idb];
72
-	$id = $boucle->primary;
73
-
74
-	if ($not or !$id) {
75
-		return (array('zbug_critere_inconnu', array('critere' => $not . $crit->op)));
76
-	}
77
-	$arg = kwote(calculer_argument_precedent($idb, $id, $boucles));
78
-	$boucle->where[] = array("'!='", "'$boucle->id_table." . "$id'", $arg);
70
+    $not = $crit->not;
71
+    $boucle = &$boucles[$idb];
72
+    $id = $boucle->primary;
73
+
74
+    if ($not or !$id) {
75
+        return (array('zbug_critere_inconnu', array('critere' => $not . $crit->op)));
76
+    }
77
+    $arg = kwote(calculer_argument_precedent($idb, $id, $boucles));
78
+    $boucle->where[] = array("'!='", "'$boucle->id_table." . "$id'", $arg);
79 79
 }
80 80
 
81 81
 
@@ -95,73 +95,73 @@  discard block
 block discarded – undo
95 95
  * @return void
96 96
  **/
97 97
 function critere_doublons_dist($idb, &$boucles, $crit) {
98
-	$boucle = &$boucles[$idb];
99
-	$primary = $boucle->primary;
100
-
101
-	// la table nécessite une clé primaire, non composée
102
-	if (!$primary or strpos($primary, ',')) {
103
-		return (array('zbug_doublon_sur_table_sans_cle_primaire'));
104
-	}
105
-
106
-	$not = ($crit->not ? '' : 'NOT');
107
-
108
-	// le doublon s'applique sur un type de boucle (article)
109
-	$nom = "'" . $boucle->type_requete . "'";
110
-
111
-	// compléter le nom avec un nom précisé {doublons nom}
112
-	// on obtient $nom = "'article' . 'nom'"
113
-	if (isset($crit->param[0])) {
114
-		$nom .= "." . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
115
-	}
116
-
117
-	// code qui déclarera l'index du stockage de nos doublons (pour éviter une notice PHP)
118
-	$init_comment = "\n\n\t// Initialise le(s) critère(s) doublons\n";
119
-	$init_code = "\tif (!isset(\$doublons[\$d = $nom])) { \$doublons[\$d] = ''; }\n";
120
-
121
-	// on crée un sql_in avec la clé primaire de la table
122
-	// et la collection des doublons déjà emmagasinés dans le tableau
123
-	// $doublons et son index, ici $nom
124
-
125
-	// debut du code "sql_in('articles.id_article', "
126
-	$debut_in = "sql_in('" . $boucle->id_table . '.' . $primary . "', ";
127
-	// lecture des données du doublon "$doublons[$doublon_index[] = "
128
-	// Attention : boucle->doublons désigne une variable qu'on affecte
129
-	$debut_doub = '$doublons[' . (!$not ? '' : ($boucle->doublons . "[]= "));
130
-
131
-	// le debut complet du code des doublons
132
-	$debut_doub = $debut_in . $debut_doub;
133
-
134
-	// nom du doublon "('article' . 'nom')]"
135
-	$fin_doub = "($nom)]";
136
-
137
-	// si on trouve un autre critère doublon,
138
-	// on fusionne pour avoir un seul IN, et on s'en va !
139
-	foreach ($boucle->where as $k => $w) {
140
-		if (strpos($w[0], $debut_doub) === 0) {
141
-			// fusionner le sql_in (du where)
142
-			$boucle->where[$k][0] = $debut_doub . $fin_doub . ' . ' . substr($w[0], strlen($debut_in));
143
-			// fusionner l'initialisation (du hash) pour faire plus joli
144
-			$x = strpos($boucle->hash, $init_comment);
145
-			$len = strlen($init_comment);
146
-			$boucle->hash =
147
-				substr($boucle->hash, 0, $x + $len) . $init_code . substr($boucle->hash, $x + $len);
148
-
149
-			return;
150
-		}
151
-	}
152
-
153
-	// mettre l'ensemble dans un tableau pour que ce ne soit pas vu comme une constante
154
-	$boucle->where[] = array($debut_doub . $fin_doub . ", '" . $not . "')");
155
-
156
-	// déclarer le doublon s'il n'existe pas encore
157
-	$boucle->hash .= $init_comment . $init_code;
158
-
159
-
160
-	# la ligne suivante avait l'intention d'eviter une collecte deja faite
161
-	# mais elle fait planter une boucle a 2 critere doublons:
162
-	# {!doublons A}{doublons B}
163
-	# (de http://article.gmane.org/gmane.comp.web.spip.devel/31034)
164
-	#	if ($crit->not) $boucle->doublons = "";
98
+    $boucle = &$boucles[$idb];
99
+    $primary = $boucle->primary;
100
+
101
+    // la table nécessite une clé primaire, non composée
102
+    if (!$primary or strpos($primary, ',')) {
103
+        return (array('zbug_doublon_sur_table_sans_cle_primaire'));
104
+    }
105
+
106
+    $not = ($crit->not ? '' : 'NOT');
107
+
108
+    // le doublon s'applique sur un type de boucle (article)
109
+    $nom = "'" . $boucle->type_requete . "'";
110
+
111
+    // compléter le nom avec un nom précisé {doublons nom}
112
+    // on obtient $nom = "'article' . 'nom'"
113
+    if (isset($crit->param[0])) {
114
+        $nom .= "." . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
115
+    }
116
+
117
+    // code qui déclarera l'index du stockage de nos doublons (pour éviter une notice PHP)
118
+    $init_comment = "\n\n\t// Initialise le(s) critère(s) doublons\n";
119
+    $init_code = "\tif (!isset(\$doublons[\$d = $nom])) { \$doublons[\$d] = ''; }\n";
120
+
121
+    // on crée un sql_in avec la clé primaire de la table
122
+    // et la collection des doublons déjà emmagasinés dans le tableau
123
+    // $doublons et son index, ici $nom
124
+
125
+    // debut du code "sql_in('articles.id_article', "
126
+    $debut_in = "sql_in('" . $boucle->id_table . '.' . $primary . "', ";
127
+    // lecture des données du doublon "$doublons[$doublon_index[] = "
128
+    // Attention : boucle->doublons désigne une variable qu'on affecte
129
+    $debut_doub = '$doublons[' . (!$not ? '' : ($boucle->doublons . "[]= "));
130
+
131
+    // le debut complet du code des doublons
132
+    $debut_doub = $debut_in . $debut_doub;
133
+
134
+    // nom du doublon "('article' . 'nom')]"
135
+    $fin_doub = "($nom)]";
136
+
137
+    // si on trouve un autre critère doublon,
138
+    // on fusionne pour avoir un seul IN, et on s'en va !
139
+    foreach ($boucle->where as $k => $w) {
140
+        if (strpos($w[0], $debut_doub) === 0) {
141
+            // fusionner le sql_in (du where)
142
+            $boucle->where[$k][0] = $debut_doub . $fin_doub . ' . ' . substr($w[0], strlen($debut_in));
143
+            // fusionner l'initialisation (du hash) pour faire plus joli
144
+            $x = strpos($boucle->hash, $init_comment);
145
+            $len = strlen($init_comment);
146
+            $boucle->hash =
147
+                substr($boucle->hash, 0, $x + $len) . $init_code . substr($boucle->hash, $x + $len);
148
+
149
+            return;
150
+        }
151
+    }
152
+
153
+    // mettre l'ensemble dans un tableau pour que ce ne soit pas vu comme une constante
154
+    $boucle->where[] = array($debut_doub . $fin_doub . ", '" . $not . "')");
155
+
156
+    // déclarer le doublon s'il n'existe pas encore
157
+    $boucle->hash .= $init_comment . $init_code;
158
+
159
+
160
+    # la ligne suivante avait l'intention d'eviter une collecte deja faite
161
+    # mais elle fait planter une boucle a 2 critere doublons:
162
+    # {!doublons A}{doublons B}
163
+    # (de http://article.gmane.org/gmane.comp.web.spip.devel/31034)
164
+    #	if ($crit->not) $boucle->doublons = "";
165 165
 }
166 166
 
167 167
 
@@ -182,14 +182,14 @@  discard block
 block discarded – undo
182 182
  * @return void
183 183
  **/
184 184
 function critere_lang_select_dist($idb, &$boucles, $crit) {
185
-	if (!isset($crit->param[1][0]) or !($param = $crit->param[1][0]->texte)) {
186
-		$param = 'oui';
187
-	}
188
-	if ($crit->not) {
189
-		$param = ($param == 'oui') ? 'non' : 'oui';
190
-	}
191
-	$boucle = &$boucles[$idb];
192
-	$boucle->lang_select = $param;
185
+    if (!isset($crit->param[1][0]) or !($param = $crit->param[1][0]->texte)) {
186
+        $param = 'oui';
187
+    }
188
+    if ($crit->not) {
189
+        $param = ($param == 'oui') ? 'non' : 'oui';
190
+    }
191
+    $boucle = &$boucles[$idb];
192
+    $boucle->lang_select = $param;
193 193
 }
194 194
 
195 195
 
@@ -211,18 +211,18 @@  discard block
 block discarded – undo
211 211
  * @return void
212 212
  **/
213 213
 function critere_debut_dist($idb, &$boucles, $crit) {
214
-	list($un, $deux) = $crit->param;
215
-	$un = $un[0]->texte;
216
-	$deux = $deux[0]->texte;
217
-	if ($deux) {
218
-		$boucles[$idb]->limit = 'intval($Pile[0]["debut' .
219
-			$un .
220
-			'"]) . ",' .
221
-			$deux .
222
-			'"';
223
-	} else {
224
-		calculer_critere_DEFAUT_dist($idb, $boucles, $crit);
225
-	}
214
+    list($un, $deux) = $crit->param;
215
+    $un = $un[0]->texte;
216
+    $deux = $deux[0]->texte;
217
+    if ($deux) {
218
+        $boucles[$idb]->limit = 'intval($Pile[0]["debut' .
219
+            $un .
220
+            '"]) . ",' .
221
+            $deux .
222
+            '"';
223
+    } else {
224
+        calculer_critere_DEFAUT_dist($idb, $boucles, $crit);
225
+    }
226 226
 }
227 227
 
228 228
 
@@ -256,57 +256,57 @@  discard block
 block discarded – undo
256 256
  **/
257 257
 function critere_pagination_dist($idb, &$boucles, $crit) {
258 258
 
259
-	$boucle = &$boucles[$idb];
260
-	// definition de la taille de la page
261
-	$pas = !isset($crit->param[0][0]) ? "''"
262
-		: calculer_liste(array($crit->param[0][0]), array(), $boucles, $boucle->id_parent);
263
-
264
-	if (!preg_match(_CODE_QUOTE, $pas, $r)) {
265
-		$pas = "((\$a = intval($pas)) ? \$a : 10)";
266
-	} else {
267
-		$r = intval($r[2]);
268
-		$pas = strval($r ? $r : 10);
269
-	}
270
-
271
-	// Calcul du nommage de la pagination si il existe.
272
-	// La nouvelle syntaxe {pagination 20, nom} est prise en compte et privilégiée mais on reste
273
-	// compatible avec l'ancienne car certains cas fonctionnent correctement
274
-	$type = "'$idb'";
275
-	// Calcul d'un nommage spécifique de la pagination si précisé.
276
-	// Syntaxe {pagination 20, nom}
277
-	if (isset($crit->param[0][1])) {
278
-		$type = calculer_liste(array($crit->param[0][1]), array(), $boucles, $boucle->id_parent);
279
-	} // Ancienne syntaxe {pagination 20 nom} pour compatibilité
280
-	elseif (isset($crit->param[1][0])) {
281
-		$type = calculer_liste(array($crit->param[1][0]), array(), $boucles, $boucle->id_parent);
282
-	}
283
-
284
-	$debut = ($type[0] !== "'") ? "'debut'.$type" : ("'debut" . substr($type, 1));
285
-	$boucle->modificateur['debut_nom'] = $type;
286
-	$partie =
287
-		// tester si le numero de page demande est de la forme '@yyy'
288
-		'isset($Pile[0][' . $debut . ']) ? $Pile[0][' . $debut . '] : _request(' . $debut . ");\n"
289
-		. "\tif(substr(\$debut_boucle,0,1)=='@'){\n"
290
-		. "\t\t" . '$debut_boucle = $Pile[0][' . $debut . '] = quete_debut_pagination(\'' . $boucle->primary . '\',$Pile[0][\'@' . $boucle->primary . '\'] = substr($debut_boucle,1),' . $pas . ',$iter);' . "\n"
291
-		. "\t\t" . '$iter->seek(0);' . "\n"
292
-		. "\t}\n"
293
-		. "\t" . '$debut_boucle = intval($debut_boucle)';
294
-
295
-	$boucle->hash .= '
259
+    $boucle = &$boucles[$idb];
260
+    // definition de la taille de la page
261
+    $pas = !isset($crit->param[0][0]) ? "''"
262
+        : calculer_liste(array($crit->param[0][0]), array(), $boucles, $boucle->id_parent);
263
+
264
+    if (!preg_match(_CODE_QUOTE, $pas, $r)) {
265
+        $pas = "((\$a = intval($pas)) ? \$a : 10)";
266
+    } else {
267
+        $r = intval($r[2]);
268
+        $pas = strval($r ? $r : 10);
269
+    }
270
+
271
+    // Calcul du nommage de la pagination si il existe.
272
+    // La nouvelle syntaxe {pagination 20, nom} est prise en compte et privilégiée mais on reste
273
+    // compatible avec l'ancienne car certains cas fonctionnent correctement
274
+    $type = "'$idb'";
275
+    // Calcul d'un nommage spécifique de la pagination si précisé.
276
+    // Syntaxe {pagination 20, nom}
277
+    if (isset($crit->param[0][1])) {
278
+        $type = calculer_liste(array($crit->param[0][1]), array(), $boucles, $boucle->id_parent);
279
+    } // Ancienne syntaxe {pagination 20 nom} pour compatibilité
280
+    elseif (isset($crit->param[1][0])) {
281
+        $type = calculer_liste(array($crit->param[1][0]), array(), $boucles, $boucle->id_parent);
282
+    }
283
+
284
+    $debut = ($type[0] !== "'") ? "'debut'.$type" : ("'debut" . substr($type, 1));
285
+    $boucle->modificateur['debut_nom'] = $type;
286
+    $partie =
287
+        // tester si le numero de page demande est de la forme '@yyy'
288
+        'isset($Pile[0][' . $debut . ']) ? $Pile[0][' . $debut . '] : _request(' . $debut . ");\n"
289
+        . "\tif(substr(\$debut_boucle,0,1)=='@'){\n"
290
+        . "\t\t" . '$debut_boucle = $Pile[0][' . $debut . '] = quete_debut_pagination(\'' . $boucle->primary . '\',$Pile[0][\'@' . $boucle->primary . '\'] = substr($debut_boucle,1),' . $pas . ',$iter);' . "\n"
291
+        . "\t\t" . '$iter->seek(0);' . "\n"
292
+        . "\t}\n"
293
+        . "\t" . '$debut_boucle = intval($debut_boucle)';
294
+
295
+    $boucle->hash .= '
296 296
 	$command[\'pagination\'] = array((isset($Pile[0][' . $debut . ']) ? $Pile[0][' . $debut . '] : null), ' . $pas . ');';
297 297
 
298
-	$boucle->total_parties = $pas;
299
-	calculer_parties($boucles, $idb, $partie, 'p+');
300
-	// ajouter la cle primaire dans le select pour pouvoir gerer la pagination referencee par @id
301
-	// sauf si pas de primaire, ou si primaire composee
302
-	// dans ce cas, on ne sait pas gerer une pagination indirecte
303
-	$t = $boucle->id_table . '.' . $boucle->primary;
304
-	if ($boucle->primary
305
-		and !preg_match('/[,\s]/', $boucle->primary)
306
-		and !in_array($t, $boucle->select)
307
-	) {
308
-		$boucle->select[] = $t;
309
-	}
298
+    $boucle->total_parties = $pas;
299
+    calculer_parties($boucles, $idb, $partie, 'p+');
300
+    // ajouter la cle primaire dans le select pour pouvoir gerer la pagination referencee par @id
301
+    // sauf si pas de primaire, ou si primaire composee
302
+    // dans ce cas, on ne sait pas gerer une pagination indirecte
303
+    $t = $boucle->id_table . '.' . $boucle->primary;
304
+    if ($boucle->primary
305
+        and !preg_match('/[,\s]/', $boucle->primary)
306
+        and !in_array($t, $boucle->select)
307
+    ) {
308
+        $boucle->select[] = $t;
309
+    }
310 310
 }
311 311
 
312 312
 
@@ -328,24 +328,24 @@  discard block
 block discarded – undo
328 328
  **/
329 329
 function critere_recherche_dist($idb, &$boucles, $crit) {
330 330
 
331
-	$boucle = &$boucles[$idb];
331
+    $boucle = &$boucles[$idb];
332 332
 
333
-	if (!$boucle->primary or strpos($boucle->primary, ',')) {
334
-		erreur_squelette(_T('zbug_critere_sur_table_sans_cle_primaire', array('critere' => 'recherche')), $boucle);
333
+    if (!$boucle->primary or strpos($boucle->primary, ',')) {
334
+        erreur_squelette(_T('zbug_critere_sur_table_sans_cle_primaire', array('critere' => 'recherche')), $boucle);
335 335
 
336
-		return;
337
-	}
336
+        return;
337
+    }
338 338
 
339
-	if (isset($crit->param[0])) {
340
-		$quoi = calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
341
-	} else {
342
-		$quoi = '(isset($Pile[0]["recherche"])?$Pile[0]["recherche"]:(isset($GLOBALS["recherche"])?$GLOBALS["recherche"]:""))';
343
-	}
339
+    if (isset($crit->param[0])) {
340
+        $quoi = calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
341
+    } else {
342
+        $quoi = '(isset($Pile[0]["recherche"])?$Pile[0]["recherche"]:(isset($GLOBALS["recherche"])?$GLOBALS["recherche"]:""))';
343
+    }
344 344
 
345
-	$_modificateur = var_export($boucle->modificateur, true);
346
-	$boucle->hash .= '
345
+    $_modificateur = var_export($boucle->modificateur, true);
346
+    $boucle->hash .= '
347 347
 	// RECHERCHE'
348
-		. ($crit->cond ? '
348
+        . ($crit->cond ? '
349 349
 	if (!strlen(' . $quoi . ')){
350 350
 		list($rech_select, $rech_where) = array("0 as points","");
351 351
 	} else' : '') . '
@@ -356,21 +356,21 @@  discard block
 block discarded – undo
356 356
 	';
357 357
 
358 358
 
359
-	$t = $boucle->id_table . '.' . $boucle->primary;
360
-	if (!in_array($t, $boucles[$idb]->select)) {
361
-		$boucle->select[] = $t;
362
-	} # pour postgres, neuneu ici
363
-	// jointure uniquement sur le serveur principal
364
-	// (on ne peut joindre une table d'un serveur distant avec la table des resultats du serveur principal)
365
-	if (!$boucle->sql_serveur) {
366
-		$boucle->join['resultats'] = array("'" . $boucle->id_table . "'", "'id'", "'" . $boucle->primary . "'");
367
-		$boucle->from['resultats'] = 'spip_resultats';
368
-	}
369
-	$boucle->select[] = '$rech_select';
370
-	//$boucle->where[]= "\$rech_where?'resultats.id=".$boucle->id_table.".".$boucle->primary."':''";
371
-
372
-	// et la recherche trouve
373
-	$boucle->where[] = '$rech_where?$rech_where:\'\'';
359
+    $t = $boucle->id_table . '.' . $boucle->primary;
360
+    if (!in_array($t, $boucles[$idb]->select)) {
361
+        $boucle->select[] = $t;
362
+    } # pour postgres, neuneu ici
363
+    // jointure uniquement sur le serveur principal
364
+    // (on ne peut joindre une table d'un serveur distant avec la table des resultats du serveur principal)
365
+    if (!$boucle->sql_serveur) {
366
+        $boucle->join['resultats'] = array("'" . $boucle->id_table . "'", "'id'", "'" . $boucle->primary . "'");
367
+        $boucle->from['resultats'] = 'spip_resultats';
368
+    }
369
+    $boucle->select[] = '$rech_select';
370
+    //$boucle->where[]= "\$rech_where?'resultats.id=".$boucle->id_table.".".$boucle->primary."':''";
371
+
372
+    // et la recherche trouve
373
+    $boucle->where[] = '$rech_where?$rech_where:\'\'';
374 374
 }
375 375
 
376 376
 /**
@@ -387,25 +387,25 @@  discard block
 block discarded – undo
387 387
  * @return void
388 388
  **/
389 389
 function critere_traduction_dist($idb, &$boucles, $crit) {
390
-	$boucle = &$boucles[$idb];
391
-	$prim = $boucle->primary;
392
-	$table = $boucle->id_table;
393
-	$arg = kwote(calculer_argument_precedent($idb, 'id_trad', $boucles));
394
-	$dprim = kwote(calculer_argument_precedent($idb, $prim, $boucles));
395
-	$boucle->where[] =
396
-		array(
397
-			"'OR'",
398
-			array(
399
-				"'AND'",
400
-				array("'='", "'$table.id_trad'", 0),
401
-				array("'='", "'$table.$prim'", $dprim)
402
-			),
403
-			array(
404
-				"'AND'",
405
-				array("'>'", "'$table.id_trad'", 0),
406
-				array("'='", "'$table.id_trad'", $arg)
407
-			)
408
-		);
390
+    $boucle = &$boucles[$idb];
391
+    $prim = $boucle->primary;
392
+    $table = $boucle->id_table;
393
+    $arg = kwote(calculer_argument_precedent($idb, 'id_trad', $boucles));
394
+    $dprim = kwote(calculer_argument_precedent($idb, $prim, $boucles));
395
+    $boucle->where[] =
396
+        array(
397
+            "'OR'",
398
+            array(
399
+                "'AND'",
400
+                array("'='", "'$table.id_trad'", 0),
401
+                array("'='", "'$table.$prim'", $dprim)
402
+            ),
403
+            array(
404
+                "'AND'",
405
+                array("'>'", "'$table.id_trad'", 0),
406
+                array("'='", "'$table.id_trad'", $arg)
407
+            )
408
+        );
409 409
 }
410 410
 
411 411
 
@@ -423,17 +423,17 @@  discard block
 block discarded – undo
423 423
  * @return void
424 424
  **/
425 425
 function critere_origine_traduction_dist($idb, &$boucles, $crit) {
426
-	$boucle = &$boucles[$idb];
427
-	$prim = $boucle->primary;
428
-	$table = $boucle->id_table;
429
-
430
-	$c =
431
-		array(
432
-			"'OR'",
433
-			array("'='", "'$table." . "id_trad'", "'$table.$prim'"),
434
-			array("'='", "'$table.id_trad'", "'0'")
435
-		);
436
-	$boucle->where[] = ($crit->not ? array("'NOT'", $c) : $c);
426
+    $boucle = &$boucles[$idb];
427
+    $prim = $boucle->primary;
428
+    $table = $boucle->id_table;
429
+
430
+    $c =
431
+        array(
432
+            "'OR'",
433
+            array("'='", "'$table." . "id_trad'", "'$table.$prim'"),
434
+            array("'='", "'$table.id_trad'", "'0'")
435
+        );
436
+    $boucle->where[] = ($crit->not ? array("'NOT'", $c) : $c);
437 437
 }
438 438
 
439 439
 
@@ -450,20 +450,20 @@  discard block
 block discarded – undo
450 450
  **/
451 451
 function critere_meme_parent_dist($idb, &$boucles, $crit) {
452 452
 
453
-	$boucle = &$boucles[$idb];
454
-	$arg = kwote(calculer_argument_precedent($idb, 'id_parent', $boucles));
455
-	$id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
456
-		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
457
-		'id_parent';
458
-	$mparent = $boucle->id_table . '.' . $id_parent;
453
+    $boucle = &$boucles[$idb];
454
+    $arg = kwote(calculer_argument_precedent($idb, 'id_parent', $boucles));
455
+    $id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
456
+        $GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
457
+        'id_parent';
458
+    $mparent = $boucle->id_table . '.' . $id_parent;
459 459
 
460
-	if ($boucle->type_requete == 'rubriques' or isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'])) {
461
-		$boucle->where[] = array("'='", "'$mparent'", $arg);
460
+    if ($boucle->type_requete == 'rubriques' or isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'])) {
461
+        $boucle->where[] = array("'='", "'$mparent'", $arg);
462 462
 
463
-	} // le cas FORUMS est gere dans le plugin forum, dans la fonction critere_FORUMS_meme_parent_dist()
464
-	else {
465
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op . ' ' . $boucle->type_requete)));
466
-	}
463
+    } // le cas FORUMS est gere dans le plugin forum, dans la fonction critere_FORUMS_meme_parent_dist()
464
+    else {
465
+        return (array('zbug_critere_inconnu', array('critere' => $crit->op . ' ' . $boucle->type_requete)));
466
+    }
467 467
 }
468 468
 
469 469
 
@@ -494,37 +494,37 @@  discard block
 block discarded – undo
494 494
  **/
495 495
 function critere_branche_dist($idb, &$boucles, $crit) {
496 496
 
497
-	$not = $crit->not;
498
-	$boucle = &$boucles[$idb];
499
-	// prendre en priorite un identifiant en parametre {branche XX}
500
-	if (isset($crit->param[0])) {
501
-		$arg = calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
502
-		// sinon on le prend chez une boucle parente
503
-	} else {
504
-		$arg = kwote(calculer_argument_precedent($idb, 'id_rubrique', $boucles), $boucle->sql_serveur, 'int NOT NULL');
505
-	}
506
-
507
-	//Trouver une jointure
508
-	$champ = "id_rubrique";
509
-	$desc = $boucle->show;
510
-	//Seulement si necessaire
511
-	if (!array_key_exists($champ, $desc['field'])) {
512
-		$cle = trouver_jointure_champ($champ, $boucle);
513
-		$trouver_table = charger_fonction("trouver_table", "base");
514
-		$desc = $trouver_table($boucle->from[$cle]);
515
-		if (count(trouver_champs_decomposes($champ, $desc)) > 1) {
516
-			$decompose = decompose_champ_id_objet($champ);
517
-			$champ = array_shift($decompose);
518
-			$boucle->where[] = array("'='", _q($cle . "." . reset($decompose)), '"' . sql_quote(end($decompose)) . '"');
519
-		}
520
-	} else {
521
-		$cle = $boucle->id_table;
522
-	}
523
-
524
-	$c = "sql_in('$cle" . ".$champ', calcul_branche_in($arg)"
525
-		. ($not ? ", 'NOT'" : '') . ")";
526
-	$boucle->where[] = !$crit->cond ? $c :
527
-		("($arg ? $c : " . ($not ? "'0=1'" : "'1=1'") . ')');
497
+    $not = $crit->not;
498
+    $boucle = &$boucles[$idb];
499
+    // prendre en priorite un identifiant en parametre {branche XX}
500
+    if (isset($crit->param[0])) {
501
+        $arg = calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
502
+        // sinon on le prend chez une boucle parente
503
+    } else {
504
+        $arg = kwote(calculer_argument_precedent($idb, 'id_rubrique', $boucles), $boucle->sql_serveur, 'int NOT NULL');
505
+    }
506
+
507
+    //Trouver une jointure
508
+    $champ = "id_rubrique";
509
+    $desc = $boucle->show;
510
+    //Seulement si necessaire
511
+    if (!array_key_exists($champ, $desc['field'])) {
512
+        $cle = trouver_jointure_champ($champ, $boucle);
513
+        $trouver_table = charger_fonction("trouver_table", "base");
514
+        $desc = $trouver_table($boucle->from[$cle]);
515
+        if (count(trouver_champs_decomposes($champ, $desc)) > 1) {
516
+            $decompose = decompose_champ_id_objet($champ);
517
+            $champ = array_shift($decompose);
518
+            $boucle->where[] = array("'='", _q($cle . "." . reset($decompose)), '"' . sql_quote(end($decompose)) . '"');
519
+        }
520
+    } else {
521
+        $cle = $boucle->id_table;
522
+    }
523
+
524
+    $c = "sql_in('$cle" . ".$champ', calcul_branche_in($arg)"
525
+        . ($not ? ", 'NOT'" : '') . ")";
526
+    $boucle->where[] = !$crit->cond ? $c :
527
+        ("($arg ? $c : " . ($not ? "'0=1'" : "'1=1'") . ')');
528 528
 }
529 529
 
530 530
 /**
@@ -540,22 +540,22 @@  discard block
 block discarded – undo
540 540
  **/
541 541
 function critere_logo_dist($idb, &$boucles, $crit) {
542 542
 
543
-	$not = $crit->not;
544
-	$boucle = &$boucles[$idb];
543
+    $not = $crit->not;
544
+    $boucle = &$boucles[$idb];
545 545
 
546
-	$c = "sql_in('" .
547
-		$boucle->id_table . '.' . $boucle->primary
548
-		. "', lister_objets_avec_logos('" . $boucle->primary . "'), '')";
546
+    $c = "sql_in('" .
547
+        $boucle->id_table . '.' . $boucle->primary
548
+        . "', lister_objets_avec_logos('" . $boucle->primary . "'), '')";
549 549
 
550
-	if ($crit->cond) {
551
-		$c = "($arg ? $c : 1)";
552
-	}
550
+    if ($crit->cond) {
551
+        $c = "($arg ? $c : 1)";
552
+    }
553 553
 
554
-	if ($not) {
555
-		$boucle->where[] = array("'NOT'", $c);
556
-	} else {
557
-		$boucle->where[] = $c;
558
-	}
554
+    if ($not) {
555
+        $boucle->where[] = array("'NOT'", $c);
556
+    } else {
557
+        $boucle->where[] = $c;
558
+    }
559 559
 }
560 560
 
561 561
 
@@ -577,31 +577,31 @@  discard block
 block discarded – undo
577 577
  * @return void
578 578
  **/
579 579
 function critere_fusion_dist($idb, &$boucles, $crit) {
580
-	if ($t = isset($crit->param[0])) {
581
-		$t = $crit->param[0];
582
-		if ($t[0]->type == 'texte') {
583
-			$t = $t[0]->texte;
584
-			if (preg_match("/^(.*)\.(.*)$/", $t, $r)) {
585
-				$t = table_objet_sql($r[1]);
586
-				$t = array_search($t, $boucles[$idb]->from);
587
-				if ($t) {
588
-					$t .= '.' . $r[2];
589
-				}
590
-			}
591
-		} else {
592
-			$t = '".'
593
-				. calculer_critere_arg_dynamique($idb, $boucles, $t)
594
-				. '."';
595
-		}
596
-	}
597
-	if ($t) {
598
-		$boucles[$idb]->group[] = $t;
599
-		if (!in_array($t, $boucles[$idb]->select)) {
600
-			$boucles[$idb]->select[] = $t;
601
-		}
602
-	} else {
603
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op . ' ?')));
604
-	}
580
+    if ($t = isset($crit->param[0])) {
581
+        $t = $crit->param[0];
582
+        if ($t[0]->type == 'texte') {
583
+            $t = $t[0]->texte;
584
+            if (preg_match("/^(.*)\.(.*)$/", $t, $r)) {
585
+                $t = table_objet_sql($r[1]);
586
+                $t = array_search($t, $boucles[$idb]->from);
587
+                if ($t) {
588
+                    $t .= '.' . $r[2];
589
+                }
590
+            }
591
+        } else {
592
+            $t = '".'
593
+                . calculer_critere_arg_dynamique($idb, $boucles, $t)
594
+                . '."';
595
+        }
596
+    }
597
+    if ($t) {
598
+        $boucles[$idb]->group[] = $t;
599
+        if (!in_array($t, $boucles[$idb]->select)) {
600
+            $boucles[$idb]->select[] = $t;
601
+        }
602
+    } else {
603
+        return (array('zbug_critere_inconnu', array('critere' => $crit->op . ' ?')));
604
+    }
605 605
 }
606 606
 
607 607
 /**
@@ -638,45 +638,45 @@  discard block
 block discarded – undo
638 638
  * @param Critere $crit Paramètres du critère dans cette boucle
639 639
  */
640 640
 function critere_collecte_dist($idb, &$boucles, $crit) {
641
-	if (isset($crit->param[0])) {
642
-		$_coll = calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
643
-		$boucle = $boucles[$idb];
644
-		$boucle->modificateur['collate'] = "($_coll ?' COLLATE '.$_coll:'')";
645
-		$n = count($boucle->order);
646
-		if ($n && (strpos($boucle->order[$n - 1], 'COLLATE') === false)) {
647
-			// l'instruction COLLATE doit être placée avant ASC ou DESC
648
-			// notamment lors de l'utilisation `{!par xxx}{collate yyy}`
649
-			if (
650
-				(false !== $i = strpos($boucle->order[$n - 1], 'ASC'))
651
-				OR (false !== $i = strpos($boucle->order[$n - 1], 'DESC'))
652
-			) {
653
-				$boucle->order[$n - 1] = substr_replace($boucle->order[$n - 1], "' . " . $boucle->modificateur['collate'] . " . ' ", $i, 0);
654
-			} else {
655
-				$boucle->order[$n - 1] .= " . " . $boucle->modificateur['collate'];
656
-			}
657
-		}
658
-	} else {
659
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op . " " . count($boucles[$idb]->order))));
660
-	}
641
+    if (isset($crit->param[0])) {
642
+        $_coll = calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
643
+        $boucle = $boucles[$idb];
644
+        $boucle->modificateur['collate'] = "($_coll ?' COLLATE '.$_coll:'')";
645
+        $n = count($boucle->order);
646
+        if ($n && (strpos($boucle->order[$n - 1], 'COLLATE') === false)) {
647
+            // l'instruction COLLATE doit être placée avant ASC ou DESC
648
+            // notamment lors de l'utilisation `{!par xxx}{collate yyy}`
649
+            if (
650
+                (false !== $i = strpos($boucle->order[$n - 1], 'ASC'))
651
+                OR (false !== $i = strpos($boucle->order[$n - 1], 'DESC'))
652
+            ) {
653
+                $boucle->order[$n - 1] = substr_replace($boucle->order[$n - 1], "' . " . $boucle->modificateur['collate'] . " . ' ", $i, 0);
654
+            } else {
655
+                $boucle->order[$n - 1] .= " . " . $boucle->modificateur['collate'];
656
+            }
657
+        }
658
+    } else {
659
+        return (array('zbug_critere_inconnu', array('critere' => $crit->op . " " . count($boucles[$idb]->order))));
660
+    }
661 661
 }
662 662
 
663 663
 // http://code.spip.net/@calculer_critere_arg_dynamique
664 664
 function calculer_critere_arg_dynamique($idb, &$boucles, $crit, $suffix = '') {
665
-	$boucle = $boucles[$idb];
666
-	$alt = "('" . $boucle->id_table . '.\' . $x' . $suffix . ')';
667
-	$var = '$champs_' . $idb;
668
-	$desc = (strpos($boucle->in, "static $var =") !== false);
669
-	if (!$desc) {
670
-		$desc = $boucle->show['field'];
671
-		$desc = implode(',', array_map('_q', array_keys($desc)));
672
-		$boucles[$idb]->in .= "\n\tstatic $var = array(" . $desc . ");";
673
-	}
674
-	if ($desc) {
675
-		$alt = "(in_array(\$x, $var)  ? $alt :(\$x$suffix))";
676
-	}
677
-	$arg = calculer_liste($crit, array(), $boucles, $boucle->id_parent);
678
-
679
-	return "((\$x = preg_replace(\"/\\W/\",'', $arg)) ? $alt : '')";
665
+    $boucle = $boucles[$idb];
666
+    $alt = "('" . $boucle->id_table . '.\' . $x' . $suffix . ')';
667
+    $var = '$champs_' . $idb;
668
+    $desc = (strpos($boucle->in, "static $var =") !== false);
669
+    if (!$desc) {
670
+        $desc = $boucle->show['field'];
671
+        $desc = implode(',', array_map('_q', array_keys($desc)));
672
+        $boucles[$idb]->in .= "\n\tstatic $var = array(" . $desc . ");";
673
+    }
674
+    if ($desc) {
675
+        $alt = "(in_array(\$x, $var)  ? $alt :(\$x$suffix))";
676
+    }
677
+    $arg = calculer_liste($crit, array(), $boucles, $boucle->id_parent);
678
+
679
+    return "((\$x = preg_replace(\"/\\W/\",'', $arg)) ? $alt : '')";
680 680
 }
681 681
 
682 682
 /**
@@ -715,7 +715,7 @@  discard block
 block discarded – undo
715 715
  * @param Critere $crit Paramètres du critère dans cette boucle
716 716
  */
717 717
 function critere_par_dist($idb, &$boucles, $crit) {
718
-	return critere_parinverse($idb, $boucles, $crit);
718
+    return critere_parinverse($idb, $boucles, $crit);
719 719
 }
720 720
 
721 721
 /**
@@ -737,93 +737,93 @@  discard block
 block discarded – undo
737 737
  * @param Critere $crit Paramètres du critère dans cette boucle
738 738
  */
739 739
 function critere_parinverse($idb, &$boucles, $crit) {
740
-	$boucle = &$boucles[$idb];
741
-
742
-	$sens = $collecte = '';
743
-	if ($crit->not) {
744
-		$sens = " . ' DESC'";
745
-	}
746
-	if (isset($boucle->modificateur['collate'])) {
747
-		$collecte = ' . ' . $boucle->modificateur['collate'];
748
-	}
749
-
750
-	// Pour chaque paramètre du critère
751
-	foreach ($crit->param as $tri) {
752
-		$order = $fct = '';
753
-		// tris specifiés dynamiquement {par #ENV{tri}}
754
-		if ($tri[0]->type != 'texte') {
755
-			// calculer le order dynamique qui verifie les champs
756
-			$order = calculer_critere_arg_dynamique($idb, $boucles, $tri, $sens);
757
-			// ajouter 'hasard' comme possibilité de tri dynamique
758
-			calculer_critere_par_hasard($idb, $boucles, $crit);
759
-		}
760
-		// tris textuels {par titre}
761
-		else {
762
-			$par = array_shift($tri);
763
-			$par = $par->texte;
764
-
765
-			// tris de la forme {par expression champ} tel que {par num titre} ou {par multi titre}
766
-			if (preg_match(",^(\w+)[\s]+(.*)$,", $par, $m)) {
767
-				$expression = trim($m[1]);
768
-				$champ = trim($m[2]);
769
-				if (function_exists($f = 'calculer_critere_par_expression_' . $expression)) {
770
-					$order = $f($idb, $boucles, $crit, $tri, $champ);
771
-				} else {
772
-					return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
773
-				}
774
-
775
-			// tris de la forme {par champ} ou {par FONCTION(champ)}
776
-			} elseif (preg_match(",^" . CHAMP_SQL_PLUS_FONC . '$,is', $par, $match)) {
777
-				// {par FONCTION(champ)}
778
-				if (count($match) > 2) {
779
-					$par = substr($match[2], 1, -1);
780
-					$fct = $match[1];
781
-				}
782
-				// quelques cas spécifiques {par hasard}, {par date}
783
-				if ($par == 'hasard') {
784
-					$order = calculer_critere_par_hasard($idb, $boucles, $crit);
785
-				} elseif ($par == 'date' and !empty($boucle->show['date'])) {
786
-					$order = "'" . $boucle->id_table . "." . $boucle->show['date'] . "'";
787
-				} else {
788
-					// cas général {par champ}, {par table.champ}, ...
789
-					$order = calculer_critere_par_champ($idb, $boucles, $crit, $par);
790
-				}
791
-			}
792
-
793
-			// on ne sait pas traiter…
794
-			else {
795
-				return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
796
-			}
797
-
798
-			// En cas d'erreur de squelette retournée par une fonction
799
-			if (is_array($order)) {
800
-				return $order;
801
-			}
802
-		}
803
-
804
-		if (preg_match('/^\'([^"]*)\'$/', $order, $m)) {
805
-			$t = $m[1];
806
-			if (strpos($t, '.') and !in_array($t, $boucle->select)) {
807
-				$boucle->select[] = $t;
808
-			}
809
-		} else {
810
-			$sens = '';
811
-		}
812
-
813
-		if ($fct) {
814
-			if (preg_match("/^\s*'(.*)'\s*$/", $order, $r)) {
815
-				$order = "'$fct(" . $r[1] . ")'";
816
-			} else {
817
-				$order = "'$fct(' . $order . ')'";
818
-			}
819
-		}
820
-		$t = $order . $collecte . $sens;
821
-		if (preg_match("/^(.*)'\s*\.\s*'([^']*')$/", $t, $r)) {
822
-			$t = $r[1] . $r[2];
823
-		}
824
-
825
-		$boucle->order[] = $t;
826
-	}
740
+    $boucle = &$boucles[$idb];
741
+
742
+    $sens = $collecte = '';
743
+    if ($crit->not) {
744
+        $sens = " . ' DESC'";
745
+    }
746
+    if (isset($boucle->modificateur['collate'])) {
747
+        $collecte = ' . ' . $boucle->modificateur['collate'];
748
+    }
749
+
750
+    // Pour chaque paramètre du critère
751
+    foreach ($crit->param as $tri) {
752
+        $order = $fct = '';
753
+        // tris specifiés dynamiquement {par #ENV{tri}}
754
+        if ($tri[0]->type != 'texte') {
755
+            // calculer le order dynamique qui verifie les champs
756
+            $order = calculer_critere_arg_dynamique($idb, $boucles, $tri, $sens);
757
+            // ajouter 'hasard' comme possibilité de tri dynamique
758
+            calculer_critere_par_hasard($idb, $boucles, $crit);
759
+        }
760
+        // tris textuels {par titre}
761
+        else {
762
+            $par = array_shift($tri);
763
+            $par = $par->texte;
764
+
765
+            // tris de la forme {par expression champ} tel que {par num titre} ou {par multi titre}
766
+            if (preg_match(",^(\w+)[\s]+(.*)$,", $par, $m)) {
767
+                $expression = trim($m[1]);
768
+                $champ = trim($m[2]);
769
+                if (function_exists($f = 'calculer_critere_par_expression_' . $expression)) {
770
+                    $order = $f($idb, $boucles, $crit, $tri, $champ);
771
+                } else {
772
+                    return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
773
+                }
774
+
775
+            // tris de la forme {par champ} ou {par FONCTION(champ)}
776
+            } elseif (preg_match(",^" . CHAMP_SQL_PLUS_FONC . '$,is', $par, $match)) {
777
+                // {par FONCTION(champ)}
778
+                if (count($match) > 2) {
779
+                    $par = substr($match[2], 1, -1);
780
+                    $fct = $match[1];
781
+                }
782
+                // quelques cas spécifiques {par hasard}, {par date}
783
+                if ($par == 'hasard') {
784
+                    $order = calculer_critere_par_hasard($idb, $boucles, $crit);
785
+                } elseif ($par == 'date' and !empty($boucle->show['date'])) {
786
+                    $order = "'" . $boucle->id_table . "." . $boucle->show['date'] . "'";
787
+                } else {
788
+                    // cas général {par champ}, {par table.champ}, ...
789
+                    $order = calculer_critere_par_champ($idb, $boucles, $crit, $par);
790
+                }
791
+            }
792
+
793
+            // on ne sait pas traiter…
794
+            else {
795
+                return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
796
+            }
797
+
798
+            // En cas d'erreur de squelette retournée par une fonction
799
+            if (is_array($order)) {
800
+                return $order;
801
+            }
802
+        }
803
+
804
+        if (preg_match('/^\'([^"]*)\'$/', $order, $m)) {
805
+            $t = $m[1];
806
+            if (strpos($t, '.') and !in_array($t, $boucle->select)) {
807
+                $boucle->select[] = $t;
808
+            }
809
+        } else {
810
+            $sens = '';
811
+        }
812
+
813
+        if ($fct) {
814
+            if (preg_match("/^\s*'(.*)'\s*$/", $order, $r)) {
815
+                $order = "'$fct(" . $r[1] . ")'";
816
+            } else {
817
+                $order = "'$fct(' . $order . ')'";
818
+            }
819
+        }
820
+        $t = $order . $collecte . $sens;
821
+        if (preg_match("/^(.*)'\s*\.\s*'([^']*')$/", $t, $r)) {
822
+            $t = $r[1] . $r[2];
823
+        }
824
+
825
+        $boucle->order[] = $t;
826
+    }
827 827
 }
828 828
 
829 829
 /**
@@ -837,13 +837,13 @@  discard block
 block discarded – undo
837 837
  * @return string Clause pour le Order by
838 838
  */
839 839
 function calculer_critere_par_hasard($idb, &$boucles, $crit) {
840
-	$boucle = &$boucles[$idb];
841
-	// Si ce n'est fait, ajouter un champ 'hasard' dans le select
842
-	$parha = "rand() AS hasard";
843
-	if (!in_array($parha, $boucle->select)) {
844
-		$boucle->select[] = $parha;
845
-	}
846
-	return "'hasard'";
840
+    $boucle = &$boucles[$idb];
841
+    // Si ce n'est fait, ajouter un champ 'hasard' dans le select
842
+    $parha = "rand() AS hasard";
843
+    if (!in_array($parha, $boucle->select)) {
844
+        $boucle->select[] = $parha;
845
+    }
846
+    return "'hasard'";
847 847
 }
848 848
 
849 849
 /**
@@ -867,20 +867,20 @@  discard block
 block discarded – undo
867 867
  * @return string Clause pour le Order by
868 868
  */
869 869
 function calculer_critere_par_expression_num($idb, &$boucles, $crit, $tri, $champ) {
870
-	$_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
871
-	if (is_array($_champ)) {
872
-		return array('zbug_critere_inconnu', array('critere' => $crit->op . " num $champ"));
873
-	}
874
-	$boucle = &$boucles[$idb];
875
-	$texte = '0+' . $_champ;
876
-	$suite = calculer_liste($tri, array(), $boucles, $boucle->id_parent);
877
-	if ($suite !== "''") {
878
-		$texte = "\" . ((\$x = $suite) ? ('$texte' . \$x) : '0')" . " . \"";
879
-	}
880
-	$as = 'num' . ($boucle->order ? count($boucle->order) : "");
881
-	$boucle->select[] = $texte . " AS $as";
882
-	$order = "'$as'";
883
-	return $order;
870
+    $_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
871
+    if (is_array($_champ)) {
872
+        return array('zbug_critere_inconnu', array('critere' => $crit->op . " num $champ"));
873
+    }
874
+    $boucle = &$boucles[$idb];
875
+    $texte = '0+' . $_champ;
876
+    $suite = calculer_liste($tri, array(), $boucles, $boucle->id_parent);
877
+    if ($suite !== "''") {
878
+        $texte = "\" . ((\$x = $suite) ? ('$texte' . \$x) : '0')" . " . \"";
879
+    }
880
+    $as = 'num' . ($boucle->order ? count($boucle->order) : "");
881
+    $boucle->select[] = $texte . " AS $as";
882
+    $order = "'$as'";
883
+    return $order;
884 884
 }
885 885
 
886 886
 /**
@@ -901,20 +901,20 @@  discard block
 block discarded – undo
901 901
  * @return string Clause pour le Order by
902 902
  */
903 903
 function calculer_critere_par_expression_sinum($idb, &$boucles, $crit, $tri, $champ) {
904
-	$_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
905
-	if (is_array($_champ)) {
906
-		return array('zbug_critere_inconnu', array('critere' => $crit->op . " sinum $champ"));
907
-	}
908
-	$boucle = &$boucles[$idb];
909
-	$texte = '0+' . $_champ;
910
-	$suite = calculer_liste($tri, array(), $boucles, $boucle->id_parent);
911
-	if ($suite !== "''") {
912
-		$texte = "\" . ((\$x = $suite) ? ('$texte' . \$x) : '0')" . " . \"";
913
-	}
914
-	$as = 'sinum' . ($boucle->order ? count($boucle->order) : "");
915
-	$boucle->select[] = 'CASE (' . $texte . ') WHEN 0 THEN 1 ELSE 0 END AS ' . $as;
916
-	$order = "'$as'";
917
-	return $order;
904
+    $_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
905
+    if (is_array($_champ)) {
906
+        return array('zbug_critere_inconnu', array('critere' => $crit->op . " sinum $champ"));
907
+    }
908
+    $boucle = &$boucles[$idb];
909
+    $texte = '0+' . $_champ;
910
+    $suite = calculer_liste($tri, array(), $boucles, $boucle->id_parent);
911
+    if ($suite !== "''") {
912
+        $texte = "\" . ((\$x = $suite) ? ('$texte' . \$x) : '0')" . " . \"";
913
+    }
914
+    $as = 'sinum' . ($boucle->order ? count($boucle->order) : "");
915
+    $boucle->select[] = 'CASE (' . $texte . ') WHEN 0 THEN 1 ELSE 0 END AS ' . $as;
916
+    $order = "'$as'";
917
+    return $order;
918 918
 }
919 919
 
920 920
 
@@ -934,14 +934,14 @@  discard block
 block discarded – undo
934 934
  * @return string Clause pour le Order by
935 935
  */
936 936
 function calculer_critere_par_expression_multi($idb, &$boucles, $crit, $tri, $champ) {
937
-	$_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
938
-	if (is_array($_champ)) {
939
-		return array('zbug_critere_inconnu', array('critere' => $crit->op . " multi $champ"));
940
-	}
941
-	$boucle = &$boucles[$idb];
942
-	$boucle->select[] = "\".sql_multi('" . $_champ . "', \$GLOBALS['spip_lang']).\"";
943
-	$order = "'multi'";
944
-	return $order;
937
+    $_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
938
+    if (is_array($_champ)) {
939
+        return array('zbug_critere_inconnu', array('critere' => $crit->op . " multi $champ"));
940
+    }
941
+    $boucle = &$boucles[$idb];
942
+    $boucle->select[] = "\".sql_multi('" . $_champ . "', \$GLOBALS['spip_lang']).\"";
943
+    $order = "'multi'";
944
+    return $order;
945 945
 }
946 946
 
947 947
 /**
@@ -960,56 +960,56 @@  discard block
 block discarded – undo
960 960
  * @return array|string
961 961
  */
962 962
 function calculer_critere_par_champ($idb, &$boucles, $crit,  $par, $raw = false) {
963
-	$boucle = &$boucles[$idb];
964
-	$desc = $boucle->show;
965
-
966
-	// le champ existe dans la table, pas de souci (le plus commun)
967
-	if (isset($desc['field'][$par])) {
968
-		$par = $boucle->id_table . "." . $par;
969
-	}
970
-	// le champ est peut être une jointure
971
-	else {
972
-		$table = $table_alias = false; // toutes les tables de jointure possibles
973
-		$champ = $par;
974
-
975
-		// le champ demandé est une exception de jointure {par titre_mot}
976
-		if (isset($GLOBALS['exceptions_des_jointures'][$par])) {
977
-			list($table, $champ) = $GLOBALS['exceptions_des_jointures'][$par];
978
-		} // la table de jointure est explicitement indiquée {par truc.muche}
979
-		elseif (preg_match("/^([^,]*)\.(.*)$/", $par, $r)) {
980
-			list(, $table, $champ) = $r;
981
-			$table_alias = $table; // c'est peut-être un alias de table {par L1.titre}
982
-			$table = table_objet_sql($table);
983
-		}
984
-
985
-		// Si on connait la table d'arrivée, on la demande donc explicitement
986
-		// Sinon on cherche le champ dans les tables possibles de jointures
987
-		// Si la table est déjà dans le from, on la réutilise.
988
-		if ($infos = chercher_champ_dans_tables($champ, $boucle->from, $boucle->sql_serveur, $table)) {
989
-			$par = $infos['alias'] . "." . $champ;
990
-		} elseif (
991
-			$boucle->jointures_explicites
992
-			and $alias = trouver_jointure_champ($champ, $boucle, explode(' ', $boucle->jointures_explicites), false, $table)
993
-		) {
994
-			$par = $alias . "." . $champ;
995
-		} elseif ($alias = trouver_jointure_champ($champ, $boucle, $boucle->jointures, false, $table)) {
996
-			$par = $alias . "." . $champ;
997
-		// en spécifiant directement l'alias {par L2.titre} (situation hasardeuse tout de même)
998
-		} elseif (
999
-			$table_alias
1000
-			and isset($boucle->from[$table_alias])
1001
-			and $infos = chercher_champ_dans_tables($champ, $boucle->from, $boucle->sql_serveur, $boucle->from[$table_alias])
1002
-		) {
1003
-			$par = $infos['alias'] . "." . $champ;
1004
-		} elseif ($table) {
1005
-			// On avait table + champ, mais on ne les a pas trouvés
1006
-			return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
1007
-		} else {
1008
-			// Sinon tant pis, ca doit etre un champ synthetise (cf points)
1009
-		}
1010
-	}
1011
-
1012
-	return $raw ? $par : "'$par'";
963
+    $boucle = &$boucles[$idb];
964
+    $desc = $boucle->show;
965
+
966
+    // le champ existe dans la table, pas de souci (le plus commun)
967
+    if (isset($desc['field'][$par])) {
968
+        $par = $boucle->id_table . "." . $par;
969
+    }
970
+    // le champ est peut être une jointure
971
+    else {
972
+        $table = $table_alias = false; // toutes les tables de jointure possibles
973
+        $champ = $par;
974
+
975
+        // le champ demandé est une exception de jointure {par titre_mot}
976
+        if (isset($GLOBALS['exceptions_des_jointures'][$par])) {
977
+            list($table, $champ) = $GLOBALS['exceptions_des_jointures'][$par];
978
+        } // la table de jointure est explicitement indiquée {par truc.muche}
979
+        elseif (preg_match("/^([^,]*)\.(.*)$/", $par, $r)) {
980
+            list(, $table, $champ) = $r;
981
+            $table_alias = $table; // c'est peut-être un alias de table {par L1.titre}
982
+            $table = table_objet_sql($table);
983
+        }
984
+
985
+        // Si on connait la table d'arrivée, on la demande donc explicitement
986
+        // Sinon on cherche le champ dans les tables possibles de jointures
987
+        // Si la table est déjà dans le from, on la réutilise.
988
+        if ($infos = chercher_champ_dans_tables($champ, $boucle->from, $boucle->sql_serveur, $table)) {
989
+            $par = $infos['alias'] . "." . $champ;
990
+        } elseif (
991
+            $boucle->jointures_explicites
992
+            and $alias = trouver_jointure_champ($champ, $boucle, explode(' ', $boucle->jointures_explicites), false, $table)
993
+        ) {
994
+            $par = $alias . "." . $champ;
995
+        } elseif ($alias = trouver_jointure_champ($champ, $boucle, $boucle->jointures, false, $table)) {
996
+            $par = $alias . "." . $champ;
997
+        // en spécifiant directement l'alias {par L2.titre} (situation hasardeuse tout de même)
998
+        } elseif (
999
+            $table_alias
1000
+            and isset($boucle->from[$table_alias])
1001
+            and $infos = chercher_champ_dans_tables($champ, $boucle->from, $boucle->sql_serveur, $boucle->from[$table_alias])
1002
+        ) {
1003
+            $par = $infos['alias'] . "." . $champ;
1004
+        } elseif ($table) {
1005
+            // On avait table + champ, mais on ne les a pas trouvés
1006
+            return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
1007
+        } else {
1008
+            // Sinon tant pis, ca doit etre un champ synthetise (cf points)
1009
+        }
1010
+    }
1011
+
1012
+    return $raw ? $par : "'$par'";
1013 1013
 }
1014 1014
 
1015 1015
 /**
@@ -1023,11 +1023,11 @@  discard block
 block discarded – undo
1023 1023
  * @return string Champ pour le compilateur si trouvé, tel que "'alias.champ'", sinon vide.
1024 1024
  */
1025 1025
 function critere_par_joint($table, $champ, &$boucle) {
1026
-	$t = array_search($table, $boucle->from);
1027
-	if (!$t) {
1028
-		$t = trouver_jointure_champ($champ, $boucle);
1029
-	}
1030
-	return !$t ? '' : ("'" . $t . '.' . $champ . "'");
1026
+    $t = array_search($table, $boucle->from);
1027
+    if (!$t) {
1028
+        $t = trouver_jointure_champ($champ, $boucle);
1029
+    }
1030
+    return !$t ? '' : ("'" . $t . '.' . $champ . "'");
1031 1031
 }
1032 1032
 
1033 1033
 /**
@@ -1052,143 +1052,143 @@  discard block
 block discarded – undo
1052 1052
  */
1053 1053
 function critere_inverse_dist($idb, &$boucles, $crit) {
1054 1054
 
1055
-	$boucle = &$boucles[$idb];
1056
-	// Classement par ordre inverse
1057
-	if ($crit->not) {
1058
-		critere_parinverse($idb, $boucles, $crit);
1059
-	} else {
1060
-		$order = "' DESC'";
1061
-		// Classement par ordre inverse fonction eventuelle de #ENV{...}
1062
-		if (isset($crit->param[0])) {
1063
-			$critere = calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
1064
-			$order = "(($critere)?' DESC':'')";
1065
-		}
1066
-
1067
-		$n = count($boucle->order);
1068
-		if (!$n) {
1069
-			if (isset($boucle->default_order[0])) {
1070
-				$boucle->default_order[0] .= ' . " DESC"';
1071
-			} else {
1072
-				$boucle->default_order[] = ' DESC';
1073
-			}
1074
-		} else {
1075
-			$t = $boucle->order[$n - 1] . " . $order";
1076
-			if (preg_match("/^(.*)'\s*\.\s*'([^']*')$/", $t, $r)) {
1077
-				$t = $r[1] . $r[2];
1078
-			}
1079
-			$boucle->order[$n - 1] = $t;
1080
-		}
1081
-	}
1055
+    $boucle = &$boucles[$idb];
1056
+    // Classement par ordre inverse
1057
+    if ($crit->not) {
1058
+        critere_parinverse($idb, $boucles, $crit);
1059
+    } else {
1060
+        $order = "' DESC'";
1061
+        // Classement par ordre inverse fonction eventuelle de #ENV{...}
1062
+        if (isset($crit->param[0])) {
1063
+            $critere = calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
1064
+            $order = "(($critere)?' DESC':'')";
1065
+        }
1066
+
1067
+        $n = count($boucle->order);
1068
+        if (!$n) {
1069
+            if (isset($boucle->default_order[0])) {
1070
+                $boucle->default_order[0] .= ' . " DESC"';
1071
+            } else {
1072
+                $boucle->default_order[] = ' DESC';
1073
+            }
1074
+        } else {
1075
+            $t = $boucle->order[$n - 1] . " . $order";
1076
+            if (preg_match("/^(.*)'\s*\.\s*'([^']*')$/", $t, $r)) {
1077
+                $t = $r[1] . $r[2];
1078
+            }
1079
+            $boucle->order[$n - 1] = $t;
1080
+        }
1081
+    }
1082 1082
 }
1083 1083
 
1084 1084
 // http://code.spip.net/@critere_agenda_dist
1085 1085
 function critere_agenda_dist($idb, &$boucles, $crit) {
1086
-	$params = $crit->param;
1087
-
1088
-	if (count($params) < 1) {
1089
-		return array('zbug_critere_inconnu', array('critere' => $crit->op . " ?"));
1090
-	}
1091
-
1092
-	$boucle = &$boucles[$idb];
1093
-	$parent = $boucle->id_parent;
1094
-	$fields = $boucle->show['field'];
1095
-
1096
-	$date = array_shift($params);
1097
-	$type = array_shift($params);
1098
-
1099
-	// la valeur $type doit etre connue a la compilation
1100
-	// donc etre forcement reduite a un litteral unique dans le source
1101
-	$type = is_object($type[0]) ? $type[0]->texte : null;
1102
-
1103
-	// La valeur date doit designer un champ de la table SQL.
1104
-	// Si c'est un litteral unique dans le source, verifier a la compil,
1105
-	// sinon synthetiser le test de verif pour execution ulterieure
1106
-	// On prendra arbitrairement le premier champ si test negatif.
1107
-	if ((count($date) == 1) and ($date[0]->type == 'texte')) {
1108
-		$date = $date[0]->texte;
1109
-		if (!isset($fields[$date])) {
1110
-			return array('zbug_critere_inconnu', array('critere' => $crit->op . " " . $date));
1111
-		}
1112
-	} else {
1113
-		$a = calculer_liste($date, array(), $boucles, $parent);
1114
-		$noms = array_keys($fields);
1115
-		$defaut = $noms[0];
1116
-		$noms = join(" ", $noms);
1117
-		# bien laisser 2 espaces avant $nom pour que strpos<>0
1118
-		$cond = "(\$a=strval($a))AND\nstrpos(\"  $noms \",\" \$a \")";
1119
-		$date = "'.(($cond)\n?\$a:\"$defaut\").'";
1120
-	}
1121
-	$annee = $params ? array_shift($params) : "";
1122
-	$annee = "\n" . 'sprintf("%04d", ($x = ' .
1123
-		calculer_liste($annee, array(), $boucles, $parent) .
1124
-		') ? $x : date("Y"))';
1125
-
1126
-	$mois = $params ? array_shift($params) : "";
1127
-	$mois = "\n" . 'sprintf("%02d", ($x = ' .
1128
-		calculer_liste($mois, array(), $boucles, $parent) .
1129
-		') ? $x : date("m"))';
1130
-
1131
-	$jour = $params ? array_shift($params) : "";
1132
-	$jour = "\n" . 'sprintf("%02d", ($x = ' .
1133
-		calculer_liste($jour, array(), $boucles, $parent) .
1134
-		') ? $x : date("d"))';
1135
-
1136
-	$annee2 = $params ? array_shift($params) : "";
1137
-	$annee2 = "\n" . 'sprintf("%04d", ($x = ' .
1138
-		calculer_liste($annee2, array(), $boucles, $parent) .
1139
-		') ? $x : date("Y"))';
1140
-
1141
-	$mois2 = $params ? array_shift($params) : "";
1142
-	$mois2 = "\n" . 'sprintf("%02d", ($x = ' .
1143
-		calculer_liste($mois2, array(), $boucles, $parent) .
1144
-		') ? $x : date("m"))';
1145
-
1146
-	$jour2 = $params ? array_shift($params) : "";
1147
-	$jour2 = "\n" . 'sprintf("%02d", ($x = ' .
1148
-		calculer_liste($jour2, array(), $boucles, $parent) .
1149
-		') ? $x : date("d"))';
1150
-
1151
-	$date = $boucle->id_table . ".$date";
1152
-
1153
-	$quote_end = ",'" . $boucle->sql_serveur . "','text'";
1154
-	if ($type == 'jour') {
1155
-		$boucle->where[] = array(
1156
-			"'='",
1157
-			"'DATE_FORMAT($date, \'%Y%m%d\')'",
1158
-			("sql_quote($annee . $mois . $jour$quote_end)")
1159
-		);
1160
-	} elseif ($type == 'mois') {
1161
-		$boucle->where[] = array(
1162
-			"'='",
1163
-			"'DATE_FORMAT($date, \'%Y%m\')'",
1164
-			("sql_quote($annee . $mois$quote_end)")
1165
-		);
1166
-	} elseif ($type == 'semaine') {
1167
-		$boucle->where[] = array(
1168
-			"'AND'",
1169
-			array(
1170
-				"'>='",
1171
-				"'DATE_FORMAT($date, \'%Y%m%d\')'",
1172
-				("date_debut_semaine($annee, $mois, $jour)")
1173
-			),
1174
-			array(
1175
-				"'<='",
1176
-				"'DATE_FORMAT($date, \'%Y%m%d\')'",
1177
-				("date_fin_semaine($annee, $mois, $jour)")
1178
-			)
1179
-		);
1180
-	} elseif (count($crit->param) > 2) {
1181
-		$boucle->where[] = array(
1182
-			"'AND'",
1183
-			array(
1184
-				"'>='",
1185
-				"'DATE_FORMAT($date, \'%Y%m%d\')'",
1186
-				("sql_quote($annee . $mois . $jour$quote_end)")
1187
-			),
1188
-			array("'<='", "'DATE_FORMAT($date, \'%Y%m%d\')'", ("sql_quote($annee2 . $mois2 . $jour2$quote_end)"))
1189
-		);
1190
-	}
1191
-	// sinon on prend tout
1086
+    $params = $crit->param;
1087
+
1088
+    if (count($params) < 1) {
1089
+        return array('zbug_critere_inconnu', array('critere' => $crit->op . " ?"));
1090
+    }
1091
+
1092
+    $boucle = &$boucles[$idb];
1093
+    $parent = $boucle->id_parent;
1094
+    $fields = $boucle->show['field'];
1095
+
1096
+    $date = array_shift($params);
1097
+    $type = array_shift($params);
1098
+
1099
+    // la valeur $type doit etre connue a la compilation
1100
+    // donc etre forcement reduite a un litteral unique dans le source
1101
+    $type = is_object($type[0]) ? $type[0]->texte : null;
1102
+
1103
+    // La valeur date doit designer un champ de la table SQL.
1104
+    // Si c'est un litteral unique dans le source, verifier a la compil,
1105
+    // sinon synthetiser le test de verif pour execution ulterieure
1106
+    // On prendra arbitrairement le premier champ si test negatif.
1107
+    if ((count($date) == 1) and ($date[0]->type == 'texte')) {
1108
+        $date = $date[0]->texte;
1109
+        if (!isset($fields[$date])) {
1110
+            return array('zbug_critere_inconnu', array('critere' => $crit->op . " " . $date));
1111
+        }
1112
+    } else {
1113
+        $a = calculer_liste($date, array(), $boucles, $parent);
1114
+        $noms = array_keys($fields);
1115
+        $defaut = $noms[0];
1116
+        $noms = join(" ", $noms);
1117
+        # bien laisser 2 espaces avant $nom pour que strpos<>0
1118
+        $cond = "(\$a=strval($a))AND\nstrpos(\"  $noms \",\" \$a \")";
1119
+        $date = "'.(($cond)\n?\$a:\"$defaut\").'";
1120
+    }
1121
+    $annee = $params ? array_shift($params) : "";
1122
+    $annee = "\n" . 'sprintf("%04d", ($x = ' .
1123
+        calculer_liste($annee, array(), $boucles, $parent) .
1124
+        ') ? $x : date("Y"))';
1125
+
1126
+    $mois = $params ? array_shift($params) : "";
1127
+    $mois = "\n" . 'sprintf("%02d", ($x = ' .
1128
+        calculer_liste($mois, array(), $boucles, $parent) .
1129
+        ') ? $x : date("m"))';
1130
+
1131
+    $jour = $params ? array_shift($params) : "";
1132
+    $jour = "\n" . 'sprintf("%02d", ($x = ' .
1133
+        calculer_liste($jour, array(), $boucles, $parent) .
1134
+        ') ? $x : date("d"))';
1135
+
1136
+    $annee2 = $params ? array_shift($params) : "";
1137
+    $annee2 = "\n" . 'sprintf("%04d", ($x = ' .
1138
+        calculer_liste($annee2, array(), $boucles, $parent) .
1139
+        ') ? $x : date("Y"))';
1140
+
1141
+    $mois2 = $params ? array_shift($params) : "";
1142
+    $mois2 = "\n" . 'sprintf("%02d", ($x = ' .
1143
+        calculer_liste($mois2, array(), $boucles, $parent) .
1144
+        ') ? $x : date("m"))';
1145
+
1146
+    $jour2 = $params ? array_shift($params) : "";
1147
+    $jour2 = "\n" . 'sprintf("%02d", ($x = ' .
1148
+        calculer_liste($jour2, array(), $boucles, $parent) .
1149
+        ') ? $x : date("d"))';
1150
+
1151
+    $date = $boucle->id_table . ".$date";
1152
+
1153
+    $quote_end = ",'" . $boucle->sql_serveur . "','text'";
1154
+    if ($type == 'jour') {
1155
+        $boucle->where[] = array(
1156
+            "'='",
1157
+            "'DATE_FORMAT($date, \'%Y%m%d\')'",
1158
+            ("sql_quote($annee . $mois . $jour$quote_end)")
1159
+        );
1160
+    } elseif ($type == 'mois') {
1161
+        $boucle->where[] = array(
1162
+            "'='",
1163
+            "'DATE_FORMAT($date, \'%Y%m\')'",
1164
+            ("sql_quote($annee . $mois$quote_end)")
1165
+        );
1166
+    } elseif ($type == 'semaine') {
1167
+        $boucle->where[] = array(
1168
+            "'AND'",
1169
+            array(
1170
+                "'>='",
1171
+                "'DATE_FORMAT($date, \'%Y%m%d\')'",
1172
+                ("date_debut_semaine($annee, $mois, $jour)")
1173
+            ),
1174
+            array(
1175
+                "'<='",
1176
+                "'DATE_FORMAT($date, \'%Y%m%d\')'",
1177
+                ("date_fin_semaine($annee, $mois, $jour)")
1178
+            )
1179
+        );
1180
+    } elseif (count($crit->param) > 2) {
1181
+        $boucle->where[] = array(
1182
+            "'AND'",
1183
+            array(
1184
+                "'>='",
1185
+                "'DATE_FORMAT($date, \'%Y%m%d\')'",
1186
+                ("sql_quote($annee . $mois . $jour$quote_end)")
1187
+            ),
1188
+            array("'<='", "'DATE_FORMAT($date, \'%Y%m%d\')'", ("sql_quote($annee2 . $mois2 . $jour2$quote_end)"))
1189
+        );
1190
+    }
1191
+    // sinon on prend tout
1192 1192
 }
1193 1193
 
1194 1194
 
@@ -1213,33 +1213,33 @@  discard block
 block discarded – undo
1213 1213
  * @return void
1214 1214
  **/
1215 1215
 function calculer_critere_parties($idb, &$boucles, $crit) {
1216
-	$boucle = &$boucles[$idb];
1217
-	$a1 = $crit->param[0];
1218
-	$a2 = $crit->param[1];
1219
-	$op = $crit->op;
1220
-
1221
-	list($a11, $a12) = calculer_critere_parties_aux($idb, $boucles, $a1);
1222
-	list($a21, $a22) = calculer_critere_parties_aux($idb, $boucles, $a2);
1223
-
1224
-	if (($op == ',') && (is_numeric($a11) && (is_numeric($a21)))) {
1225
-		$boucle->limit = $a11 . ',' . $a21;
1226
-	} else {
1227
-		// 3 dans {1/3}, {2,3} ou {1,n-3}
1228
-		$boucle->total_parties = ($a21 != 'n') ? $a21 : $a22;
1229
-		// 2 dans {2/3}, {2,5}, {n-2,1}
1230
-		$partie = ($a11 != 'n') ? $a11 : $a12;
1231
-		$mode = (($op == '/') ? '/' :
1232
-			(($a11 == 'n') ? '-' : '+') . (($a21 == 'n') ? '-' : '+'));
1233
-		// cas simple {0,#ENV{truc}} compilons le en LIMIT :
1234
-		if ($a11 !== 'n' and $a21 !== 'n' and $mode == "++" and $op == ',') {
1235
-			$boucle->limit =
1236
-				(is_numeric($a11) ? "'$a11'" : $a11)
1237
-				. ".','."
1238
-				. (is_numeric($a21) ? "'$a21'" : $a21);
1239
-		} else {
1240
-			calculer_parties($boucles, $idb, $partie, $mode);
1241
-		}
1242
-	}
1216
+    $boucle = &$boucles[$idb];
1217
+    $a1 = $crit->param[0];
1218
+    $a2 = $crit->param[1];
1219
+    $op = $crit->op;
1220
+
1221
+    list($a11, $a12) = calculer_critere_parties_aux($idb, $boucles, $a1);
1222
+    list($a21, $a22) = calculer_critere_parties_aux($idb, $boucles, $a2);
1223
+
1224
+    if (($op == ',') && (is_numeric($a11) && (is_numeric($a21)))) {
1225
+        $boucle->limit = $a11 . ',' . $a21;
1226
+    } else {
1227
+        // 3 dans {1/3}, {2,3} ou {1,n-3}
1228
+        $boucle->total_parties = ($a21 != 'n') ? $a21 : $a22;
1229
+        // 2 dans {2/3}, {2,5}, {n-2,1}
1230
+        $partie = ($a11 != 'n') ? $a11 : $a12;
1231
+        $mode = (($op == '/') ? '/' :
1232
+            (($a11 == 'n') ? '-' : '+') . (($a21 == 'n') ? '-' : '+'));
1233
+        // cas simple {0,#ENV{truc}} compilons le en LIMIT :
1234
+        if ($a11 !== 'n' and $a21 !== 'n' and $mode == "++" and $op == ',') {
1235
+            $boucle->limit =
1236
+                (is_numeric($a11) ? "'$a11'" : $a11)
1237
+                . ".','."
1238
+                . (is_numeric($a21) ? "'$a21'" : $a21);
1239
+        } else {
1240
+            calculer_parties($boucles, $idb, $partie, $mode);
1241
+        }
1242
+    }
1243 1243
 }
1244 1244
 
1245 1245
 /**
@@ -1267,63 +1267,63 @@  discard block
 block discarded – undo
1267 1267
  * @return void
1268 1268
  **/
1269 1269
 function calculer_parties(&$boucles, $id_boucle, $debut, $mode) {
1270
-	$total_parties = $boucles[$id_boucle]->total_parties;
1271
-
1272
-	preg_match(",([+-/p])([+-/])?,", $mode, $regs);
1273
-	list(, $op1, $op2) = array_pad($regs, 3, null);
1274
-	$nombre_boucle = "\$Numrows['$id_boucle']['total']";
1275
-	// {1/3}
1276
-	if ($op1 == '/') {
1277
-		$pmoins1 = is_numeric($debut) ? ($debut - 1) : "($debut-1)";
1278
-		$totpos = is_numeric($total_parties) ? ($total_parties) :
1279
-			"($total_parties ? $total_parties : 1)";
1280
-		$fin = "ceil(($nombre_boucle * $debut )/$totpos) - 1";
1281
-		$debut = !$pmoins1 ? 0 : "ceil(($nombre_boucle * $pmoins1)/$totpos);";
1282
-	} else {
1283
-		// cas {n-1,x}
1284
-		if ($op1 == '-') {
1285
-			$debut = "$nombre_boucle - $debut;";
1286
-		}
1287
-
1288
-		// cas {x,n-1}
1289
-		if ($op2 == '-') {
1290
-			$fin = '$debut_boucle + ' . $nombre_boucle . ' - '
1291
-				. (is_numeric($total_parties) ? ($total_parties + 1) :
1292
-					($total_parties . ' - 1'));
1293
-		} else {
1294
-			// {x,1} ou {pagination}
1295
-			$fin = '$debut_boucle'
1296
-				. (is_numeric($total_parties) ?
1297
-					(($total_parties == 1) ? "" : (' + ' . ($total_parties - 1))) :
1298
-					('+' . $total_parties . ' - 1'));
1299
-		}
1300
-
1301
-		// {pagination}, gerer le debut_xx=-1 pour tout voir
1302
-		if ($op1 == 'p') {
1303
-			$debut .= ";\n	\$debut_boucle = ((\$tout=(\$debut_boucle == -1))?0:(\$debut_boucle))";
1304
-			$debut .= ";\n	\$debut_boucle = max(0,min(\$debut_boucle,floor(($nombre_boucle-1)/($total_parties))*($total_parties)))";
1305
-			$fin = "(\$tout ? $nombre_boucle : $fin)";
1306
-		}
1307
-	}
1308
-
1309
-	// Notes :
1310
-	// $debut_boucle et $fin_boucle sont les indices SQL du premier
1311
-	// et du dernier demandes dans la boucle : 0 pour le premier,
1312
-	// n-1 pour le dernier ; donc total_boucle = 1 + debut - fin
1313
-	// Utiliser min pour rabattre $fin_boucle sur total_boucle.
1314
-
1315
-	$boucles[$id_boucle]->mode_partie = "\n\t"
1316
-		. '$debut_boucle = ' . $debut . ";\n	"
1317
-		. "\$debut_boucle = intval(\$debut_boucle);\n	"
1318
-		. '$fin_boucle = min(' . $fin . ", \$Numrows['$id_boucle']['total'] - 1);\n	"
1319
-		. '$Numrows[\'' . $id_boucle . "']['grand_total'] = \$Numrows['$id_boucle']['total'];\n	"
1320
-		. '$Numrows[\'' . $id_boucle . '\']["total"] = max(0,$fin_boucle - $debut_boucle + 1);'
1321
-		. "\n\tif (\$debut_boucle>0"
1322
-		. " AND \$debut_boucle < \$Numrows['$id_boucle']['grand_total']"
1323
-		. " AND \$iter->seek(\$debut_boucle,'continue'))"
1324
-		. "\n\t\t\$Numrows['$id_boucle']['compteur_boucle'] = \$debut_boucle;\n\t";
1325
-
1326
-	$boucles[$id_boucle]->partie = "
1270
+    $total_parties = $boucles[$id_boucle]->total_parties;
1271
+
1272
+    preg_match(",([+-/p])([+-/])?,", $mode, $regs);
1273
+    list(, $op1, $op2) = array_pad($regs, 3, null);
1274
+    $nombre_boucle = "\$Numrows['$id_boucle']['total']";
1275
+    // {1/3}
1276
+    if ($op1 == '/') {
1277
+        $pmoins1 = is_numeric($debut) ? ($debut - 1) : "($debut-1)";
1278
+        $totpos = is_numeric($total_parties) ? ($total_parties) :
1279
+            "($total_parties ? $total_parties : 1)";
1280
+        $fin = "ceil(($nombre_boucle * $debut )/$totpos) - 1";
1281
+        $debut = !$pmoins1 ? 0 : "ceil(($nombre_boucle * $pmoins1)/$totpos);";
1282
+    } else {
1283
+        // cas {n-1,x}
1284
+        if ($op1 == '-') {
1285
+            $debut = "$nombre_boucle - $debut;";
1286
+        }
1287
+
1288
+        // cas {x,n-1}
1289
+        if ($op2 == '-') {
1290
+            $fin = '$debut_boucle + ' . $nombre_boucle . ' - '
1291
+                . (is_numeric($total_parties) ? ($total_parties + 1) :
1292
+                    ($total_parties . ' - 1'));
1293
+        } else {
1294
+            // {x,1} ou {pagination}
1295
+            $fin = '$debut_boucle'
1296
+                . (is_numeric($total_parties) ?
1297
+                    (($total_parties == 1) ? "" : (' + ' . ($total_parties - 1))) :
1298
+                    ('+' . $total_parties . ' - 1'));
1299
+        }
1300
+
1301
+        // {pagination}, gerer le debut_xx=-1 pour tout voir
1302
+        if ($op1 == 'p') {
1303
+            $debut .= ";\n	\$debut_boucle = ((\$tout=(\$debut_boucle == -1))?0:(\$debut_boucle))";
1304
+            $debut .= ";\n	\$debut_boucle = max(0,min(\$debut_boucle,floor(($nombre_boucle-1)/($total_parties))*($total_parties)))";
1305
+            $fin = "(\$tout ? $nombre_boucle : $fin)";
1306
+        }
1307
+    }
1308
+
1309
+    // Notes :
1310
+    // $debut_boucle et $fin_boucle sont les indices SQL du premier
1311
+    // et du dernier demandes dans la boucle : 0 pour le premier,
1312
+    // n-1 pour le dernier ; donc total_boucle = 1 + debut - fin
1313
+    // Utiliser min pour rabattre $fin_boucle sur total_boucle.
1314
+
1315
+    $boucles[$id_boucle]->mode_partie = "\n\t"
1316
+        . '$debut_boucle = ' . $debut . ";\n	"
1317
+        . "\$debut_boucle = intval(\$debut_boucle);\n	"
1318
+        . '$fin_boucle = min(' . $fin . ", \$Numrows['$id_boucle']['total'] - 1);\n	"
1319
+        . '$Numrows[\'' . $id_boucle . "']['grand_total'] = \$Numrows['$id_boucle']['total'];\n	"
1320
+        . '$Numrows[\'' . $id_boucle . '\']["total"] = max(0,$fin_boucle - $debut_boucle + 1);'
1321
+        . "\n\tif (\$debut_boucle>0"
1322
+        . " AND \$debut_boucle < \$Numrows['$id_boucle']['grand_total']"
1323
+        . " AND \$iter->seek(\$debut_boucle,'continue'))"
1324
+        . "\n\t\t\$Numrows['$id_boucle']['compteur_boucle'] = \$debut_boucle;\n\t";
1325
+
1326
+    $boucles[$id_boucle]->partie = "
1327 1327
 		if (\$Numrows['$id_boucle']['compteur_boucle'] <= \$debut_boucle) continue;
1328 1328
 		if (\$Numrows['$id_boucle']['compteur_boucle']-1 > \$fin_boucle) break;";
1329 1329
 }
@@ -1340,26 +1340,26 @@  discard block
 block discarded – undo
1340 1340
  * @return array          Valeur de l'élément (peut être une expression PHP), Nombre soustrait
1341 1341
  **/
1342 1342
 function calculer_critere_parties_aux($idb, &$boucles, $param) {
1343
-	if ($param[0]->type != 'texte') {
1344
-		$a1 = calculer_liste(array($param[0]), array('id_mere' => $idb), $boucles, $boucles[$idb]->id_parent);
1345
-		if (isset($param[1]->texte)) {
1346
-			preg_match(',^ *(-([0-9]+))? *$,', $param[1]->texte, $m);
1347
-
1348
-			return array("intval($a1)", ((isset($m[2]) and $m[2]) ? $m[2] : 0));
1349
-		} else {
1350
-			return array("intval($a1)", 0);
1351
-		}
1352
-	} else {
1353
-		preg_match(',^ *(([0-9]+)|n) *(- *([0-9]+)? *)?$,', $param[0]->texte, $m);
1354
-		$a1 = $m[1];
1355
-		if (empty($m[3])) {
1356
-			return array($a1, 0);
1357
-		} elseif (!empty($m[4])) {
1358
-			return array($a1, $m[4]);
1359
-		} else {
1360
-			return array($a1, calculer_liste(array($param[1]), array(), $boucles, $boucles[$idb]->id_parent));
1361
-		}
1362
-	}
1343
+    if ($param[0]->type != 'texte') {
1344
+        $a1 = calculer_liste(array($param[0]), array('id_mere' => $idb), $boucles, $boucles[$idb]->id_parent);
1345
+        if (isset($param[1]->texte)) {
1346
+            preg_match(',^ *(-([0-9]+))? *$,', $param[1]->texte, $m);
1347
+
1348
+            return array("intval($a1)", ((isset($m[2]) and $m[2]) ? $m[2] : 0));
1349
+        } else {
1350
+            return array("intval($a1)", 0);
1351
+        }
1352
+    } else {
1353
+        preg_match(',^ *(([0-9]+)|n) *(- *([0-9]+)? *)?$,', $param[0]->texte, $m);
1354
+        $a1 = $m[1];
1355
+        if (empty($m[3])) {
1356
+            return array($a1, 0);
1357
+        } elseif (!empty($m[4])) {
1358
+            return array($a1, $m[4]);
1359
+        } else {
1360
+            return array($a1, calculer_liste(array($param[1]), array(), $boucles, $boucles[$idb]->id_parent));
1361
+        }
1362
+    }
1363 1363
 }
1364 1364
 
1365 1365
 
@@ -1386,47 +1386,47 @@  discard block
 block discarded – undo
1386 1386
  *     array : Erreur sur un des critères
1387 1387
  **/
1388 1388
 function calculer_criteres($idb, &$boucles) {
1389
-	$msg = '';
1390
-	$boucle = $boucles[$idb];
1391
-	$table = strtoupper($boucle->type_requete);
1392
-	$serveur = strtolower($boucle->sql_serveur);
1393
-
1394
-	$defaut = charger_fonction('DEFAUT', 'calculer_critere');
1395
-	// s'il y avait une erreur de syntaxe, propager cette info
1396
-	if (!is_array($boucle->criteres)) {
1397
-		return array();
1398
-	}
1399
-
1400
-	foreach ($boucle->criteres as $crit) {
1401
-		$critere = $crit->op;
1402
-		// critere personnalise ?
1403
-		if (
1404
-			(!$serveur or
1405
-				((!function_exists($f = "critere_" . $serveur . "_" . $table . "_" . $critere))
1406
-					and (!function_exists($f = $f . "_dist"))
1407
-					and (!function_exists($f = "critere_" . $serveur . "_" . $critere))
1408
-					and (!function_exists($f = $f . "_dist"))
1409
-				)
1410
-			)
1411
-			and (!function_exists($f = "critere_" . $table . "_" . $critere))
1412
-			and (!function_exists($f = $f . "_dist"))
1413
-			and (!function_exists($f = "critere_" . $critere))
1414
-			and (!function_exists($f = $f . "_dist"))
1415
-		) {
1416
-			// fonction critere standard
1417
-			$f = $defaut;
1418
-		}
1419
-		// compile le critere
1420
-		$res = $f($idb, $boucles, $crit);
1421
-
1422
-		// Gestion centralisee des erreurs pour pouvoir propager
1423
-		if (is_array($res)) {
1424
-			$msg = $res;
1425
-			erreur_squelette($msg, $boucle);
1426
-		}
1427
-	}
1428
-
1429
-	return $msg;
1389
+    $msg = '';
1390
+    $boucle = $boucles[$idb];
1391
+    $table = strtoupper($boucle->type_requete);
1392
+    $serveur = strtolower($boucle->sql_serveur);
1393
+
1394
+    $defaut = charger_fonction('DEFAUT', 'calculer_critere');
1395
+    // s'il y avait une erreur de syntaxe, propager cette info
1396
+    if (!is_array($boucle->criteres)) {
1397
+        return array();
1398
+    }
1399
+
1400
+    foreach ($boucle->criteres as $crit) {
1401
+        $critere = $crit->op;
1402
+        // critere personnalise ?
1403
+        if (
1404
+            (!$serveur or
1405
+                ((!function_exists($f = "critere_" . $serveur . "_" . $table . "_" . $critere))
1406
+                    and (!function_exists($f = $f . "_dist"))
1407
+                    and (!function_exists($f = "critere_" . $serveur . "_" . $critere))
1408
+                    and (!function_exists($f = $f . "_dist"))
1409
+                )
1410
+            )
1411
+            and (!function_exists($f = "critere_" . $table . "_" . $critere))
1412
+            and (!function_exists($f = $f . "_dist"))
1413
+            and (!function_exists($f = "critere_" . $critere))
1414
+            and (!function_exists($f = $f . "_dist"))
1415
+        ) {
1416
+            // fonction critere standard
1417
+            $f = $defaut;
1418
+        }
1419
+        // compile le critere
1420
+        $res = $f($idb, $boucles, $crit);
1421
+
1422
+        // Gestion centralisee des erreurs pour pouvoir propager
1423
+        if (is_array($res)) {
1424
+            $msg = $res;
1425
+            erreur_squelette($msg, $boucle);
1426
+        }
1427
+    }
1428
+
1429
+    return $msg;
1430 1430
 }
1431 1431
 
1432 1432
 /**
@@ -1443,11 +1443,11 @@  discard block
 block discarded – undo
1443 1443
  * @return string         Code compilé rééchappé
1444 1444
  */
1445 1445
 function kwote($lisp, $serveur = '', $type = '') {
1446
-	if (preg_match(_CODE_QUOTE, $lisp, $r)) {
1447
-		return $r[1] . "\"" . sql_quote(str_replace(array("\\'", "\\\\"), array("'", "\\"), $r[2]), $serveur, $type) . "\"";
1448
-	} else {
1449
-		return "sql_quote($lisp, '$serveur', '" . str_replace("'", "\\'", $type) . "')";
1450
-	}
1446
+    if (preg_match(_CODE_QUOTE, $lisp, $r)) {
1447
+        return $r[1] . "\"" . sql_quote(str_replace(array("\\'", "\\\\"), array("'", "\\"), $r[2]), $serveur, $type) . "\"";
1448
+    } else {
1449
+        return "sql_quote($lisp, '$serveur', '" . str_replace("'", "\\'", $type) . "')";
1450
+    }
1451 1451
 }
1452 1452
 
1453 1453
 
@@ -1466,85 +1466,85 @@  discard block
 block discarded – undo
1466 1466
  * @return void
1467 1467
  **/
1468 1468
 function critere_IN_dist($idb, &$boucles, $crit) {
1469
-	$r = calculer_critere_infixe($idb, $boucles, $crit);
1470
-	if (!$r) {
1471
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op . " ?")));
1472
-	}
1473
-	list($arg, $op, $val, $col, $where_complement) = $r;
1474
-
1475
-	$in = critere_IN_cas($idb, $boucles, $crit->not ? 'NOT' : ($crit->exclus ? 'exclus' : ''), $arg, $op, $val, $col);
1476
-
1477
-	//	inserer la condition; exemple: {id_mot ?IN (66, 62, 64)}
1478
-	$where = $in;
1479
-	if ($crit->cond) {
1480
-		$pred = calculer_argument_precedent($idb, $col, $boucles);
1481
-		$where = array("'?'", $pred, $where, "''");
1482
-		if ($where_complement) // condition annexe du type "AND (objet='article')"
1483
-		{
1484
-			$where_complement = array("'?'", $pred, $where_complement, "''");
1485
-		}
1486
-	}
1487
-	if ($crit->exclus) {
1488
-		if (!preg_match(",^L[0-9]+[.],", $arg)) {
1489
-			$where = array("'NOT'", $where);
1490
-		} else
1491
-			// un not sur un critere de jointure se traduit comme un NOT IN avec une sous requete
1492
-			// c'est une sous requete identique a la requete principale sous la forme (SELF,$select,$where) avec $select et $where qui surchargent
1493
-		{
1494
-			$where = array(
1495
-				"'NOT'",
1496
-				array(
1497
-					"'IN'",
1498
-					"'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'",
1499
-					array("'SELF'", "'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'", $where)
1500
-				)
1501
-			);
1502
-		}
1503
-	}
1504
-
1505
-	$boucles[$idb]->where[] = $where;
1506
-	if ($where_complement) // condition annexe du type "AND (objet='article')"
1507
-	{
1508
-		$boucles[$idb]->where[] = $where_complement;
1509
-	}
1469
+    $r = calculer_critere_infixe($idb, $boucles, $crit);
1470
+    if (!$r) {
1471
+        return (array('zbug_critere_inconnu', array('critere' => $crit->op . " ?")));
1472
+    }
1473
+    list($arg, $op, $val, $col, $where_complement) = $r;
1474
+
1475
+    $in = critere_IN_cas($idb, $boucles, $crit->not ? 'NOT' : ($crit->exclus ? 'exclus' : ''), $arg, $op, $val, $col);
1476
+
1477
+    //	inserer la condition; exemple: {id_mot ?IN (66, 62, 64)}
1478
+    $where = $in;
1479
+    if ($crit->cond) {
1480
+        $pred = calculer_argument_precedent($idb, $col, $boucles);
1481
+        $where = array("'?'", $pred, $where, "''");
1482
+        if ($where_complement) // condition annexe du type "AND (objet='article')"
1483
+        {
1484
+            $where_complement = array("'?'", $pred, $where_complement, "''");
1485
+        }
1486
+    }
1487
+    if ($crit->exclus) {
1488
+        if (!preg_match(",^L[0-9]+[.],", $arg)) {
1489
+            $where = array("'NOT'", $where);
1490
+        } else
1491
+            // un not sur un critere de jointure se traduit comme un NOT IN avec une sous requete
1492
+            // c'est une sous requete identique a la requete principale sous la forme (SELF,$select,$where) avec $select et $where qui surchargent
1493
+        {
1494
+            $where = array(
1495
+                "'NOT'",
1496
+                array(
1497
+                    "'IN'",
1498
+                    "'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'",
1499
+                    array("'SELF'", "'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'", $where)
1500
+                )
1501
+            );
1502
+        }
1503
+    }
1504
+
1505
+    $boucles[$idb]->where[] = $where;
1506
+    if ($where_complement) // condition annexe du type "AND (objet='article')"
1507
+    {
1508
+        $boucles[$idb]->where[] = $where_complement;
1509
+    }
1510 1510
 }
1511 1511
 
1512 1512
 // http://code.spip.net/@critere_IN_cas
1513 1513
 function critere_IN_cas($idb, &$boucles, $crit2, $arg, $op, $val, $col) {
1514
-	static $num = array();
1515
-	$descr = $boucles[$idb]->descr;
1516
-	$cpt = &$num[$descr['nom']][$descr['gram']][$idb];
1517
-
1518
-	$var = '$in' . $cpt++;
1519
-	$x = "\n\t$var = array();";
1520
-	foreach ($val as $k => $v) {
1521
-		if (preg_match(",^(\n//.*\n)?'(.*)'$,", $v, $r)) {
1522
-			// optimiser le traitement des constantes
1523
-			if (is_numeric($r[2])) {
1524
-				$x .= "\n\t$var" . "[]= $r[2];";
1525
-			} else {
1526
-				$x .= "\n\t$var" . "[]= " . sql_quote($r[2]) . ";";
1527
-			}
1528
-		} else {
1529
-			// Pour permettre de passer des tableaux de valeurs
1530
-			// on repere l'utilisation brute de #ENV**{X},
1531
-			// c'est-a-dire sa  traduction en ($PILE[0][X]).
1532
-			// et on deballe mais en rajoutant l'anti XSS
1533
-			$x .= "\n\tif (!(is_array(\$a = ($v))))\n\t\t$var" . "[]= \$a;\n\telse $var = array_merge($var, \$a);";
1534
-		}
1535
-	}
1536
-
1537
-	$boucles[$idb]->in .= $x;
1538
-
1539
-	// inserer le tri par defaut selon les ordres du IN ...
1540
-	// avec une ecriture de type FIELD qui degrade les performances (du meme ordre qu'un regexp)
1541
-	// et que l'on limite donc strictement aux cas necessaires :
1542
-	// si ce n'est pas un !IN, et si il n'y a pas d'autre order dans la boucle
1543
-	if (!$crit2) {
1544
-		$boucles[$idb]->default_order[] = "((!sql_quote($var) OR sql_quote($var)===\"''\") ? 0 : ('FIELD($arg,' . sql_quote($var) . ')'))";
1545
-	}
1546
-
1547
-	return "sql_in('$arg',sql_quote($var)" . ($crit2 == 'NOT' ? ",'NOT'" : "") . ")";
1514
+    static $num = array();
1515
+    $descr = $boucles[$idb]->descr;
1516
+    $cpt = &$num[$descr['nom']][$descr['gram']][$idb];
1517
+
1518
+    $var = '$in' . $cpt++;
1519
+    $x = "\n\t$var = array();";
1520
+    foreach ($val as $k => $v) {
1521
+        if (preg_match(",^(\n//.*\n)?'(.*)'$,", $v, $r)) {
1522
+            // optimiser le traitement des constantes
1523
+            if (is_numeric($r[2])) {
1524
+                $x .= "\n\t$var" . "[]= $r[2];";
1525
+            } else {
1526
+                $x .= "\n\t$var" . "[]= " . sql_quote($r[2]) . ";";
1527
+            }
1528
+        } else {
1529
+            // Pour permettre de passer des tableaux de valeurs
1530
+            // on repere l'utilisation brute de #ENV**{X},
1531
+            // c'est-a-dire sa  traduction en ($PILE[0][X]).
1532
+            // et on deballe mais en rajoutant l'anti XSS
1533
+            $x .= "\n\tif (!(is_array(\$a = ($v))))\n\t\t$var" . "[]= \$a;\n\telse $var = array_merge($var, \$a);";
1534
+        }
1535
+    }
1536
+
1537
+    $boucles[$idb]->in .= $x;
1538
+
1539
+    // inserer le tri par defaut selon les ordres du IN ...
1540
+    // avec une ecriture de type FIELD qui degrade les performances (du meme ordre qu'un regexp)
1541
+    // et que l'on limite donc strictement aux cas necessaires :
1542
+    // si ce n'est pas un !IN, et si il n'y a pas d'autre order dans la boucle
1543
+    if (!$crit2) {
1544
+        $boucles[$idb]->default_order[] = "((!sql_quote($var) OR sql_quote($var)===\"''\") ? 0 : ('FIELD($arg,' . sql_quote($var) . ')'))";
1545
+    }
1546
+
1547
+    return "sql_in('$arg',sql_quote($var)" . ($crit2 == 'NOT' ? ",'NOT'" : "") . ")";
1548 1548
 }
1549 1549
 
1550 1550
 /**
@@ -1560,22 +1560,22 @@  discard block
 block discarded – undo
1560 1560
  * @return void
1561 1561
  */
1562 1562
 function critere_where_dist($idb, &$boucles, $crit) {
1563
-	$boucle = &$boucles[$idb];
1564
-	if (isset($crit->param[0])) {
1565
-		$_where = calculer_liste($crit->param[0], array(), $boucles, $boucle->id_parent);
1566
-	} else {
1567
-		$_where = '@$Pile[0]["where"]';
1568
-	}
1569
-
1570
-	if ($crit->cond) {
1571
-		$_where = "(($_where) ? ($_where) : '')";
1572
-	}
1573
-
1574
-	if ($crit->not) {
1575
-		$_where = "array('NOT',$_where)";
1576
-	}
1577
-
1578
-	$boucle->where[] = $_where;
1563
+    $boucle = &$boucles[$idb];
1564
+    if (isset($crit->param[0])) {
1565
+        $_where = calculer_liste($crit->param[0], array(), $boucles, $boucle->id_parent);
1566
+    } else {
1567
+        $_where = '@$Pile[0]["where"]';
1568
+    }
1569
+
1570
+    if ($crit->cond) {
1571
+        $_where = "(($_where) ? ($_where) : '')";
1572
+    }
1573
+
1574
+    if ($crit->not) {
1575
+        $_where = "array('NOT',$_where)";
1576
+    }
1577
+
1578
+    $boucle->where[] = $_where;
1579 1579
 }
1580 1580
 
1581 1581
 /**
@@ -1604,20 +1604,20 @@  discard block
 block discarded – undo
1604 1604
  */
1605 1605
 function critere_id__dist($idb, &$boucles, $crit) {
1606 1606
 
1607
-	$champs = lister_champs_selection_conditionnelle(
1608
-		$boucles[$idb]->show['table'],
1609
-		$boucles[$idb]->show,
1610
-		$boucles[$idb]->sql_serveur
1611
-	);
1612
-
1613
-	// créer un critère {id_xxx?} de chaque champ retenu
1614
-	foreach ($champs as $champ) {
1615
-		$critere_id_table = new Critere;
1616
-		$critere_id_table->op = $champ;
1617
-		$critere_id_table->cond = '?';
1618
-		$critere_id_table->ligne = $crit->ligne;
1619
-		calculer_critere_DEFAUT_dist($idb, $boucles, $critere_id_table);
1620
-	}
1607
+    $champs = lister_champs_selection_conditionnelle(
1608
+        $boucles[$idb]->show['table'],
1609
+        $boucles[$idb]->show,
1610
+        $boucles[$idb]->sql_serveur
1611
+    );
1612
+
1613
+    // créer un critère {id_xxx?} de chaque champ retenu
1614
+    foreach ($champs as $champ) {
1615
+        $critere_id_table = new Critere;
1616
+        $critere_id_table->op = $champ;
1617
+        $critere_id_table->cond = '?';
1618
+        $critere_id_table->ligne = $crit->ligne;
1619
+        calculer_critere_DEFAUT_dist($idb, $boucles, $critere_id_table);
1620
+    }
1621 1621
 }
1622 1622
 
1623 1623
 /**
@@ -1637,67 +1637,67 @@  discard block
 block discarded – undo
1637 1637
  * @return array Liste de nom de champs (tel que id_article, id_mot, id_parent ...)
1638 1638
  */
1639 1639
 function lister_champs_selection_conditionnelle($table, $desc = null, $serveur = '') {
1640
-	// calculer la description de la table
1641
-	if (!is_array($desc)) {
1642
-		$desc = description_table($table, $serveur);
1643
-	}
1644
-	if (!$desc) {
1645
-		return [];
1646
-	}
1647
-
1648
-	// Les champs id_xx de la table demandée
1649
-	$champs = array_filter(
1650
-		array_keys($desc['field']),
1651
-		function($champ){
1652
-			return
1653
-				strpos($champ, 'id_') === 0
1654
-				or (in_array($champ, array('objet')));
1655
-		}
1656
-	);
1657
-
1658
-	// On ne fera pas mieux pour les tables d’un autre serveur
1659
-	if ($serveur) {
1660
-		return $champs;
1661
-	}
1662
-
1663
-	$primary = false;
1664
-	$associable = false;
1665
-	include_spip('action/editer_liens');
1666
-
1667
-	if (isset($desc['type'])) {
1668
-		$primary = id_table_objet($desc['type']);
1669
-		$associable = objet_associable($desc['type']);
1670
-	}
1671
-	if (isset($desc['field']['id_objet']) and isset($desc['field']['objet'])) {
1672
-		$associable = true;
1673
-	}
1674
-
1675
-	// liste de toutes les tables principales, sauf la notre
1676
-	$tables = lister_tables_objets_sql();
1677
-	unset($tables[$table]);
1678
-
1679
-	foreach ($tables as $_table => $_desc) {
1680
-		if (
1681
-			$associable
1682
-			or ($primary and in_array($primary, array_keys($_desc['field'])))
1683
-			or objet_associable($_desc['type'])
1684
-		) {
1685
-			$champs[] = id_table_objet($_table);
1686
-		}
1687
-	}
1688
-	$champs = array_unique($champs);
1689
-	$champs = pipeline(
1690
-		'lister_champs_selection_conditionnelle',
1691
-		array(
1692
-			'args' => array(
1693
-				'table' => $table,
1694
-				'id_table_objet' => $primary,
1695
-				'associable' => $associable,
1696
-			),
1697
-			'data' => $champs,
1698
-		)
1699
-	);
1700
-	return $champs;
1640
+    // calculer la description de la table
1641
+    if (!is_array($desc)) {
1642
+        $desc = description_table($table, $serveur);
1643
+    }
1644
+    if (!$desc) {
1645
+        return [];
1646
+    }
1647
+
1648
+    // Les champs id_xx de la table demandée
1649
+    $champs = array_filter(
1650
+        array_keys($desc['field']),
1651
+        function($champ){
1652
+            return
1653
+                strpos($champ, 'id_') === 0
1654
+                or (in_array($champ, array('objet')));
1655
+        }
1656
+    );
1657
+
1658
+    // On ne fera pas mieux pour les tables d’un autre serveur
1659
+    if ($serveur) {
1660
+        return $champs;
1661
+    }
1662
+
1663
+    $primary = false;
1664
+    $associable = false;
1665
+    include_spip('action/editer_liens');
1666
+
1667
+    if (isset($desc['type'])) {
1668
+        $primary = id_table_objet($desc['type']);
1669
+        $associable = objet_associable($desc['type']);
1670
+    }
1671
+    if (isset($desc['field']['id_objet']) and isset($desc['field']['objet'])) {
1672
+        $associable = true;
1673
+    }
1674
+
1675
+    // liste de toutes les tables principales, sauf la notre
1676
+    $tables = lister_tables_objets_sql();
1677
+    unset($tables[$table]);
1678
+
1679
+    foreach ($tables as $_table => $_desc) {
1680
+        if (
1681
+            $associable
1682
+            or ($primary and in_array($primary, array_keys($_desc['field'])))
1683
+            or objet_associable($_desc['type'])
1684
+        ) {
1685
+            $champs[] = id_table_objet($_table);
1686
+        }
1687
+    }
1688
+    $champs = array_unique($champs);
1689
+    $champs = pipeline(
1690
+        'lister_champs_selection_conditionnelle',
1691
+        array(
1692
+            'args' => array(
1693
+                'table' => $table,
1694
+                'id_table_objet' => $primary,
1695
+                'associable' => $associable,
1696
+            ),
1697
+            'data' => $champs,
1698
+        )
1699
+    );
1700
+    return $champs;
1701 1701
 }
1702 1702
 
1703 1703
 /**
@@ -1752,27 +1752,27 @@  discard block
 block discarded – undo
1752 1752
  * @return void
1753 1753
  */
1754 1754
 function critere_tri_dist($idb, &$boucles, $crit) {
1755
-	$boucle = &$boucles[$idb];
1756
-
1757
-	// definition du champ par defaut
1758
-	$_champ_defaut = !isset($crit->param[0][0]) ? "''"
1759
-		: calculer_liste(array($crit->param[0][0]), array(), $boucles, $boucle->id_parent);
1760
-	$_sens_defaut = !isset($crit->param[1][0]) ? "1"
1761
-		: calculer_liste(array($crit->param[1][0]), array(), $boucles, $boucle->id_parent);
1762
-	$_variable = !isset($crit->param[2][0]) ? "'$idb'"
1763
-		: calculer_liste(array($crit->param[2][0]), array(), $boucles, $boucle->id_parent);
1764
-
1765
-	$_tri = "((\$t=(isset(\$Pile[0]['tri'.$_variable]))?\$Pile[0]['tri'.$_variable]:((strncmp($_variable,'session',7)==0 AND session_get('tri'.$_variable))?session_get('tri'.$_variable):$_champ_defaut))?tri_protege_champ(\$t):'')";
1766
-
1767
-	$_sens_defaut = "(is_array(\$s=$_sens_defaut)?(isset(\$s[\$st=$_tri])?\$s[\$st]:reset(\$s)):\$s)";
1768
-	$_sens = "((intval(\$t=(isset(\$Pile[0]['sens'.$_variable]))?\$Pile[0]['sens'.$_variable]:((strncmp($_variable,'session',7)==0 AND session_get('sens'.$_variable))?session_get('sens'.$_variable):$_sens_defaut))==-1 OR \$t=='inverse')?-1:1)";
1769
-
1770
-	$boucle->modificateur['tri_champ'] = $_tri;
1771
-	$boucle->modificateur['tri_sens'] = $_sens;
1772
-	$boucle->modificateur['tri_nom'] = $_variable;
1773
-	// faut il inserer un test sur l'existence de $tri parmi les champs de la table ?
1774
-	// evite des erreurs sql, mais peut empecher des tri sur jointure ...
1775
-	$boucle->hash .= "
1755
+    $boucle = &$boucles[$idb];
1756
+
1757
+    // definition du champ par defaut
1758
+    $_champ_defaut = !isset($crit->param[0][0]) ? "''"
1759
+        : calculer_liste(array($crit->param[0][0]), array(), $boucles, $boucle->id_parent);
1760
+    $_sens_defaut = !isset($crit->param[1][0]) ? "1"
1761
+        : calculer_liste(array($crit->param[1][0]), array(), $boucles, $boucle->id_parent);
1762
+    $_variable = !isset($crit->param[2][0]) ? "'$idb'"
1763
+        : calculer_liste(array($crit->param[2][0]), array(), $boucles, $boucle->id_parent);
1764
+
1765
+    $_tri = "((\$t=(isset(\$Pile[0]['tri'.$_variable]))?\$Pile[0]['tri'.$_variable]:((strncmp($_variable,'session',7)==0 AND session_get('tri'.$_variable))?session_get('tri'.$_variable):$_champ_defaut))?tri_protege_champ(\$t):'')";
1766
+
1767
+    $_sens_defaut = "(is_array(\$s=$_sens_defaut)?(isset(\$s[\$st=$_tri])?\$s[\$st]:reset(\$s)):\$s)";
1768
+    $_sens = "((intval(\$t=(isset(\$Pile[0]['sens'.$_variable]))?\$Pile[0]['sens'.$_variable]:((strncmp($_variable,'session',7)==0 AND session_get('sens'.$_variable))?session_get('sens'.$_variable):$_sens_defaut))==-1 OR \$t=='inverse')?-1:1)";
1769
+
1770
+    $boucle->modificateur['tri_champ'] = $_tri;
1771
+    $boucle->modificateur['tri_sens'] = $_sens;
1772
+    $boucle->modificateur['tri_nom'] = $_variable;
1773
+    // faut il inserer un test sur l'existence de $tri parmi les champs de la table ?
1774
+    // evite des erreurs sql, mais peut empecher des tri sur jointure ...
1775
+    $boucle->hash .= "
1776 1776
 	\$senstri = '';
1777 1777
 	\$tri = $_tri;
1778 1778
 	if (\$tri){
@@ -1780,8 +1780,8 @@  discard block
 block discarded – undo
1780 1780
 		\$senstri = (\$senstri<0)?' DESC':'';
1781 1781
 	};
1782 1782
 	";
1783
-	$boucle->select[] = "\".tri_champ_select(\$tri).\"";
1784
-	$boucle->order[] = "tri_champ_order(\$tri,\$command['from']).\$senstri";
1783
+    $boucle->select[] = "\".tri_champ_select(\$tri).\"";
1784
+    $boucle->order[] = "tri_champ_order(\$tri,\$command['from']).\$senstri";
1785 1785
 }
1786 1786
 
1787 1787
 # Criteres de comparaison
@@ -1798,20 +1798,20 @@  discard block
 block discarded – undo
1798 1798
  * @return void
1799 1799
  **/
1800 1800
 function calculer_critere_DEFAUT_dist($idb, &$boucles, $crit) {
1801
-	// double cas particulier {0,1} et {1/2} repere a l'analyse lexicale
1802
-	if (($crit->op == ",") or ($crit->op == '/')) {
1803
-		return calculer_critere_parties($idb, $boucles, $crit);
1804
-	}
1805
-
1806
-	$r = calculer_critere_infixe($idb, $boucles, $crit);
1807
-	if (!$r) {
1808
-		#	// on produit une erreur seulement si le critere n'a pas de '?'
1809
-		#	if (!$crit->cond) {
1810
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op)));
1811
-		#	}
1812
-	} else {
1813
-		calculer_critere_DEFAUT_args($idb, $boucles, $crit, $r);
1814
-	}
1801
+    // double cas particulier {0,1} et {1/2} repere a l'analyse lexicale
1802
+    if (($crit->op == ",") or ($crit->op == '/')) {
1803
+        return calculer_critere_parties($idb, $boucles, $crit);
1804
+    }
1805
+
1806
+    $r = calculer_critere_infixe($idb, $boucles, $crit);
1807
+    if (!$r) {
1808
+        #	// on produit une erreur seulement si le critere n'a pas de '?'
1809
+        #	if (!$crit->cond) {
1810
+        return (array('zbug_critere_inconnu', array('critere' => $crit->op)));
1811
+        #	}
1812
+    } else {
1813
+        calculer_critere_DEFAUT_args($idb, $boucles, $crit, $r);
1814
+    }
1815 1815
 }
1816 1816
 
1817 1817
 
@@ -1831,63 +1831,63 @@  discard block
 block discarded – undo
1831 1831
  * @return void
1832 1832
  **/
1833 1833
 function calculer_critere_DEFAUT_args($idb, &$boucles, $crit, $args) {
1834
-	list($arg, $op, $val, $col, $where_complement) = $args;
1835
-
1836
-	$where = array("'$op'", "'$arg'", $val[0]);
1837
-
1838
-	// inserer la negation (cf !...)
1839
-
1840
-	if ($crit->not) {
1841
-		$where = array("'NOT'", $where);
1842
-	}
1843
-	if ($crit->exclus) {
1844
-		if (!preg_match(",^L[0-9]+[.],", $arg)) {
1845
-			$where = array("'NOT'", $where);
1846
-		} else
1847
-			// un not sur un critere de jointure se traduit comme un NOT IN avec une sous requete
1848
-			// c'est une sous requete identique a la requete principale sous la forme (SELF,$select,$where) avec $select et $where qui surchargent
1849
-		{
1850
-			$where = array(
1851
-				"'NOT'",
1852
-				array(
1853
-					"'IN'",
1854
-					"'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'",
1855
-					array("'SELF'", "'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'", $where)
1856
-				)
1857
-			);
1858
-		}
1859
-	}
1860
-
1861
-	// inserer la condition (cf {lang?})
1862
-	// traiter a part la date, elle est mise d'office par SPIP,
1863
-	if ($crit->cond) {
1864
-		$pred = calculer_argument_precedent($idb, $col, $boucles);
1865
-		if ($col == "date" or $col == "date_redac") {
1866
-			if ($pred == "\$Pile[0]['" . $col . "']") {
1867
-				$pred = "(\$Pile[0]['{$col}_default']?'':$pred)";
1868
-			}
1869
-		}
1870
-
1871
-		if ($op == '=' and !$crit->not) {
1872
-			$where = array(
1873
-				"'?'",
1874
-				"(is_array($pred))",
1875
-				critere_IN_cas($idb, $boucles, 'COND', $arg, $op, array($pred), $col),
1876
-				$where
1877
-			);
1878
-		}
1879
-		$where = array("'?'", "!(is_array($pred)?count($pred):strlen($pred))", "''", $where);
1880
-		if ($where_complement) // condition annexe du type "AND (objet='article')"
1881
-		{
1882
-			$where_complement = array("'?'", "!(is_array($pred)?count($pred):strlen($pred))", "''", $where_complement);
1883
-		}
1884
-	}
1885
-
1886
-	$boucles[$idb]->where[] = $where;
1887
-	if ($where_complement) // condition annexe du type "AND (objet='article')"
1888
-	{
1889
-		$boucles[$idb]->where[] = $where_complement;
1890
-	}
1834
+    list($arg, $op, $val, $col, $where_complement) = $args;
1835
+
1836
+    $where = array("'$op'", "'$arg'", $val[0]);
1837
+
1838
+    // inserer la negation (cf !...)
1839
+
1840
+    if ($crit->not) {
1841
+        $where = array("'NOT'", $where);
1842
+    }
1843
+    if ($crit->exclus) {
1844
+        if (!preg_match(",^L[0-9]+[.],", $arg)) {
1845
+            $where = array("'NOT'", $where);
1846
+        } else
1847
+            // un not sur un critere de jointure se traduit comme un NOT IN avec une sous requete
1848
+            // c'est une sous requete identique a la requete principale sous la forme (SELF,$select,$where) avec $select et $where qui surchargent
1849
+        {
1850
+            $where = array(
1851
+                "'NOT'",
1852
+                array(
1853
+                    "'IN'",
1854
+                    "'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'",
1855
+                    array("'SELF'", "'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'", $where)
1856
+                )
1857
+            );
1858
+        }
1859
+    }
1860
+
1861
+    // inserer la condition (cf {lang?})
1862
+    // traiter a part la date, elle est mise d'office par SPIP,
1863
+    if ($crit->cond) {
1864
+        $pred = calculer_argument_precedent($idb, $col, $boucles);
1865
+        if ($col == "date" or $col == "date_redac") {
1866
+            if ($pred == "\$Pile[0]['" . $col . "']") {
1867
+                $pred = "(\$Pile[0]['{$col}_default']?'':$pred)";
1868
+            }
1869
+        }
1870
+
1871
+        if ($op == '=' and !$crit->not) {
1872
+            $where = array(
1873
+                "'?'",
1874
+                "(is_array($pred))",
1875
+                critere_IN_cas($idb, $boucles, 'COND', $arg, $op, array($pred), $col),
1876
+                $where
1877
+            );
1878
+        }
1879
+        $where = array("'?'", "!(is_array($pred)?count($pred):strlen($pred))", "''", $where);
1880
+        if ($where_complement) // condition annexe du type "AND (objet='article')"
1881
+        {
1882
+            $where_complement = array("'?'", "!(is_array($pred)?count($pred):strlen($pred))", "''", $where_complement);
1883
+        }
1884
+    }
1885
+
1886
+    $boucles[$idb]->where[] = $where;
1887
+    if ($where_complement) // condition annexe du type "AND (objet='article')"
1888
+    {
1889
+        $boucles[$idb]->where[] = $where_complement;
1890
+    }
1891 1891
 }
1892 1892
 
1893 1893
 
@@ -1928,167 +1928,167 @@  discard block
 block discarded – undo
1928 1928
  **/
1929 1929
 function calculer_critere_infixe($idb, &$boucles, $crit) {
1930 1930
 
1931
-	$boucle = &$boucles[$idb];
1932
-	$type = $boucle->type_requete;
1933
-	$table = $boucle->id_table;
1934
-	$desc = $boucle->show;
1935
-	$col_vraie = null;
1936
-
1937
-	list($fct, $col, $op, $val, $args_sql) =
1938
-		calculer_critere_infixe_ops($idb, $boucles, $crit);
1939
-
1940
-	$col_alias = $col;
1941
-	$where_complement = false;
1942
-
1943
-	// Cas particulier : id_enfant => utiliser la colonne id_objet
1944
-	if ($col == 'id_enfant') {
1945
-		$col = $boucle->primary;
1946
-	}
1947
-
1948
-	// Cas particulier : id_parent => verifier les exceptions de tables
1949
-	if ((in_array($col, array('id_parent', 'id_secteur')) and isset($GLOBALS['exceptions_des_tables'][$table][$col]))
1950
-		or (isset($GLOBALS['exceptions_des_tables'][$table][$col]) and is_string($GLOBALS['exceptions_des_tables'][$table][$col]))
1951
-	) {
1952
-		$col = $GLOBALS['exceptions_des_tables'][$table][$col];
1953
-	} // et possibilite de gerer un critere secteur sur des tables de plugins (ie forums)
1954
-	else {
1955
-		if (($col == 'id_secteur') and ($critere_secteur = charger_fonction("critere_secteur_$type", "public", true))) {
1956
-			$table = $critere_secteur($idb, $boucles, $val, $crit);
1957
-		}
1958
-
1959
-		// cas id_article=xx qui se mappe en id_objet=xx AND objet=article
1960
-		// sauf si exception declaree : sauter cette etape
1961
-		else {
1962
-			if (
1963
-				!isset($GLOBALS['exceptions_des_jointures'][table_objet_sql($table)][$col])
1964
-				and !isset($GLOBALS['exceptions_des_jointures'][$col])
1965
-				and count(trouver_champs_decomposes($col, $desc)) > 1
1966
-			) {
1967
-				$e = decompose_champ_id_objet($col);
1968
-				$col = array_shift($e);
1969
-				$where_complement = primary_doublee($e, $table);
1970
-			} // Cas particulier : expressions de date
1971
-			else {
1972
-				if ($c = calculer_critere_infixe_date($idb, $boucles, $col)) {
1973
-					list($col, $col_vraie) = $c;
1974
-					$table = '';
1975
-				} // table explicitée {mots.titre}
1976
-				else {
1977
-					if (preg_match('/^(.*)\.(.*)$/', $col, $r)) {
1978
-						list(, $table, $col) = $r;
1979
-						$col_alias = $col;
1980
-
1981
-						$trouver_table = charger_fonction('trouver_table', 'base');
1982
-						if ($desc = $trouver_table($table, $boucle->sql_serveur)
1983
-							and isset($desc['field'][$col])
1984
-							and $cle = array_search($desc['table'], $boucle->from)
1985
-						) {
1986
-							$table = $cle;
1987
-						} else {
1988
-							$table = trouver_jointure_champ($col, $boucle, array($table), ($crit->cond or $op != '='));
1989
-						}
1990
-						#$table = calculer_critere_externe_init($boucle, array($table), $col, $desc, ($crit->cond OR $op!='='), true);
1991
-						if (!$table) {
1992
-							return '';
1993
-						}
1994
-					}
1995
-					// si le champ n'est pas trouvé dans la table,
1996
-					// on cherche si une jointure peut l'obtenir
1997
-					elseif (@!array_key_exists($col, $desc['field'])) {
1998
-						// Champ joker * des iterateurs DATA qui accepte tout
1999
-						if (@array_key_exists('*', $desc['field'])) {
2000
-							$desc['field'][$col_vraie ? $col_vraie : $col] = ''; // on veut pas de cast INT par defaut car le type peut etre n'importe quoi dans les boucles DATA
2001
-						}
2002
-						else {
2003
-							$r = calculer_critere_infixe_externe($boucle, $crit, $op, $desc, $col, $col_alias, $table);
2004
-							if (!$r) {
2005
-								return '';
2006
-							}
2007
-							list($col, $col_alias, $table, $where_complement, $desc) = $r;
2008
-						}
2009
-					}
2010
-				}
2011
-			}
2012
-		}
2013
-	}
2014
-
2015
-	$col_vraie = ($col_vraie ? $col_vraie : $col);
2016
-	// Dans tous les cas,
2017
-	// virer les guillemets eventuels autour d'un int (qui sont refuses par certains SQL)
2018
-	// et passer dans sql_quote avec le type si connu
2019
-	// et int sinon si la valeur est numerique
2020
-	// sinon introduire le vrai type du champ si connu dans le sql_quote (ou int NOT NULL sinon)
2021
-	// Ne pas utiliser intval, PHP tronquant les Bigint de SQL
2022
-	if ($op == '=' or in_array($op, $GLOBALS['table_criteres_infixes'])) {
2023
-		$type_cast_quote = (isset($desc['field'][$col_vraie]) ? $desc['field'][$col_vraie] : 'int NOT NULL');
2024
-		// defaire le quote des int et les passer dans sql_quote avec le bon type de champ si on le connait, int sinon
2025
-		// prendre en compte le debug ou la valeur arrive avec un commentaire PHP en debut
2026
-		if (preg_match(",^\\A(\s*//.*?$\s*)?\"'(-?\d+)'\"\\z,ms", $val[0], $r)) {
2027
-			$val[0] = $r[1] . '"' . sql_quote($r[2], $boucle->sql_serveur, $type_cast_quote) . '"';
2028
-		}
2029
-		// sinon expliciter les
2030
-		// sql_quote(truc) en sql_quote(truc,'',type)
2031
-		// sql_quote(truc,serveur) en sql_quote(truc,serveur,type)
2032
-		// sql_quote(truc,serveur,'') en sql_quote(truc,serveur,type)
2033
-		// sans toucher aux
2034
-		// sql_quote(truc,'','varchar(10) DEFAULT \'oui\' COLLATE NOCASE')
2035
-		// sql_quote(truc,'','varchar')
2036
-		elseif (preg_match('/\Asql_quote[(](.*?)(,[^)]*?)?(,[^)]*(?:\(\d+\)[^)]*)?)?[)]\s*\z/ms', $val[0], $r)
2037
-			// si pas deja un type
2038
-			and (!isset($r[3]) or !$r[3] or !trim($r[3],", '"))
2039
-		) {
2040
-			$r = $r[1]
2041
-				. ((isset($r[2]) and $r[2]) ? $r[2] : ",''")
2042
-				. ",'" . addslashes($type_cast_quote) . "'";
2043
-			$val[0] = "sql_quote($r)";
2044
-		}
2045
-		elseif(strpos($val[0], '@@defaultcast@@') !== false
2046
-		  and preg_match("/'@@defaultcast@@'\s*\)\s*\z/ms", $val[0], $r)) {
2047
-			$val[0] = substr($val[0], 0, -strlen($r[0])) . "'" . addslashes($type_cast_quote) . "')";
2048
-		}
2049
-	}
2050
-
2051
-	if(strpos($val[0], '@@defaultcast@@') !== false
2052
-	  and preg_match("/'@@defaultcast@@'\s*\)\s*\z/ms", $val[0], $r)) {
2053
-		$val[0] = substr($val[0], 0, -strlen($r[0])) . "'char')";
2054
-	}
2055
-
2056
-	// Indicateur pour permettre aux fonctionx boucle_X de modifier
2057
-	// leurs requetes par defaut, notamment le champ statut
2058
-	// Ne pas confondre champs de la table principale et des jointures
2059
-	if ($table === $boucle->id_table) {
2060
-		$boucles[$idb]->modificateur['criteres'][$col_vraie] = true;
2061
-		if ($col_alias != $col_vraie) {
2062
-			$boucles[$idb]->modificateur['criteres'][$col_alias] = true;
2063
-		}
2064
-	}
2065
-
2066
-	// ajout pour le cas special d'une condition sur le champ statut:
2067
-	// il faut alors interdire a la fonction de boucle
2068
-	// de mettre ses propres criteres de statut
2069
-	// http://www.spip.net/@statut (a documenter)
2070
-	// garde pour compatibilite avec code des plugins anterieurs, mais redondant avec la ligne precedente
2071
-	if ($col == 'statut') {
2072
-		$boucles[$idb]->statut = true;
2073
-	}
2074
-
2075
-	// inserer le nom de la table SQL devant le nom du champ
2076
-	if ($table) {
2077
-		if ($col[0] == "`") {
2078
-			$arg = "$table." . substr($col, 1, -1);
2079
-		} else {
2080
-			$arg = "$table.$col";
2081
-		}
2082
-	} else {
2083
-		$arg = $col;
2084
-	}
2085
-
2086
-	// inserer la fonction SQL
2087
-	if ($fct) {
2088
-		$arg = "$fct($arg$args_sql)";
2089
-	}
2090
-
2091
-	return array($arg, $op, $val, $col_alias, $where_complement);
1931
+    $boucle = &$boucles[$idb];
1932
+    $type = $boucle->type_requete;
1933
+    $table = $boucle->id_table;
1934
+    $desc = $boucle->show;
1935
+    $col_vraie = null;
1936
+
1937
+    list($fct, $col, $op, $val, $args_sql) =
1938
+        calculer_critere_infixe_ops($idb, $boucles, $crit);
1939
+
1940
+    $col_alias = $col;
1941
+    $where_complement = false;
1942
+
1943
+    // Cas particulier : id_enfant => utiliser la colonne id_objet
1944
+    if ($col == 'id_enfant') {
1945
+        $col = $boucle->primary;
1946
+    }
1947
+
1948
+    // Cas particulier : id_parent => verifier les exceptions de tables
1949
+    if ((in_array($col, array('id_parent', 'id_secteur')) and isset($GLOBALS['exceptions_des_tables'][$table][$col]))
1950
+        or (isset($GLOBALS['exceptions_des_tables'][$table][$col]) and is_string($GLOBALS['exceptions_des_tables'][$table][$col]))
1951
+    ) {
1952
+        $col = $GLOBALS['exceptions_des_tables'][$table][$col];
1953
+    } // et possibilite de gerer un critere secteur sur des tables de plugins (ie forums)
1954
+    else {
1955
+        if (($col == 'id_secteur') and ($critere_secteur = charger_fonction("critere_secteur_$type", "public", true))) {
1956
+            $table = $critere_secteur($idb, $boucles, $val, $crit);
1957
+        }
1958
+
1959
+        // cas id_article=xx qui se mappe en id_objet=xx AND objet=article
1960
+        // sauf si exception declaree : sauter cette etape
1961
+        else {
1962
+            if (
1963
+                !isset($GLOBALS['exceptions_des_jointures'][table_objet_sql($table)][$col])
1964
+                and !isset($GLOBALS['exceptions_des_jointures'][$col])
1965
+                and count(trouver_champs_decomposes($col, $desc)) > 1
1966
+            ) {
1967
+                $e = decompose_champ_id_objet($col);
1968
+                $col = array_shift($e);
1969
+                $where_complement = primary_doublee($e, $table);
1970
+            } // Cas particulier : expressions de date
1971
+            else {
1972
+                if ($c = calculer_critere_infixe_date($idb, $boucles, $col)) {
1973
+                    list($col, $col_vraie) = $c;
1974
+                    $table = '';
1975
+                } // table explicitée {mots.titre}
1976
+                else {
1977
+                    if (preg_match('/^(.*)\.(.*)$/', $col, $r)) {
1978
+                        list(, $table, $col) = $r;
1979
+                        $col_alias = $col;
1980
+
1981
+                        $trouver_table = charger_fonction('trouver_table', 'base');
1982
+                        if ($desc = $trouver_table($table, $boucle->sql_serveur)
1983
+                            and isset($desc['field'][$col])
1984
+                            and $cle = array_search($desc['table'], $boucle->from)
1985
+                        ) {
1986
+                            $table = $cle;
1987
+                        } else {
1988
+                            $table = trouver_jointure_champ($col, $boucle, array($table), ($crit->cond or $op != '='));
1989
+                        }
1990
+                        #$table = calculer_critere_externe_init($boucle, array($table), $col, $desc, ($crit->cond OR $op!='='), true);
1991
+                        if (!$table) {
1992
+                            return '';
1993
+                        }
1994
+                    }
1995
+                    // si le champ n'est pas trouvé dans la table,
1996
+                    // on cherche si une jointure peut l'obtenir
1997
+                    elseif (@!array_key_exists($col, $desc['field'])) {
1998
+                        // Champ joker * des iterateurs DATA qui accepte tout
1999
+                        if (@array_key_exists('*', $desc['field'])) {
2000
+                            $desc['field'][$col_vraie ? $col_vraie : $col] = ''; // on veut pas de cast INT par defaut car le type peut etre n'importe quoi dans les boucles DATA
2001
+                        }
2002
+                        else {
2003
+                            $r = calculer_critere_infixe_externe($boucle, $crit, $op, $desc, $col, $col_alias, $table);
2004
+                            if (!$r) {
2005
+                                return '';
2006
+                            }
2007
+                            list($col, $col_alias, $table, $where_complement, $desc) = $r;
2008
+                        }
2009
+                    }
2010
+                }
2011
+            }
2012
+        }
2013
+    }
2014
+
2015
+    $col_vraie = ($col_vraie ? $col_vraie : $col);
2016
+    // Dans tous les cas,
2017
+    // virer les guillemets eventuels autour d'un int (qui sont refuses par certains SQL)
2018
+    // et passer dans sql_quote avec le type si connu
2019
+    // et int sinon si la valeur est numerique
2020
+    // sinon introduire le vrai type du champ si connu dans le sql_quote (ou int NOT NULL sinon)
2021
+    // Ne pas utiliser intval, PHP tronquant les Bigint de SQL
2022
+    if ($op == '=' or in_array($op, $GLOBALS['table_criteres_infixes'])) {
2023
+        $type_cast_quote = (isset($desc['field'][$col_vraie]) ? $desc['field'][$col_vraie] : 'int NOT NULL');
2024
+        // defaire le quote des int et les passer dans sql_quote avec le bon type de champ si on le connait, int sinon
2025
+        // prendre en compte le debug ou la valeur arrive avec un commentaire PHP en debut
2026
+        if (preg_match(",^\\A(\s*//.*?$\s*)?\"'(-?\d+)'\"\\z,ms", $val[0], $r)) {
2027
+            $val[0] = $r[1] . '"' . sql_quote($r[2], $boucle->sql_serveur, $type_cast_quote) . '"';
2028
+        }
2029
+        // sinon expliciter les
2030
+        // sql_quote(truc) en sql_quote(truc,'',type)
2031
+        // sql_quote(truc,serveur) en sql_quote(truc,serveur,type)
2032
+        // sql_quote(truc,serveur,'') en sql_quote(truc,serveur,type)
2033
+        // sans toucher aux
2034
+        // sql_quote(truc,'','varchar(10) DEFAULT \'oui\' COLLATE NOCASE')
2035
+        // sql_quote(truc,'','varchar')
2036
+        elseif (preg_match('/\Asql_quote[(](.*?)(,[^)]*?)?(,[^)]*(?:\(\d+\)[^)]*)?)?[)]\s*\z/ms', $val[0], $r)
2037
+            // si pas deja un type
2038
+            and (!isset($r[3]) or !$r[3] or !trim($r[3],", '"))
2039
+        ) {
2040
+            $r = $r[1]
2041
+                . ((isset($r[2]) and $r[2]) ? $r[2] : ",''")
2042
+                . ",'" . addslashes($type_cast_quote) . "'";
2043
+            $val[0] = "sql_quote($r)";
2044
+        }
2045
+        elseif(strpos($val[0], '@@defaultcast@@') !== false
2046
+          and preg_match("/'@@defaultcast@@'\s*\)\s*\z/ms", $val[0], $r)) {
2047
+            $val[0] = substr($val[0], 0, -strlen($r[0])) . "'" . addslashes($type_cast_quote) . "')";
2048
+        }
2049
+    }
2050
+
2051
+    if(strpos($val[0], '@@defaultcast@@') !== false
2052
+      and preg_match("/'@@defaultcast@@'\s*\)\s*\z/ms", $val[0], $r)) {
2053
+        $val[0] = substr($val[0], 0, -strlen($r[0])) . "'char')";
2054
+    }
2055
+
2056
+    // Indicateur pour permettre aux fonctionx boucle_X de modifier
2057
+    // leurs requetes par defaut, notamment le champ statut
2058
+    // Ne pas confondre champs de la table principale et des jointures
2059
+    if ($table === $boucle->id_table) {
2060
+        $boucles[$idb]->modificateur['criteres'][$col_vraie] = true;
2061
+        if ($col_alias != $col_vraie) {
2062
+            $boucles[$idb]->modificateur['criteres'][$col_alias] = true;
2063
+        }
2064
+    }
2065
+
2066
+    // ajout pour le cas special d'une condition sur le champ statut:
2067
+    // il faut alors interdire a la fonction de boucle
2068
+    // de mettre ses propres criteres de statut
2069
+    // http://www.spip.net/@statut (a documenter)
2070
+    // garde pour compatibilite avec code des plugins anterieurs, mais redondant avec la ligne precedente
2071
+    if ($col == 'statut') {
2072
+        $boucles[$idb]->statut = true;
2073
+    }
2074
+
2075
+    // inserer le nom de la table SQL devant le nom du champ
2076
+    if ($table) {
2077
+        if ($col[0] == "`") {
2078
+            $arg = "$table." . substr($col, 1, -1);
2079
+        } else {
2080
+            $arg = "$table.$col";
2081
+        }
2082
+    } else {
2083
+        $arg = $col;
2084
+    }
2085
+
2086
+    // inserer la fonction SQL
2087
+    if ($fct) {
2088
+        $arg = "$fct($arg$args_sql)";
2089
+    }
2090
+
2091
+    return array($arg, $op, $val, $col_alias, $where_complement);
2092 2092
 }
2093 2093
 
2094 2094
 
@@ -2117,77 +2117,77 @@  discard block
 block discarded – undo
2117 2117
  **/
2118 2118
 function calculer_critere_infixe_externe($boucle, $crit, $op, $desc, $col, $col_alias, $table) {
2119 2119
 
2120
-	$where = '';
2121
-
2122
-	$calculer_critere_externe = 'calculer_critere_externe_init';
2123
-	// gestion par les plugins des jointures tordues
2124
-	// pas automatiques mais necessaires
2125
-	$table_sql = table_objet_sql($table);
2126
-	if (isset($GLOBALS['exceptions_des_jointures'][$table_sql])
2127
-		and is_array($GLOBALS['exceptions_des_jointures'][$table_sql])
2128
-		and
2129
-		(
2130
-			isset($GLOBALS['exceptions_des_jointures'][$table_sql][$col])
2131
-			or
2132
-			isset($GLOBALS['exceptions_des_jointures'][$table_sql][''])
2133
-		)
2134
-	) {
2135
-		$t = $GLOBALS['exceptions_des_jointures'][$table_sql];
2136
-		$index = isset($t[$col])
2137
-			? $t[$col] : (isset($t['']) ? $t[''] : array());
2138
-
2139
-		if (count($index) == 3) {
2140
-			list($t, $col, $calculer_critere_externe) = $index;
2141
-		} elseif (count($index) == 2) {
2142
-			list($t, $col) = $t[$col];
2143
-		} elseif (count($index) == 1) {
2144
-			list($calculer_critere_externe) = $index;
2145
-			$t = $table;
2146
-		} else {
2147
-			$t = '';
2148
-		} // jointure non declaree. La trouver.
2149
-	} elseif (isset($GLOBALS['exceptions_des_jointures'][$col])) {
2150
-		list($t, $col) = $GLOBALS['exceptions_des_jointures'][$col];
2151
-	} else {
2152
-		$t = '';
2153
-	} // jointure non declaree. La trouver.
2154
-
2155
-	// ici on construit le from pour fournir $col en piochant dans les jointures
2156
-
2157
-	// si des jointures explicites sont fournies, on cherche d'abord dans celles ci
2158
-	// permet de forcer une table de lien quand il y a ambiguite
2159
-	// <BOUCLE_(DOCUMENTS documents_liens){id_mot}>
2160
-	// alors que <BOUCLE_(DOCUMENTS){id_mot}> produit la meme chose que <BOUCLE_(DOCUMENTS mots_liens){id_mot}>
2161
-	$table = "";
2162
-	if ($boucle->jointures_explicites) {
2163
-		$jointures_explicites = explode(' ', $boucle->jointures_explicites);
2164
-		$table = $calculer_critere_externe($boucle, $jointures_explicites, $col, $desc, ($crit->cond or $op != '='), $t);
2165
-	}
2166
-
2167
-	// et sinon on cherche parmi toutes les jointures declarees
2168
-	if (!$table) {
2169
-		$table = $calculer_critere_externe($boucle, $boucle->jointures, $col, $desc, ($crit->cond or $op != '='), $t);
2170
-	}
2171
-
2172
-	if (!$table) {
2173
-		return '';
2174
-	}
2175
-
2176
-	// il ne reste plus qu'a trouver le champ dans les from
2177
-	list($nom, $desc, $cle) = trouver_champ_exterieur($col, $boucle->from, $boucle);
2178
-
2179
-	if (count($cle) > 1 or reset($cle) !== $col) {
2180
-		$col_alias = $col; // id_article devient juste le nom d'origine
2181
-		if (count($cle) > 1 and reset($cle) == 'id_objet') {
2182
-			$e = decompose_champ_id_objet($col);
2183
-			$col = array_shift($e);
2184
-			$where = primary_doublee($e, $table);
2185
-		} else {
2186
-			$col = reset($cle);
2187
-		}
2188
-	}
2189
-
2190
-	return array($col, $col_alias, $table, $where, $desc);
2120
+    $where = '';
2121
+
2122
+    $calculer_critere_externe = 'calculer_critere_externe_init';
2123
+    // gestion par les plugins des jointures tordues
2124
+    // pas automatiques mais necessaires
2125
+    $table_sql = table_objet_sql($table);
2126
+    if (isset($GLOBALS['exceptions_des_jointures'][$table_sql])
2127
+        and is_array($GLOBALS['exceptions_des_jointures'][$table_sql])
2128
+        and
2129
+        (
2130
+            isset($GLOBALS['exceptions_des_jointures'][$table_sql][$col])
2131
+            or
2132
+            isset($GLOBALS['exceptions_des_jointures'][$table_sql][''])
2133
+        )
2134
+    ) {
2135
+        $t = $GLOBALS['exceptions_des_jointures'][$table_sql];
2136
+        $index = isset($t[$col])
2137
+            ? $t[$col] : (isset($t['']) ? $t[''] : array());
2138
+
2139
+        if (count($index) == 3) {
2140
+            list($t, $col, $calculer_critere_externe) = $index;
2141
+        } elseif (count($index) == 2) {
2142
+            list($t, $col) = $t[$col];
2143
+        } elseif (count($index) == 1) {
2144
+            list($calculer_critere_externe) = $index;
2145
+            $t = $table;
2146
+        } else {
2147
+            $t = '';
2148
+        } // jointure non declaree. La trouver.
2149
+    } elseif (isset($GLOBALS['exceptions_des_jointures'][$col])) {
2150
+        list($t, $col) = $GLOBALS['exceptions_des_jointures'][$col];
2151
+    } else {
2152
+        $t = '';
2153
+    } // jointure non declaree. La trouver.
2154
+
2155
+    // ici on construit le from pour fournir $col en piochant dans les jointures
2156
+
2157
+    // si des jointures explicites sont fournies, on cherche d'abord dans celles ci
2158
+    // permet de forcer une table de lien quand il y a ambiguite
2159
+    // <BOUCLE_(DOCUMENTS documents_liens){id_mot}>
2160
+    // alors que <BOUCLE_(DOCUMENTS){id_mot}> produit la meme chose que <BOUCLE_(DOCUMENTS mots_liens){id_mot}>
2161
+    $table = "";
2162
+    if ($boucle->jointures_explicites) {
2163
+        $jointures_explicites = explode(' ', $boucle->jointures_explicites);
2164
+        $table = $calculer_critere_externe($boucle, $jointures_explicites, $col, $desc, ($crit->cond or $op != '='), $t);
2165
+    }
2166
+
2167
+    // et sinon on cherche parmi toutes les jointures declarees
2168
+    if (!$table) {
2169
+        $table = $calculer_critere_externe($boucle, $boucle->jointures, $col, $desc, ($crit->cond or $op != '='), $t);
2170
+    }
2171
+
2172
+    if (!$table) {
2173
+        return '';
2174
+    }
2175
+
2176
+    // il ne reste plus qu'a trouver le champ dans les from
2177
+    list($nom, $desc, $cle) = trouver_champ_exterieur($col, $boucle->from, $boucle);
2178
+
2179
+    if (count($cle) > 1 or reset($cle) !== $col) {
2180
+        $col_alias = $col; // id_article devient juste le nom d'origine
2181
+        if (count($cle) > 1 and reset($cle) == 'id_objet') {
2182
+            $e = decompose_champ_id_objet($col);
2183
+            $col = array_shift($e);
2184
+            $where = primary_doublee($e, $table);
2185
+        } else {
2186
+            $col = reset($cle);
2187
+        }
2188
+    }
2189
+
2190
+    return array($col, $col_alias, $table, $where, $desc);
2191 2191
 }
2192 2192
 
2193 2193
 
@@ -2208,10 +2208,10 @@  discard block
 block discarded – undo
2208 2208
  *     - valeur
2209 2209
  **/
2210 2210
 function primary_doublee($decompose, $table) {
2211
-	$e1 = reset($decompose);
2212
-	$e2 = "sql_quote('" . end($decompose) . "')";
2211
+    $e1 = reset($decompose);
2212
+    $e2 = "sql_quote('" . end($decompose) . "')";
2213 2213
 
2214
-	return array("'='", "'$table." . $e1 . "'", $e2);
2214
+    return array("'='", "'$table." . $e1 . "'", $e2);
2215 2215
 }
2216 2216
 
2217 2217
 /**
@@ -2242,56 +2242,56 @@  discard block
 block discarded – undo
2242 2242
  *     Vide sinon.
2243 2243
  */
2244 2244
 function calculer_critere_externe_init(&$boucle, $joints, $col, $desc, $cond, $checkarrivee = false) {
2245
-	// si on demande un truc du genre spip_mots
2246
-	// avec aussi spip_mots_liens dans les jointures dispo
2247
-	// et qu'on est la
2248
-	// il faut privilegier la jointure directe en 2 etapes spip_mots_liens, spip_mots
2249
-	if ($checkarrivee
2250
-		and is_string($checkarrivee)
2251
-		and $a = table_objet($checkarrivee)
2252
-		and in_array($a . '_liens', $joints)
2253
-	) {
2254
-		if ($res = calculer_lien_externe_init($boucle, $joints, $col, $desc, $cond, $checkarrivee)) {
2255
-			return $res;
2256
-		}
2257
-	}
2258
-	foreach ($joints as $joint) {
2259
-		if ($arrivee = trouver_champ_exterieur($col, array($joint), $boucle, $checkarrivee)) {
2260
-			// alias de table dans le from
2261
-			$t = array_search($arrivee[0], $boucle->from);
2262
-			// recuperer la cle id_xx eventuellement decomposee en (id_objet,objet)
2263
-			$cols = $arrivee[2];
2264
-			// mais on ignore la 3eme cle si presente qui correspond alors au point de depart
2265
-			if (count($cols) > 2) {
2266
-				array_pop($cols);
2267
-			}
2268
-			if ($t) {
2269
-				// la table est déjà dans le FROM, on vérifie si le champ est utilisé.
2270
-				$joindre = false;
2271
-				foreach ($cols as $col) {
2272
-					$c = '/\b' . $t . ".$col" . '\b/';
2273
-					if (trouver_champ($c, $boucle->where)) {
2274
-						$joindre = true;
2275
-					} else {
2276
-						// mais ca peut etre dans le FIELD pour le Having
2277
-						$c = "/FIELD.$t" . ".$col,/";
2278
-						if (trouver_champ($c, $boucle->select)) {
2279
-							$joindre = true;
2280
-						}
2281
-					}
2282
-				}
2283
-				if (!$joindre) {
2284
-					return $t;
2285
-				}
2286
-			}
2287
-			array_pop($arrivee);
2288
-			if ($res = calculer_jointure($boucle, array($boucle->id_table, $desc), $arrivee, $cols, $cond, 1)) {
2289
-				return $res;
2290
-			}
2291
-		}
2292
-	}
2293
-
2294
-	return '';
2245
+    // si on demande un truc du genre spip_mots
2246
+    // avec aussi spip_mots_liens dans les jointures dispo
2247
+    // et qu'on est la
2248
+    // il faut privilegier la jointure directe en 2 etapes spip_mots_liens, spip_mots
2249
+    if ($checkarrivee
2250
+        and is_string($checkarrivee)
2251
+        and $a = table_objet($checkarrivee)
2252
+        and in_array($a . '_liens', $joints)
2253
+    ) {
2254
+        if ($res = calculer_lien_externe_init($boucle, $joints, $col, $desc, $cond, $checkarrivee)) {
2255
+            return $res;
2256
+        }
2257
+    }
2258
+    foreach ($joints as $joint) {
2259
+        if ($arrivee = trouver_champ_exterieur($col, array($joint), $boucle, $checkarrivee)) {
2260
+            // alias de table dans le from
2261
+            $t = array_search($arrivee[0], $boucle->from);
2262
+            // recuperer la cle id_xx eventuellement decomposee en (id_objet,objet)
2263
+            $cols = $arrivee[2];
2264
+            // mais on ignore la 3eme cle si presente qui correspond alors au point de depart
2265
+            if (count($cols) > 2) {
2266
+                array_pop($cols);
2267
+            }
2268
+            if ($t) {
2269
+                // la table est déjà dans le FROM, on vérifie si le champ est utilisé.
2270
+                $joindre = false;
2271
+                foreach ($cols as $col) {
2272
+                    $c = '/\b' . $t . ".$col" . '\b/';
2273
+                    if (trouver_champ($c, $boucle->where)) {
2274
+                        $joindre = true;
2275
+                    } else {
2276
+                        // mais ca peut etre dans le FIELD pour le Having
2277
+                        $c = "/FIELD.$t" . ".$col,/";
2278
+                        if (trouver_champ($c, $boucle->select)) {
2279
+                            $joindre = true;
2280
+                        }
2281
+                    }
2282
+                }
2283
+                if (!$joindre) {
2284
+                    return $t;
2285
+                }
2286
+            }
2287
+            array_pop($arrivee);
2288
+            if ($res = calculer_jointure($boucle, array($boucle->id_table, $desc), $arrivee, $cols, $cond, 1)) {
2289
+                return $res;
2290
+            }
2291
+        }
2292
+    }
2293
+
2294
+    return '';
2295 2295
 
2296 2296
 }
2297 2297
 
@@ -2318,29 +2318,29 @@  discard block
 block discarded – undo
2318 2318
  *     Alias de la table de jointure (Lx)
2319 2319
  */
2320 2320
 function calculer_lien_externe_init(&$boucle, $joints, $col, $desc, $cond, $checkarrivee = false) {
2321
-	$primary_arrivee = id_table_objet($checkarrivee);
2322
-
2323
-	// [FIXME] $checkarrivee peut-il arriver avec false ????
2324
-	$intermediaire = trouver_champ_exterieur($primary_arrivee, $joints, $boucle, $checkarrivee . "_liens");
2325
-	$arrivee = trouver_champ_exterieur($col, $joints, $boucle, $checkarrivee);
2326
-
2327
-	if (!$intermediaire or !$arrivee) {
2328
-		return '';
2329
-	}
2330
-	array_pop($intermediaire); // enlever la cle en 3eme argument
2331
-	array_pop($arrivee); // enlever la cle en 3eme argument
2332
-
2333
-	$res = fabrique_jointures($boucle,
2334
-		array(
2335
-			array(
2336
-				$boucle->id_table,
2337
-				$intermediaire,
2338
-				array(id_table_objet($desc['table_objet']), 'id_objet', 'objet', $desc['type'])
2339
-			),
2340
-			array(reset($intermediaire), $arrivee, $primary_arrivee)
2341
-		), $cond, $desc, $boucle->id_table, array($col));
2342
-
2343
-	return $res;
2321
+    $primary_arrivee = id_table_objet($checkarrivee);
2322
+
2323
+    // [FIXME] $checkarrivee peut-il arriver avec false ????
2324
+    $intermediaire = trouver_champ_exterieur($primary_arrivee, $joints, $boucle, $checkarrivee . "_liens");
2325
+    $arrivee = trouver_champ_exterieur($col, $joints, $boucle, $checkarrivee);
2326
+
2327
+    if (!$intermediaire or !$arrivee) {
2328
+        return '';
2329
+    }
2330
+    array_pop($intermediaire); // enlever la cle en 3eme argument
2331
+    array_pop($arrivee); // enlever la cle en 3eme argument
2332
+
2333
+    $res = fabrique_jointures($boucle,
2334
+        array(
2335
+            array(
2336
+                $boucle->id_table,
2337
+                $intermediaire,
2338
+                array(id_table_objet($desc['table_objet']), 'id_objet', 'objet', $desc['type'])
2339
+            ),
2340
+            array(reset($intermediaire), $arrivee, $primary_arrivee)
2341
+        ), $cond, $desc, $boucle->id_table, array($col));
2342
+
2343
+    return $res;
2344 2344
 }
2345 2345
 
2346 2346
 
@@ -2357,17 +2357,17 @@  discard block
 block discarded – undo
2357 2357
  *     false sinon.
2358 2358
  **/
2359 2359
 function trouver_champ($champ, $where) {
2360
-	if (!is_array($where)) {
2361
-		return preg_match($champ, $where);
2362
-	} else {
2363
-		foreach ($where as $clause) {
2364
-			if (trouver_champ($champ, $clause)) {
2365
-				return true;
2366
-			}
2367
-		}
2368
-
2369
-		return false;
2370
-	}
2360
+    if (!is_array($where)) {
2361
+        return preg_match($champ, $where);
2362
+    } else {
2363
+        foreach ($where as $clause) {
2364
+            if (trouver_champ($champ, $clause)) {
2365
+                return true;
2366
+            }
2367
+        }
2368
+
2369
+        return false;
2370
+    }
2371 2371
 }
2372 2372
 
2373 2373
 
@@ -2393,129 +2393,129 @@  discard block
 block discarded – undo
2393 2393
  *     - string $args_sql  Suite des arguments du critère. ?
2394 2394
  **/
2395 2395
 function calculer_critere_infixe_ops($idb, &$boucles, $crit) {
2396
-	// cas d'une valeur comparee a elle-meme ou son referent
2397
-	if (count($crit->param) == 0) {
2398
-		$op = '=';
2399
-		$col = $val = $crit->op;
2400
-		if (preg_match('/^(.*)\.(.*)$/', $col, $r)) {
2401
-			$val = $r[2];
2402
-		}
2403
-		// Cas special {lang} : aller chercher $GLOBALS['spip_lang']
2404
-		if ($val == 'lang') {
2405
-			$val = array(kwote('$GLOBALS[\'spip_lang\']'));
2406
-		} else {
2407
-			$defaut = null;
2408
-			if ($val == 'id_parent') {
2409
-				// Si id_parent, comparer l'id_parent avec l'id_objet
2410
-				// de la boucle superieure.... faudrait verifier qu'il existe
2411
-				// pour eviter l'erreur SQL
2412
-				$val = $boucles[$idb]->primary;
2413
-				// mais si pas de boucle superieure, prendre id_parent dans l'env
2414
-				$defaut = "@\$Pile[0]['id_parent']";
2415
-			} elseif ($val == 'id_enfant') {
2416
-				// Si id_enfant, comparer l'id_objet avec l'id_parent
2417
-				// de la boucle superieure
2418
-				$val = 'id_parent';
2419
-			} elseif ($crit->cond and ($col == "date" or $col == "date_redac")) {
2420
-				// un critere conditionnel sur date est traite a part
2421
-				// car la date est mise d'office par SPIP,
2422
-				$defaut = "(\$Pile[0]['{$col}_default']?'':\$Pile[0]['" . $col . "'])";
2423
-			}
2424
-
2425
-			$val = calculer_argument_precedent($idb, $val, $boucles, $defaut);
2426
-			$val = array(kwote($val));
2427
-		}
2428
-	} else {
2429
-		// comparaison explicite
2430
-		// le phraseur impose que le premier param soit du texte
2431
-		$params = $crit->param;
2432
-		$op = $crit->op;
2433
-		if ($op == '==') {
2434
-			$op = 'REGEXP';
2435
-		}
2436
-		$col = array_shift($params);
2437
-		$col = $col[0]->texte;
2438
-
2439
-		$val = array();
2440
-		$desc = array('id_mere' => $idb);
2441
-		$parent = $boucles[$idb]->id_parent;
2442
-
2443
-		// Dans le cas {x=='#DATE'} etc, defaire le travail du phraseur,
2444
-		// celui ne sachant pas ce qu'est un critere infixe
2445
-		// et a fortiori son 2e operande qu'entoure " ou '
2446
-		if (count($params) == 1
2447
-			and count($params[0]) == 3
2448
-			and $params[0][0]->type == 'texte'
2449
-			and $params[0][2]->type == 'texte'
2450
-			and ($p = $params[0][0]->texte) == $params[0][2]->texte
2451
-			and (($p == "'") or ($p == '"'))
2452
-			and $params[0][1]->type == 'champ'
2453
-		) {
2454
-			$val[] = "$p\\$p#" . $params[0][1]->nom_champ . "\\$p$p";
2455
-		} else {
2456
-			foreach ((($op != 'IN') ? $params : calculer_vieux_in($params)) as $p) {
2457
-				$a = calculer_liste($p, $desc, $boucles, $parent);
2458
-				if (strcasecmp($op, 'IN') == 0) {
2459
-					$val[] = $a;
2460
-				} else {
2461
-					$val[] = kwote($a, $boucles[$idb]->sql_serveur, '@@defaultcast@@');
2462
-				} // toujours quoter en char ici
2463
-			}
2464
-		}
2465
-	}
2466
-
2467
-	$fct = $args_sql = '';
2468
-	// fonction SQL ?
2469
-	// chercher FONCTION(champ) tel que CONCAT(titre,descriptif)
2470
-	if (preg_match('/^(.*)' . SQL_ARGS . '$/', $col, $m)) {
2471
-		$fct = $m[1];
2472
-		preg_match('/^\(([^,]*)(.*)\)$/', $m[2], $a);
2473
-		$col = $a[1];
2474
-		if (preg_match('/^(\S*)(\s+AS\s+.*)$/i', $col, $m)) {
2475
-			$col = $m[1];
2476
-			$args_sql = $m[2];
2477
-		}
2478
-		$args_sql .= $a[2];
2479
-	}
2480
-
2481
-	return array($fct, $col, $op, $val, $args_sql);
2396
+    // cas d'une valeur comparee a elle-meme ou son referent
2397
+    if (count($crit->param) == 0) {
2398
+        $op = '=';
2399
+        $col = $val = $crit->op;
2400
+        if (preg_match('/^(.*)\.(.*)$/', $col, $r)) {
2401
+            $val = $r[2];
2402
+        }
2403
+        // Cas special {lang} : aller chercher $GLOBALS['spip_lang']
2404
+        if ($val == 'lang') {
2405
+            $val = array(kwote('$GLOBALS[\'spip_lang\']'));
2406
+        } else {
2407
+            $defaut = null;
2408
+            if ($val == 'id_parent') {
2409
+                // Si id_parent, comparer l'id_parent avec l'id_objet
2410
+                // de la boucle superieure.... faudrait verifier qu'il existe
2411
+                // pour eviter l'erreur SQL
2412
+                $val = $boucles[$idb]->primary;
2413
+                // mais si pas de boucle superieure, prendre id_parent dans l'env
2414
+                $defaut = "@\$Pile[0]['id_parent']";
2415
+            } elseif ($val == 'id_enfant') {
2416
+                // Si id_enfant, comparer l'id_objet avec l'id_parent
2417
+                // de la boucle superieure
2418
+                $val = 'id_parent';
2419
+            } elseif ($crit->cond and ($col == "date" or $col == "date_redac")) {
2420
+                // un critere conditionnel sur date est traite a part
2421
+                // car la date est mise d'office par SPIP,
2422
+                $defaut = "(\$Pile[0]['{$col}_default']?'':\$Pile[0]['" . $col . "'])";
2423
+            }
2424
+
2425
+            $val = calculer_argument_precedent($idb, $val, $boucles, $defaut);
2426
+            $val = array(kwote($val));
2427
+        }
2428
+    } else {
2429
+        // comparaison explicite
2430
+        // le phraseur impose que le premier param soit du texte
2431
+        $params = $crit->param;
2432
+        $op = $crit->op;
2433
+        if ($op == '==') {
2434
+            $op = 'REGEXP';
2435
+        }
2436
+        $col = array_shift($params);
2437
+        $col = $col[0]->texte;
2438
+
2439
+        $val = array();
2440
+        $desc = array('id_mere' => $idb);
2441
+        $parent = $boucles[$idb]->id_parent;
2442
+
2443
+        // Dans le cas {x=='#DATE'} etc, defaire le travail du phraseur,
2444
+        // celui ne sachant pas ce qu'est un critere infixe
2445
+        // et a fortiori son 2e operande qu'entoure " ou '
2446
+        if (count($params) == 1
2447
+            and count($params[0]) == 3
2448
+            and $params[0][0]->type == 'texte'
2449
+            and $params[0][2]->type == 'texte'
2450
+            and ($p = $params[0][0]->texte) == $params[0][2]->texte
2451
+            and (($p == "'") or ($p == '"'))
2452
+            and $params[0][1]->type == 'champ'
2453
+        ) {
2454
+            $val[] = "$p\\$p#" . $params[0][1]->nom_champ . "\\$p$p";
2455
+        } else {
2456
+            foreach ((($op != 'IN') ? $params : calculer_vieux_in($params)) as $p) {
2457
+                $a = calculer_liste($p, $desc, $boucles, $parent);
2458
+                if (strcasecmp($op, 'IN') == 0) {
2459
+                    $val[] = $a;
2460
+                } else {
2461
+                    $val[] = kwote($a, $boucles[$idb]->sql_serveur, '@@defaultcast@@');
2462
+                } // toujours quoter en char ici
2463
+            }
2464
+        }
2465
+    }
2466
+
2467
+    $fct = $args_sql = '';
2468
+    // fonction SQL ?
2469
+    // chercher FONCTION(champ) tel que CONCAT(titre,descriptif)
2470
+    if (preg_match('/^(.*)' . SQL_ARGS . '$/', $col, $m)) {
2471
+        $fct = $m[1];
2472
+        preg_match('/^\(([^,]*)(.*)\)$/', $m[2], $a);
2473
+        $col = $a[1];
2474
+        if (preg_match('/^(\S*)(\s+AS\s+.*)$/i', $col, $m)) {
2475
+            $col = $m[1];
2476
+            $args_sql = $m[2];
2477
+        }
2478
+        $args_sql .= $a[2];
2479
+    }
2480
+
2481
+    return array($fct, $col, $op, $val, $args_sql);
2482 2482
 }
2483 2483
 
2484 2484
 // compatibilite ancienne version
2485 2485
 
2486 2486
 // http://code.spip.net/@calculer_vieux_in
2487 2487
 function calculer_vieux_in($params) {
2488
-	$deb = $params[0][0];
2489
-	$k = count($params) - 1;
2490
-	$last = $params[$k];
2491
-	$j = count($last) - 1;
2492
-	$last = $last[$j];
2493
-	$n = isset($last->texte) ? strlen($last->texte) : 0;
2494
-
2495
-	if (!((isset($deb->texte[0]) and $deb->texte[0] == '(')
2496
-		&& (isset($last->texte[$n - 1]) and $last->texte[$n - 1] == ')'))
2497
-	) {
2498
-		return $params;
2499
-	}
2500
-	$params[0][0]->texte = substr($deb->texte, 1);
2501
-	// attention, on peut avoir k=0,j=0 ==> recalculer
2502
-	$last = $params[$k][$j];
2503
-	$n = strlen($last->texte);
2504
-	$params[$k][$j]->texte = substr($last->texte, 0, $n - 1);
2505
-	$newp = array();
2506
-	foreach ($params as $v) {
2507
-		if ($v[0]->type != 'texte') {
2508
-			$newp[] = $v;
2509
-		} else {
2510
-			foreach (explode(',', $v[0]->texte) as $x) {
2511
-				$t = new Texte;
2512
-				$t->texte = $x;
2513
-				$newp[] = array($t);
2514
-			}
2515
-		}
2516
-	}
2517
-
2518
-	return $newp;
2488
+    $deb = $params[0][0];
2489
+    $k = count($params) - 1;
2490
+    $last = $params[$k];
2491
+    $j = count($last) - 1;
2492
+    $last = $last[$j];
2493
+    $n = isset($last->texte) ? strlen($last->texte) : 0;
2494
+
2495
+    if (!((isset($deb->texte[0]) and $deb->texte[0] == '(')
2496
+        && (isset($last->texte[$n - 1]) and $last->texte[$n - 1] == ')'))
2497
+    ) {
2498
+        return $params;
2499
+    }
2500
+    $params[0][0]->texte = substr($deb->texte, 1);
2501
+    // attention, on peut avoir k=0,j=0 ==> recalculer
2502
+    $last = $params[$k][$j];
2503
+    $n = strlen($last->texte);
2504
+    $params[$k][$j]->texte = substr($last->texte, 0, $n - 1);
2505
+    $newp = array();
2506
+    foreach ($params as $v) {
2507
+        if ($v[0]->type != 'texte') {
2508
+            $newp[] = $v;
2509
+        } else {
2510
+            foreach (explode(',', $v[0]->texte) as $x) {
2511
+                $t = new Texte;
2512
+                $t->texte = $x;
2513
+                $newp[] = array($t);
2514
+            }
2515
+        }
2516
+    }
2517
+
2518
+    return $newp;
2519 2519
 }
2520 2520
 
2521 2521
 /**
@@ -2534,89 +2534,89 @@  discard block
 block discarded – undo
2534 2534
  *     - nom de la colonne de date (si le calcul n'est pas relatif)
2535 2535
  **/
2536 2536
 function calculer_critere_infixe_date($idb, &$boucles, $col) {
2537
-	if (!preg_match(",^((age|jour|mois|annee)_relatif|date|mois|annee|jour|heure|age)(_[a-z]+)?$,", $col, $regs)) {
2538
-		return '';
2539
-	}
2540
-
2541
-	$boucle = $boucles[$idb];
2542
-	$table = $boucle->show;
2543
-
2544
-	// si c'est une colonne de la table, ne rien faire
2545
-	if (isset($table['field'][$col])) {
2546
-		return '';
2547
-	}
2548
-
2549
-	if (!$table['date'] && !isset($GLOBALS['table_date'][$table['id_table']])) {
2550
-		return '';
2551
-	}
2552
-	$pred = $date_orig = isset($GLOBALS['table_date'][$table['id_table']]) ? $GLOBALS['table_date'][$table['id_table']] : $table['date'];
2553
-
2554
-	$col = $regs[1];
2555
-	if (isset($regs[3]) and $suite = $regs[3]) {
2556
-		# Recherche de l'existence du champ date_xxxx,
2557
-		# si oui choisir ce champ, sinon choisir xxxx
2558
-
2559
-		if (isset($table['field']["date$suite"])) {
2560
-			$date_orig = 'date' . $suite;
2561
-		} else {
2562
-			$date_orig = substr($suite, 1);
2563
-		}
2564
-		$pred = $date_orig;
2565
-	} else {
2566
-		if (isset($regs[2]) and $rel = $regs[2]) {
2567
-			$pred = 'date';
2568
-		}
2569
-	}
2570
-
2571
-	$date_compare = "\"' . normaliser_date(" .
2572
-		calculer_argument_precedent($idb, $pred, $boucles) .
2573
-		") . '\"";
2574
-
2575
-	$col_vraie = $date_orig;
2576
-	$date_orig = $boucle->id_table . '.' . $date_orig;
2577
-
2578
-	switch ($col) {
2579
-		case 'date':
2580
-			$col = $date_orig;
2581
-			break;
2582
-		case 'jour':
2583
-			$col = "DAYOFMONTH($date_orig)";
2584
-			break;
2585
-		case 'mois':
2586
-			$col = "MONTH($date_orig)";
2587
-			break;
2588
-		case 'annee':
2589
-			$col = "YEAR($date_orig)";
2590
-			break;
2591
-		case 'heure':
2592
-			$col = "DATE_FORMAT($date_orig, \\'%H:%i\\')";
2593
-			break;
2594
-		case 'age':
2595
-			$col = calculer_param_date("NOW()", $date_orig);
2596
-			$col_vraie = "";// comparer a un int (par defaut)
2597
-			break;
2598
-		case 'age_relatif':
2599
-			$col = calculer_param_date($date_compare, $date_orig);
2600
-			$col_vraie = "";// comparer a un int (par defaut)
2601
-			break;
2602
-		case 'jour_relatif':
2603
-			$col = "(TO_DAYS(" . $date_compare . ")-TO_DAYS(" . $date_orig . "))";
2604
-			$col_vraie = "";// comparer a un int (par defaut)
2605
-			break;
2606
-		case 'mois_relatif':
2607
-			$col = "MONTH(" . $date_compare . ")-MONTH(" .
2608
-				$date_orig . ")+12*(YEAR(" . $date_compare .
2609
-				")-YEAR(" . $date_orig . "))";
2610
-			$col_vraie = "";// comparer a un int (par defaut)
2611
-			break;
2612
-		case 'annee_relatif':
2613
-			$col = "YEAR(" . $date_compare . ")-YEAR(" .
2614
-				$date_orig . ")";
2615
-			$col_vraie = "";// comparer a un int (par defaut)
2616
-			break;
2617
-	}
2618
-
2619
-	return array($col, $col_vraie);
2537
+    if (!preg_match(",^((age|jour|mois|annee)_relatif|date|mois|annee|jour|heure|age)(_[a-z]+)?$,", $col, $regs)) {
2538
+        return '';
2539
+    }
2540
+
2541
+    $boucle = $boucles[$idb];
2542
+    $table = $boucle->show;
2543
+
2544
+    // si c'est une colonne de la table, ne rien faire
2545
+    if (isset($table['field'][$col])) {
2546
+        return '';
2547
+    }
2548
+
2549
+    if (!$table['date'] && !isset($GLOBALS['table_date'][$table['id_table']])) {
2550
+        return '';
2551
+    }
2552
+    $pred = $date_orig = isset($GLOBALS['table_date'][$table['id_table']]) ? $GLOBALS['table_date'][$table['id_table']] : $table['date'];
2553
+
2554
+    $col = $regs[1];
2555
+    if (isset($regs[3]) and $suite = $regs[3]) {
2556
+        # Recherche de l'existence du champ date_xxxx,
2557
+        # si oui choisir ce champ, sinon choisir xxxx
2558
+
2559
+        if (isset($table['field']["date$suite"])) {
2560
+            $date_orig = 'date' . $suite;
2561
+        } else {
2562
+            $date_orig = substr($suite, 1);
2563
+        }
2564
+        $pred = $date_orig;
2565
+    } else {
2566
+        if (isset($regs[2]) and $rel = $regs[2]) {
2567
+            $pred = 'date';
2568
+        }
2569
+    }
2570
+
2571
+    $date_compare = "\"' . normaliser_date(" .
2572
+        calculer_argument_precedent($idb, $pred, $boucles) .
2573
+        ") . '\"";
2574
+
2575
+    $col_vraie = $date_orig;
2576
+    $date_orig = $boucle->id_table . '.' . $date_orig;
2577
+
2578
+    switch ($col) {
2579
+        case 'date':
2580
+            $col = $date_orig;
2581
+            break;
2582
+        case 'jour':
2583
+            $col = "DAYOFMONTH($date_orig)";
2584
+            break;
2585
+        case 'mois':
2586
+            $col = "MONTH($date_orig)";
2587
+            break;
2588
+        case 'annee':
2589
+            $col = "YEAR($date_orig)";
2590
+            break;
2591
+        case 'heure':
2592
+            $col = "DATE_FORMAT($date_orig, \\'%H:%i\\')";
2593
+            break;
2594
+        case 'age':
2595
+            $col = calculer_param_date("NOW()", $date_orig);
2596
+            $col_vraie = "";// comparer a un int (par defaut)
2597
+            break;
2598
+        case 'age_relatif':
2599
+            $col = calculer_param_date($date_compare, $date_orig);
2600
+            $col_vraie = "";// comparer a un int (par defaut)
2601
+            break;
2602
+        case 'jour_relatif':
2603
+            $col = "(TO_DAYS(" . $date_compare . ")-TO_DAYS(" . $date_orig . "))";
2604
+            $col_vraie = "";// comparer a un int (par defaut)
2605
+            break;
2606
+        case 'mois_relatif':
2607
+            $col = "MONTH(" . $date_compare . ")-MONTH(" .
2608
+                $date_orig . ")+12*(YEAR(" . $date_compare .
2609
+                ")-YEAR(" . $date_orig . "))";
2610
+            $col_vraie = "";// comparer a un int (par defaut)
2611
+            break;
2612
+        case 'annee_relatif':
2613
+            $col = "YEAR(" . $date_compare . ")-YEAR(" .
2614
+                $date_orig . ")";
2615
+            $col_vraie = "";// comparer a un int (par defaut)
2616
+            break;
2617
+    }
2618
+
2619
+    return array($col, $col_vraie);
2620 2620
 }
2621 2621
 
2622 2622
 /**
@@ -2635,16 +2635,16 @@  discard block
 block discarded – undo
2635 2635
  *     de colonne SQL et une date.
2636 2636
  **/
2637 2637
 function calculer_param_date($date_compare, $date_orig) {
2638
-	if (preg_match(",'\" *\.(.*)\. *\"',", $date_compare, $r)) {
2639
-		$init = "'\" . (\$x = $r[1]) . \"'";
2640
-		$date_compare = '\'$x\'';
2641
-	} else {
2642
-		$init = $date_compare;
2643
-	}
2644
-
2645
-	return
2646
-		// optimisation : mais prevoir le support SQLite avant
2647
-		"TIMESTAMPDIFF(HOUR,$date_orig,$init)/24";
2638
+    if (preg_match(",'\" *\.(.*)\. *\"',", $date_compare, $r)) {
2639
+        $init = "'\" . (\$x = $r[1]) . \"'";
2640
+        $date_compare = '\'$x\'';
2641
+    } else {
2642
+        $init = $date_compare;
2643
+    }
2644
+
2645
+    return
2646
+        // optimisation : mais prevoir le support SQLite avant
2647
+        "TIMESTAMPDIFF(HOUR,$date_orig,$init)/24";
2648 2648
 }
2649 2649
 
2650 2650
 /**
@@ -2662,18 +2662,18 @@  discard block
 block discarded – undo
2662 2662
  * @param Critere $crit Paramètres du critère dans cette boucle
2663 2663
  */
2664 2664
 function critere_DATA_source_dist($idb, &$boucles, $crit) {
2665
-	$boucle = &$boucles[$idb];
2665
+    $boucle = &$boucles[$idb];
2666 2666
 
2667
-	$args = array();
2668
-	foreach ($crit->param as &$param) {
2669
-		array_push($args,
2670
-			calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent));
2671
-	}
2667
+    $args = array();
2668
+    foreach ($crit->param as &$param) {
2669
+        array_push($args,
2670
+            calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent));
2671
+    }
2672 2672
 
2673
-	$boucle->hash .= '
2673
+    $boucle->hash .= '
2674 2674
 	$command[\'sourcemode\'] = ' . array_shift($args) . ";\n";
2675 2675
 
2676
-	$boucle->hash .= '
2676
+    $boucle->hash .= '
2677 2677
 	$command[\'source\'] = array(' . join(', ', $args) . ");\n";
2678 2678
 }
2679 2679
 
@@ -2690,8 +2690,8 @@  discard block
 block discarded – undo
2690 2690
  * @param Critere $crit Paramètres du critère dans cette boucle
2691 2691
  */
2692 2692
 function critere_DATA_datasource_dist($idb, &$boucles, $crit) {
2693
-	$boucle = &$boucles[$idb];
2694
-	$boucle->hash .= '
2693
+    $boucle = &$boucles[$idb];
2694
+    $boucle->hash .= '
2695 2695
 	$command[\'source\'] = array(' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent) . ');
2696 2696
 	$command[\'sourcemode\'] = ' . calculer_liste($crit->param[1], array(), $boucles, $boucles[$idb]->id_parent) . ';';
2697 2697
 }
@@ -2711,8 +2711,8 @@  discard block
 block discarded – undo
2711 2711
  * @param Critere $crit Paramètres du critère dans cette boucle
2712 2712
  */
2713 2713
 function critere_DATA_datacache_dist($idb, &$boucles, $crit) {
2714
-	$boucle = &$boucles[$idb];
2715
-	$boucle->hash .= '
2714
+    $boucle = &$boucles[$idb];
2715
+    $boucle->hash .= '
2716 2716
 	$command[\'datacache\'] = ' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent) . ';';
2717 2717
 }
2718 2718
 
@@ -2728,12 +2728,12 @@  discard block
 block discarded – undo
2728 2728
  * @param Critere $crit Paramètres du critère dans cette boucle
2729 2729
  */
2730 2730
 function critere_php_args_dist($idb, &$boucles, $crit) {
2731
-	$boucle = &$boucles[$idb];
2732
-	$boucle->hash .= '$command[\'args\']=array();';
2733
-	foreach ($crit->param as $param) {
2734
-		$boucle->hash .= '
2731
+    $boucle = &$boucles[$idb];
2732
+    $boucle->hash .= '$command[\'args\']=array();';
2733
+    foreach ($crit->param as $param) {
2734
+        $boucle->hash .= '
2735 2735
 			$command[\'args\'][] = ' . calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent) . ';';
2736
-	}
2736
+    }
2737 2737
 }
2738 2738
 
2739 2739
 /**
@@ -2750,12 +2750,12 @@  discard block
 block discarded – undo
2750 2750
  * @param Critere $crit Paramètres du critère dans cette boucle
2751 2751
  */
2752 2752
 function critere_DATA_liste_dist($idb, &$boucles, $crit) {
2753
-	$boucle = &$boucles[$idb];
2754
-	$boucle->hash .= "\n\t" . '$command[\'liste\'] = array();' . "\n";
2755
-	foreach ($crit->param as $param) {
2756
-		$boucle->hash .= "\t" . '$command[\'liste\'][] = ' . calculer_liste($param, array(), $boucles,
2757
-				$boucles[$idb]->id_parent) . ";\n";
2758
-	}
2753
+    $boucle = &$boucles[$idb];
2754
+    $boucle->hash .= "\n\t" . '$command[\'liste\'] = array();' . "\n";
2755
+    foreach ($crit->param as $param) {
2756
+        $boucle->hash .= "\t" . '$command[\'liste\'][] = ' . calculer_liste($param, array(), $boucles,
2757
+                $boucles[$idb]->id_parent) . ";\n";
2758
+    }
2759 2759
 }
2760 2760
 
2761 2761
 /**
@@ -2780,12 +2780,12 @@  discard block
 block discarded – undo
2780 2780
  * @param Critere $crit Paramètres du critère dans cette boucle
2781 2781
  */
2782 2782
 function critere_DATA_enum_dist($idb, &$boucles, $crit) {
2783
-	$boucle = &$boucles[$idb];
2784
-	$boucle->hash .= "\n\t" . '$command[\'enum\'] = array();' . "\n";
2785
-	foreach ($crit->param as $param) {
2786
-		$boucle->hash .= "\t" . '$command[\'enum\'][] = ' . calculer_liste($param, array(), $boucles,
2787
-				$boucles[$idb]->id_parent) . ";\n";
2788
-	}
2783
+    $boucle = &$boucles[$idb];
2784
+    $boucle->hash .= "\n\t" . '$command[\'enum\'] = array();' . "\n";
2785
+    foreach ($crit->param as $param) {
2786
+        $boucle->hash .= "\t" . '$command[\'enum\'][] = ' . calculer_liste($param, array(), $boucles,
2787
+                $boucles[$idb]->id_parent) . ";\n";
2788
+    }
2789 2789
 }
2790 2790
 
2791 2791
 /**
@@ -2800,11 +2800,11 @@  discard block
 block discarded – undo
2800 2800
  * @param Critere $crit Paramètres du critère dans cette boucle
2801 2801
  */
2802 2802
 function critere_DATA_datapath_dist($idb, &$boucles, $crit) {
2803
-	$boucle = &$boucles[$idb];
2804
-	foreach ($crit->param as $param) {
2805
-		$boucle->hash .= '
2803
+    $boucle = &$boucles[$idb];
2804
+    foreach ($crit->param as $param) {
2805
+        $boucle->hash .= '
2806 2806
 			$command[\'datapath\'][] = ' . calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent) . ';';
2807
-	}
2807
+    }
2808 2808
 }
2809 2809
 
2810 2810
 
@@ -2836,20 +2836,20 @@  discard block
 block discarded – undo
2836 2836
  * @param Critere $crit Paramètres du critère dans cette boucle
2837 2837
  */
2838 2838
 function critere_si_dist($idb, &$boucles, $crit) {
2839
-	$boucle = &$boucles[$idb];
2840
-	// il faut initialiser 1 fois le tableau a chaque appel de la boucle
2841
-	// (par exemple lorsque notre boucle est appelee dans une autre boucle)
2842
-	// mais ne pas l'initialiser n fois si il y a n criteres {si } dans la boucle !
2843
-	$boucle->hash .= "\n\tif (!isset(\$si_init)) { \$command['si'] = array(); \$si_init = true; }\n";
2844
-	if ($crit->param) {
2845
-		foreach ($crit->param as $param) {
2846
-			$boucle->hash .= "\t\$command['si'][] = "
2847
-				. calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent) . ";\n";
2848
-		}
2849
-		// interdire {si 0} aussi !
2850
-	} else {
2851
-		$boucle->hash .= '$command[\'si\'][] = 0;';
2852
-	}
2839
+    $boucle = &$boucles[$idb];
2840
+    // il faut initialiser 1 fois le tableau a chaque appel de la boucle
2841
+    // (par exemple lorsque notre boucle est appelee dans une autre boucle)
2842
+    // mais ne pas l'initialiser n fois si il y a n criteres {si } dans la boucle !
2843
+    $boucle->hash .= "\n\tif (!isset(\$si_init)) { \$command['si'] = array(); \$si_init = true; }\n";
2844
+    if ($crit->param) {
2845
+        foreach ($crit->param as $param) {
2846
+            $boucle->hash .= "\t\$command['si'][] = "
2847
+                . calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent) . ";\n";
2848
+        }
2849
+        // interdire {si 0} aussi !
2850
+    } else {
2851
+        $boucle->hash .= '$command[\'si\'][] = 0;';
2852
+    }
2853 2853
 }
2854 2854
 
2855 2855
 /**
@@ -2865,8 +2865,8 @@  discard block
 block discarded – undo
2865 2865
  * @param Critere $crit Paramètres du critère dans cette boucle
2866 2866
  */
2867 2867
 function critere_POUR_tableau_dist($idb, &$boucles, $crit) {
2868
-	$boucle = &$boucles[$idb];
2869
-	$boucle->hash .= '
2868
+    $boucle = &$boucles[$idb];
2869
+    $boucle->hash .= '
2870 2870
 	$command[\'source\'] = array(' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent) . ');
2871 2871
 	$command[\'sourcemode\'] = \'table\';';
2872 2872
 }
@@ -2887,29 +2887,29 @@  discard block
 block discarded – undo
2887 2887
  */
2888 2888
 function critere_noeud_dist($idb, &$boucles, $crit) {
2889 2889
 
2890
-	$not = $crit->not;
2891
-	$boucle = &$boucles[$idb];
2892
-	$primary = $boucle->primary;
2890
+    $not = $crit->not;
2891
+    $boucle = &$boucles[$idb];
2892
+    $primary = $boucle->primary;
2893 2893
 
2894
-	if (!$primary or strpos($primary, ',')) {
2895
-		erreur_squelette(_T('zbug_doublon_sur_table_sans_cle_primaire'), $boucle);
2894
+    if (!$primary or strpos($primary, ',')) {
2895
+        erreur_squelette(_T('zbug_doublon_sur_table_sans_cle_primaire'), $boucle);
2896 2896
 
2897
-		return;
2898
-	}
2899
-	$table = $boucle->type_requete;
2900
-	$table_sql = table_objet_sql(objet_type($table));
2897
+        return;
2898
+    }
2899
+    $table = $boucle->type_requete;
2900
+    $table_sql = table_objet_sql(objet_type($table));
2901 2901
 
2902
-	$id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
2903
-		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
2904
-		'id_parent';
2902
+    $id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
2903
+        $GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
2904
+        'id_parent';
2905 2905
 
2906
-	$in = "IN";
2907
-	$where = array("'IN'", "'$boucle->id_table." . "$primary'", "'('.sql_get_select('$id_parent', '$table_sql').')'");
2908
-	if ($not) {
2909
-		$where = array("'NOT'", $where);
2910
-	}
2906
+    $in = "IN";
2907
+    $where = array("'IN'", "'$boucle->id_table." . "$primary'", "'('.sql_get_select('$id_parent', '$table_sql').')'");
2908
+    if ($not) {
2909
+        $where = array("'NOT'", $where);
2910
+    }
2911 2911
 
2912
-	$boucle->where[] = $where;
2912
+    $boucle->where[] = $where;
2913 2913
 }
2914 2914
 
2915 2915
 /**
@@ -2925,8 +2925,8 @@  discard block
 block discarded – undo
2925 2925
  * @param Critere $crit Paramètres du critère dans cette boucle
2926 2926
  */
2927 2927
 function critere_feuille_dist($idb, &$boucles, $crit) {
2928
-	$not = $crit->not;
2929
-	$crit->not = $not ? false : true;
2930
-	critere_noeud_dist($idb, $boucles, $crit);
2931
-	$crit->not = $not;
2928
+    $not = $crit->not;
2929
+    $crit->not = $not ? false : true;
2930
+    critere_noeud_dist($idb, $boucles, $crit);
2931
+    $crit->not = $not;
2932 2932
 }
Please login to merge, or discard this patch.
Spacing   +176 added lines, -184 removed lines patch added patch discarded remove patch
@@ -46,10 +46,9 @@  discard block
 block discarded – undo
46 46
 	$not = $crit->not;
47 47
 	$boucle = &$boucles[$idb];
48 48
 	$id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
49
-		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
50
-		'id_parent';
49
+		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] : 'id_parent';
51 50
 
52
-	$c = array("'='", "'$boucle->id_table." . "$id_parent'", 0);
51
+	$c = array("'='", "'$boucle->id_table."."$id_parent'", 0);
53 52
 	$boucle->where[] = ($crit->not ? array("'NOT'", $c) : $c);
54 53
 }
55 54
 
@@ -72,10 +71,10 @@  discard block
 block discarded – undo
72 71
 	$id = $boucle->primary;
73 72
 
74 73
 	if ($not or !$id) {
75
-		return (array('zbug_critere_inconnu', array('critere' => $not . $crit->op)));
74
+		return (array('zbug_critere_inconnu', array('critere' => $not.$crit->op)));
76 75
 	}
77 76
 	$arg = kwote(calculer_argument_precedent($idb, $id, $boucles));
78
-	$boucle->where[] = array("'!='", "'$boucle->id_table." . "$id'", $arg);
77
+	$boucle->where[] = array("'!='", "'$boucle->id_table."."$id'", $arg);
79 78
 }
80 79
 
81 80
 
@@ -106,12 +105,12 @@  discard block
 block discarded – undo
106 105
 	$not = ($crit->not ? '' : 'NOT');
107 106
 
108 107
 	// le doublon s'applique sur un type de boucle (article)
109
-	$nom = "'" . $boucle->type_requete . "'";
108
+	$nom = "'".$boucle->type_requete."'";
110 109
 
111 110
 	// compléter le nom avec un nom précisé {doublons nom}
112 111
 	// on obtient $nom = "'article' . 'nom'"
113 112
 	if (isset($crit->param[0])) {
114
-		$nom .= "." . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
113
+		$nom .= ".".calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent);
115 114
 	}
116 115
 
117 116
 	// code qui déclarera l'index du stockage de nos doublons (pour éviter une notice PHP)
@@ -123,13 +122,13 @@  discard block
 block discarded – undo
123 122
 	// $doublons et son index, ici $nom
124 123
 
125 124
 	// debut du code "sql_in('articles.id_article', "
126
-	$debut_in = "sql_in('" . $boucle->id_table . '.' . $primary . "', ";
125
+	$debut_in = "sql_in('".$boucle->id_table.'.'.$primary."', ";
127 126
 	// lecture des données du doublon "$doublons[$doublon_index[] = "
128 127
 	// Attention : boucle->doublons désigne une variable qu'on affecte
129
-	$debut_doub = '$doublons[' . (!$not ? '' : ($boucle->doublons . "[]= "));
128
+	$debut_doub = '$doublons['.(!$not ? '' : ($boucle->doublons."[]= "));
130 129
 
131 130
 	// le debut complet du code des doublons
132
-	$debut_doub = $debut_in . $debut_doub;
131
+	$debut_doub = $debut_in.$debut_doub;
133 132
 
134 133
 	// nom du doublon "('article' . 'nom')]"
135 134
 	$fin_doub = "($nom)]";
@@ -139,22 +138,22 @@  discard block
 block discarded – undo
139 138
 	foreach ($boucle->where as $k => $w) {
140 139
 		if (strpos($w[0], $debut_doub) === 0) {
141 140
 			// fusionner le sql_in (du where)
142
-			$boucle->where[$k][0] = $debut_doub . $fin_doub . ' . ' . substr($w[0], strlen($debut_in));
141
+			$boucle->where[$k][0] = $debut_doub.$fin_doub.' . '.substr($w[0], strlen($debut_in));
143 142
 			// fusionner l'initialisation (du hash) pour faire plus joli
144 143
 			$x = strpos($boucle->hash, $init_comment);
145 144
 			$len = strlen($init_comment);
146 145
 			$boucle->hash =
147
-				substr($boucle->hash, 0, $x + $len) . $init_code . substr($boucle->hash, $x + $len);
146
+				substr($boucle->hash, 0, $x + $len).$init_code.substr($boucle->hash, $x + $len);
148 147
 
149 148
 			return;
150 149
 		}
151 150
 	}
152 151
 
153 152
 	// mettre l'ensemble dans un tableau pour que ce ne soit pas vu comme une constante
154
-	$boucle->where[] = array($debut_doub . $fin_doub . ", '" . $not . "')");
153
+	$boucle->where[] = array($debut_doub.$fin_doub.", '".$not."')");
155 154
 
156 155
 	// déclarer le doublon s'il n'existe pas encore
157
-	$boucle->hash .= $init_comment . $init_code;
156
+	$boucle->hash .= $init_comment.$init_code;
158 157
 
159 158
 
160 159
 	# la ligne suivante avait l'intention d'eviter une collecte deja faite
@@ -215,10 +214,10 @@  discard block
 block discarded – undo
215 214
 	$un = $un[0]->texte;
216 215
 	$deux = $deux[0]->texte;
217 216
 	if ($deux) {
218
-		$boucles[$idb]->limit = 'intval($Pile[0]["debut' .
219
-			$un .
220
-			'"]) . ",' .
221
-			$deux .
217
+		$boucles[$idb]->limit = 'intval($Pile[0]["debut'.
218
+			$un.
219
+			'"]) . ",'.
220
+			$deux.
222 221
 			'"';
223 222
 	} else {
224 223
 		calculer_critere_DEFAUT_dist($idb, $boucles, $crit);
@@ -281,26 +280,26 @@  discard block
 block discarded – undo
281 280
 		$type = calculer_liste(array($crit->param[1][0]), array(), $boucles, $boucle->id_parent);
282 281
 	}
283 282
 
284
-	$debut = ($type[0] !== "'") ? "'debut'.$type" : ("'debut" . substr($type, 1));
283
+	$debut = ($type[0] !== "'") ? "'debut'.$type" : ("'debut".substr($type, 1));
285 284
 	$boucle->modificateur['debut_nom'] = $type;
286 285
 	$partie =
287 286
 		// tester si le numero de page demande est de la forme '@yyy'
288
-		'isset($Pile[0][' . $debut . ']) ? $Pile[0][' . $debut . '] : _request(' . $debut . ");\n"
287
+		'isset($Pile[0]['.$debut.']) ? $Pile[0]['.$debut.'] : _request('.$debut.");\n"
289 288
 		. "\tif(substr(\$debut_boucle,0,1)=='@'){\n"
290
-		. "\t\t" . '$debut_boucle = $Pile[0][' . $debut . '] = quete_debut_pagination(\'' . $boucle->primary . '\',$Pile[0][\'@' . $boucle->primary . '\'] = substr($debut_boucle,1),' . $pas . ',$iter);' . "\n"
291
-		. "\t\t" . '$iter->seek(0);' . "\n"
289
+		. "\t\t".'$debut_boucle = $Pile[0]['.$debut.'] = quete_debut_pagination(\''.$boucle->primary.'\',$Pile[0][\'@'.$boucle->primary.'\'] = substr($debut_boucle,1),'.$pas.',$iter);'."\n"
290
+		. "\t\t".'$iter->seek(0);'."\n"
292 291
 		. "\t}\n"
293
-		. "\t" . '$debut_boucle = intval($debut_boucle)';
292
+		. "\t".'$debut_boucle = intval($debut_boucle)';
294 293
 
295 294
 	$boucle->hash .= '
296
-	$command[\'pagination\'] = array((isset($Pile[0][' . $debut . ']) ? $Pile[0][' . $debut . '] : null), ' . $pas . ');';
295
+	$command[\'pagination\'] = array((isset($Pile[0][' . $debut.']) ? $Pile[0]['.$debut.'] : null), '.$pas.');';
297 296
 
298 297
 	$boucle->total_parties = $pas;
299 298
 	calculer_parties($boucles, $idb, $partie, 'p+');
300 299
 	// ajouter la cle primaire dans le select pour pouvoir gerer la pagination referencee par @id
301 300
 	// sauf si pas de primaire, ou si primaire composee
302 301
 	// dans ce cas, on ne sait pas gerer une pagination indirecte
303
-	$t = $boucle->id_table . '.' . $boucle->primary;
302
+	$t = $boucle->id_table.'.'.$boucle->primary;
304 303
 	if ($boucle->primary
305 304
 		and !preg_match('/[,\s]/', $boucle->primary)
306 305
 		and !in_array($t, $boucle->select)
@@ -346,24 +345,24 @@  discard block
 block discarded – undo
346 345
 	$boucle->hash .= '
347 346
 	// RECHERCHE'
348 347
 		. ($crit->cond ? '
349
-	if (!strlen(' . $quoi . ')){
348
+	if (!strlen(' . $quoi.')){
350 349
 		list($rech_select, $rech_where) = array("0 as points","");
351
-	} else' : '') . '
350
+	} else' : '').'
352 351
 	{
353 352
 		$prepare_recherche = charger_fonction(\'prepare_recherche\', \'inc\');
354
-		list($rech_select, $rech_where) = $prepare_recherche(' . $quoi . ', "' . $boucle->id_table . '", "' . $crit->cond . '","' . $boucle->sql_serveur . '",' . $_modificateur . ',"' . $boucle->primary . '");
353
+		list($rech_select, $rech_where) = $prepare_recherche(' . $quoi.', "'.$boucle->id_table.'", "'.$crit->cond.'","'.$boucle->sql_serveur.'",'.$_modificateur.',"'.$boucle->primary.'");
355 354
 	}
356 355
 	';
357 356
 
358 357
 
359
-	$t = $boucle->id_table . '.' . $boucle->primary;
358
+	$t = $boucle->id_table.'.'.$boucle->primary;
360 359
 	if (!in_array($t, $boucles[$idb]->select)) {
361 360
 		$boucle->select[] = $t;
362 361
 	} # pour postgres, neuneu ici
363 362
 	// jointure uniquement sur le serveur principal
364 363
 	// (on ne peut joindre une table d'un serveur distant avec la table des resultats du serveur principal)
365 364
 	if (!$boucle->sql_serveur) {
366
-		$boucle->join['resultats'] = array("'" . $boucle->id_table . "'", "'id'", "'" . $boucle->primary . "'");
365
+		$boucle->join['resultats'] = array("'".$boucle->id_table."'", "'id'", "'".$boucle->primary."'");
367 366
 		$boucle->from['resultats'] = 'spip_resultats';
368 367
 	}
369 368
 	$boucle->select[] = '$rech_select';
@@ -430,7 +429,7 @@  discard block
 block discarded – undo
430 429
 	$c =
431 430
 		array(
432 431
 			"'OR'",
433
-			array("'='", "'$table." . "id_trad'", "'$table.$prim'"),
432
+			array("'='", "'$table."."id_trad'", "'$table.$prim'"),
434 433
 			array("'='", "'$table.id_trad'", "'0'")
435 434
 		);
436 435
 	$boucle->where[] = ($crit->not ? array("'NOT'", $c) : $c);
@@ -453,16 +452,15 @@  discard block
 block discarded – undo
453 452
 	$boucle = &$boucles[$idb];
454 453
 	$arg = kwote(calculer_argument_precedent($idb, 'id_parent', $boucles));
455 454
 	$id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
456
-		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
457
-		'id_parent';
458
-	$mparent = $boucle->id_table . '.' . $id_parent;
455
+		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] : 'id_parent';
456
+	$mparent = $boucle->id_table.'.'.$id_parent;
459 457
 
460 458
 	if ($boucle->type_requete == 'rubriques' or isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'])) {
461 459
 		$boucle->where[] = array("'='", "'$mparent'", $arg);
462 460
 
463 461
 	} // le cas FORUMS est gere dans le plugin forum, dans la fonction critere_FORUMS_meme_parent_dist()
464 462
 	else {
465
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op . ' ' . $boucle->type_requete)));
463
+		return (array('zbug_critere_inconnu', array('critere' => $crit->op.' '.$boucle->type_requete)));
466 464
 	}
467 465
 }
468 466
 
@@ -515,16 +513,15 @@  discard block
 block discarded – undo
515 513
 		if (count(trouver_champs_decomposes($champ, $desc)) > 1) {
516 514
 			$decompose = decompose_champ_id_objet($champ);
517 515
 			$champ = array_shift($decompose);
518
-			$boucle->where[] = array("'='", _q($cle . "." . reset($decompose)), '"' . sql_quote(end($decompose)) . '"');
516
+			$boucle->where[] = array("'='", _q($cle.".".reset($decompose)), '"'.sql_quote(end($decompose)).'"');
519 517
 		}
520 518
 	} else {
521 519
 		$cle = $boucle->id_table;
522 520
 	}
523 521
 
524
-	$c = "sql_in('$cle" . ".$champ', calcul_branche_in($arg)"
525
-		. ($not ? ", 'NOT'" : '') . ")";
526
-	$boucle->where[] = !$crit->cond ? $c :
527
-		("($arg ? $c : " . ($not ? "'0=1'" : "'1=1'") . ')');
522
+	$c = "sql_in('$cle".".$champ', calcul_branche_in($arg)"
523
+		. ($not ? ", 'NOT'" : '').")";
524
+	$boucle->where[] = !$crit->cond ? $c : ("($arg ? $c : ".($not ? "'0=1'" : "'1=1'").')');
528 525
 }
529 526
 
530 527
 /**
@@ -543,9 +540,9 @@  discard block
 block discarded – undo
543 540
 	$not = $crit->not;
544 541
 	$boucle = &$boucles[$idb];
545 542
 
546
-	$c = "sql_in('" .
547
-		$boucle->id_table . '.' . $boucle->primary
548
-		. "', lister_objets_avec_logos('" . $boucle->primary . "'), '')";
543
+	$c = "sql_in('".
544
+		$boucle->id_table.'.'.$boucle->primary
545
+		. "', lister_objets_avec_logos('".$boucle->primary."'), '')";
549 546
 
550 547
 	if ($crit->cond) {
551 548
 		$c = "($arg ? $c : 1)";
@@ -585,7 +582,7 @@  discard block
 block discarded – undo
585 582
 				$t = table_objet_sql($r[1]);
586 583
 				$t = array_search($t, $boucles[$idb]->from);
587 584
 				if ($t) {
588
-					$t .= '.' . $r[2];
585
+					$t .= '.'.$r[2];
589 586
 				}
590 587
 			}
591 588
 		} else {
@@ -600,7 +597,7 @@  discard block
 block discarded – undo
600 597
 			$boucles[$idb]->select[] = $t;
601 598
 		}
602 599
 	} else {
603
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op . ' ?')));
600
+		return (array('zbug_critere_inconnu', array('critere' => $crit->op.' ?')));
604 601
 	}
605 602
 }
606 603
 
@@ -650,26 +647,26 @@  discard block
 block discarded – undo
650 647
 				(false !== $i = strpos($boucle->order[$n - 1], 'ASC'))
651 648
 				OR (false !== $i = strpos($boucle->order[$n - 1], 'DESC'))
652 649
 			) {
653
-				$boucle->order[$n - 1] = substr_replace($boucle->order[$n - 1], "' . " . $boucle->modificateur['collate'] . " . ' ", $i, 0);
650
+				$boucle->order[$n - 1] = substr_replace($boucle->order[$n - 1], "' . ".$boucle->modificateur['collate']." . ' ", $i, 0);
654 651
 			} else {
655
-				$boucle->order[$n - 1] .= " . " . $boucle->modificateur['collate'];
652
+				$boucle->order[$n - 1] .= " . ".$boucle->modificateur['collate'];
656 653
 			}
657 654
 		}
658 655
 	} else {
659
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op . " " . count($boucles[$idb]->order))));
656
+		return (array('zbug_critere_inconnu', array('critere' => $crit->op." ".count($boucles[$idb]->order))));
660 657
 	}
661 658
 }
662 659
 
663 660
 // http://code.spip.net/@calculer_critere_arg_dynamique
664 661
 function calculer_critere_arg_dynamique($idb, &$boucles, $crit, $suffix = '') {
665 662
 	$boucle = $boucles[$idb];
666
-	$alt = "('" . $boucle->id_table . '.\' . $x' . $suffix . ')';
667
-	$var = '$champs_' . $idb;
663
+	$alt = "('".$boucle->id_table.'.\' . $x'.$suffix.')';
664
+	$var = '$champs_'.$idb;
668 665
 	$desc = (strpos($boucle->in, "static $var =") !== false);
669 666
 	if (!$desc) {
670 667
 		$desc = $boucle->show['field'];
671 668
 		$desc = implode(',', array_map('_q', array_keys($desc)));
672
-		$boucles[$idb]->in .= "\n\tstatic $var = array(" . $desc . ");";
669
+		$boucles[$idb]->in .= "\n\tstatic $var = array(".$desc.");";
673 670
 	}
674 671
 	if ($desc) {
675 672
 		$alt = "(in_array(\$x, $var)  ? $alt :(\$x$suffix))";
@@ -744,7 +741,7 @@  discard block
 block discarded – undo
744 741
 		$sens = " . ' DESC'";
745 742
 	}
746 743
 	if (isset($boucle->modificateur['collate'])) {
747
-		$collecte = ' . ' . $boucle->modificateur['collate'];
744
+		$collecte = ' . '.$boucle->modificateur['collate'];
748 745
 	}
749 746
 
750 747
 	// Pour chaque paramètre du critère
@@ -766,14 +763,14 @@  discard block
 block discarded – undo
766 763
 			if (preg_match(",^(\w+)[\s]+(.*)$,", $par, $m)) {
767 764
 				$expression = trim($m[1]);
768 765
 				$champ = trim($m[2]);
769
-				if (function_exists($f = 'calculer_critere_par_expression_' . $expression)) {
766
+				if (function_exists($f = 'calculer_critere_par_expression_'.$expression)) {
770 767
 					$order = $f($idb, $boucles, $crit, $tri, $champ);
771 768
 				} else {
772
-					return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
769
+					return array('zbug_critere_inconnu', array('critere' => $crit->op." $par"));
773 770
 				}
774 771
 
775 772
 			// tris de la forme {par champ} ou {par FONCTION(champ)}
776
-			} elseif (preg_match(",^" . CHAMP_SQL_PLUS_FONC . '$,is', $par, $match)) {
773
+			} elseif (preg_match(",^".CHAMP_SQL_PLUS_FONC.'$,is', $par, $match)) {
777 774
 				// {par FONCTION(champ)}
778 775
 				if (count($match) > 2) {
779 776
 					$par = substr($match[2], 1, -1);
@@ -783,7 +780,7 @@  discard block
 block discarded – undo
783 780
 				if ($par == 'hasard') {
784 781
 					$order = calculer_critere_par_hasard($idb, $boucles, $crit);
785 782
 				} elseif ($par == 'date' and !empty($boucle->show['date'])) {
786
-					$order = "'" . $boucle->id_table . "." . $boucle->show['date'] . "'";
783
+					$order = "'".$boucle->id_table.".".$boucle->show['date']."'";
787 784
 				} else {
788 785
 					// cas général {par champ}, {par table.champ}, ...
789 786
 					$order = calculer_critere_par_champ($idb, $boucles, $crit, $par);
@@ -792,7 +789,7 @@  discard block
 block discarded – undo
792 789
 
793 790
 			// on ne sait pas traiter…
794 791
 			else {
795
-				return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
792
+				return array('zbug_critere_inconnu', array('critere' => $crit->op." $par"));
796 793
 			}
797 794
 
798 795
 			// En cas d'erreur de squelette retournée par une fonction
@@ -812,14 +809,14 @@  discard block
 block discarded – undo
812 809
 
813 810
 		if ($fct) {
814 811
 			if (preg_match("/^\s*'(.*)'\s*$/", $order, $r)) {
815
-				$order = "'$fct(" . $r[1] . ")'";
812
+				$order = "'$fct(".$r[1].")'";
816 813
 			} else {
817 814
 				$order = "'$fct(' . $order . ')'";
818 815
 			}
819 816
 		}
820
-		$t = $order . $collecte . $sens;
817
+		$t = $order.$collecte.$sens;
821 818
 		if (preg_match("/^(.*)'\s*\.\s*'([^']*')$/", $t, $r)) {
822
-			$t = $r[1] . $r[2];
819
+			$t = $r[1].$r[2];
823 820
 		}
824 821
 
825 822
 		$boucle->order[] = $t;
@@ -869,16 +866,16 @@  discard block
 block discarded – undo
869 866
 function calculer_critere_par_expression_num($idb, &$boucles, $crit, $tri, $champ) {
870 867
 	$_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
871 868
 	if (is_array($_champ)) {
872
-		return array('zbug_critere_inconnu', array('critere' => $crit->op . " num $champ"));
869
+		return array('zbug_critere_inconnu', array('critere' => $crit->op." num $champ"));
873 870
 	}
874 871
 	$boucle = &$boucles[$idb];
875
-	$texte = '0+' . $_champ;
872
+	$texte = '0+'.$_champ;
876 873
 	$suite = calculer_liste($tri, array(), $boucles, $boucle->id_parent);
877 874
 	if ($suite !== "''") {
878
-		$texte = "\" . ((\$x = $suite) ? ('$texte' . \$x) : '0')" . " . \"";
875
+		$texte = "\" . ((\$x = $suite) ? ('$texte' . \$x) : '0')"." . \"";
879 876
 	}
880
-	$as = 'num' . ($boucle->order ? count($boucle->order) : "");
881
-	$boucle->select[] = $texte . " AS $as";
877
+	$as = 'num'.($boucle->order ? count($boucle->order) : "");
878
+	$boucle->select[] = $texte." AS $as";
882 879
 	$order = "'$as'";
883 880
 	return $order;
884 881
 }
@@ -903,16 +900,16 @@  discard block
 block discarded – undo
903 900
 function calculer_critere_par_expression_sinum($idb, &$boucles, $crit, $tri, $champ) {
904 901
 	$_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
905 902
 	if (is_array($_champ)) {
906
-		return array('zbug_critere_inconnu', array('critere' => $crit->op . " sinum $champ"));
903
+		return array('zbug_critere_inconnu', array('critere' => $crit->op." sinum $champ"));
907 904
 	}
908 905
 	$boucle = &$boucles[$idb];
909
-	$texte = '0+' . $_champ;
906
+	$texte = '0+'.$_champ;
910 907
 	$suite = calculer_liste($tri, array(), $boucles, $boucle->id_parent);
911 908
 	if ($suite !== "''") {
912
-		$texte = "\" . ((\$x = $suite) ? ('$texte' . \$x) : '0')" . " . \"";
909
+		$texte = "\" . ((\$x = $suite) ? ('$texte' . \$x) : '0')"." . \"";
913 910
 	}
914
-	$as = 'sinum' . ($boucle->order ? count($boucle->order) : "");
915
-	$boucle->select[] = 'CASE (' . $texte . ') WHEN 0 THEN 1 ELSE 0 END AS ' . $as;
911
+	$as = 'sinum'.($boucle->order ? count($boucle->order) : "");
912
+	$boucle->select[] = 'CASE ('.$texte.') WHEN 0 THEN 1 ELSE 0 END AS '.$as;
916 913
 	$order = "'$as'";
917 914
 	return $order;
918 915
 }
@@ -936,10 +933,10 @@  discard block
 block discarded – undo
936 933
 function calculer_critere_par_expression_multi($idb, &$boucles, $crit, $tri, $champ) {
937 934
 	$_champ = calculer_critere_par_champ($idb, $boucles, $crit, $champ, true);
938 935
 	if (is_array($_champ)) {
939
-		return array('zbug_critere_inconnu', array('critere' => $crit->op . " multi $champ"));
936
+		return array('zbug_critere_inconnu', array('critere' => $crit->op." multi $champ"));
940 937
 	}
941 938
 	$boucle = &$boucles[$idb];
942
-	$boucle->select[] = "\".sql_multi('" . $_champ . "', \$GLOBALS['spip_lang']).\"";
939
+	$boucle->select[] = "\".sql_multi('".$_champ."', \$GLOBALS['spip_lang']).\"";
943 940
 	$order = "'multi'";
944 941
 	return $order;
945 942
 }
@@ -959,13 +956,13 @@  discard block
 block discarded – undo
959 956
  * @param bool $raw Retourne le champ pour le compilateur ("'alias.champ'") ou brut ('alias.champ')
960 957
  * @return array|string
961 958
  */
962
-function calculer_critere_par_champ($idb, &$boucles, $crit,  $par, $raw = false) {
959
+function calculer_critere_par_champ($idb, &$boucles, $crit, $par, $raw = false) {
963 960
 	$boucle = &$boucles[$idb];
964 961
 	$desc = $boucle->show;
965 962
 
966 963
 	// le champ existe dans la table, pas de souci (le plus commun)
967 964
 	if (isset($desc['field'][$par])) {
968
-		$par = $boucle->id_table . "." . $par;
965
+		$par = $boucle->id_table.".".$par;
969 966
 	}
970 967
 	// le champ est peut être une jointure
971 968
 	else {
@@ -986,24 +983,24 @@  discard block
 block discarded – undo
986 983
 		// Sinon on cherche le champ dans les tables possibles de jointures
987 984
 		// Si la table est déjà dans le from, on la réutilise.
988 985
 		if ($infos = chercher_champ_dans_tables($champ, $boucle->from, $boucle->sql_serveur, $table)) {
989
-			$par = $infos['alias'] . "." . $champ;
986
+			$par = $infos['alias'].".".$champ;
990 987
 		} elseif (
991 988
 			$boucle->jointures_explicites
992 989
 			and $alias = trouver_jointure_champ($champ, $boucle, explode(' ', $boucle->jointures_explicites), false, $table)
993 990
 		) {
994
-			$par = $alias . "." . $champ;
991
+			$par = $alias.".".$champ;
995 992
 		} elseif ($alias = trouver_jointure_champ($champ, $boucle, $boucle->jointures, false, $table)) {
996
-			$par = $alias . "." . $champ;
993
+			$par = $alias.".".$champ;
997 994
 		// en spécifiant directement l'alias {par L2.titre} (situation hasardeuse tout de même)
998 995
 		} elseif (
999 996
 			$table_alias
1000 997
 			and isset($boucle->from[$table_alias])
1001 998
 			and $infos = chercher_champ_dans_tables($champ, $boucle->from, $boucle->sql_serveur, $boucle->from[$table_alias])
1002 999
 		) {
1003
-			$par = $infos['alias'] . "." . $champ;
1000
+			$par = $infos['alias'].".".$champ;
1004 1001
 		} elseif ($table) {
1005 1002
 			// On avait table + champ, mais on ne les a pas trouvés
1006
-			return array('zbug_critere_inconnu', array('critere' => $crit->op . " $par"));
1003
+			return array('zbug_critere_inconnu', array('critere' => $crit->op." $par"));
1007 1004
 		} else {
1008 1005
 			// Sinon tant pis, ca doit etre un champ synthetise (cf points)
1009 1006
 		}
@@ -1027,7 +1024,7 @@  discard block
 block discarded – undo
1027 1024
 	if (!$t) {
1028 1025
 		$t = trouver_jointure_champ($champ, $boucle);
1029 1026
 	}
1030
-	return !$t ? '' : ("'" . $t . '.' . $champ . "'");
1027
+	return !$t ? '' : ("'".$t.'.'.$champ."'");
1031 1028
 }
1032 1029
 
1033 1030
 /**
@@ -1072,9 +1069,9 @@  discard block
 block discarded – undo
1072 1069
 				$boucle->default_order[] = ' DESC';
1073 1070
 			}
1074 1071
 		} else {
1075
-			$t = $boucle->order[$n - 1] . " . $order";
1072
+			$t = $boucle->order[$n - 1]." . $order";
1076 1073
 			if (preg_match("/^(.*)'\s*\.\s*'([^']*')$/", $t, $r)) {
1077
-				$t = $r[1] . $r[2];
1074
+				$t = $r[1].$r[2];
1078 1075
 			}
1079 1076
 			$boucle->order[$n - 1] = $t;
1080 1077
 		}
@@ -1086,7 +1083,7 @@  discard block
 block discarded – undo
1086 1083
 	$params = $crit->param;
1087 1084
 
1088 1085
 	if (count($params) < 1) {
1089
-		return array('zbug_critere_inconnu', array('critere' => $crit->op . " ?"));
1086
+		return array('zbug_critere_inconnu', array('critere' => $crit->op." ?"));
1090 1087
 	}
1091 1088
 
1092 1089
 	$boucle = &$boucles[$idb];
@@ -1107,7 +1104,7 @@  discard block
 block discarded – undo
1107 1104
 	if ((count($date) == 1) and ($date[0]->type == 'texte')) {
1108 1105
 		$date = $date[0]->texte;
1109 1106
 		if (!isset($fields[$date])) {
1110
-			return array('zbug_critere_inconnu', array('critere' => $crit->op . " " . $date));
1107
+			return array('zbug_critere_inconnu', array('critere' => $crit->op." ".$date));
1111 1108
 		}
1112 1109
 	} else {
1113 1110
 		$a = calculer_liste($date, array(), $boucles, $parent);
@@ -1119,38 +1116,38 @@  discard block
 block discarded – undo
1119 1116
 		$date = "'.(($cond)\n?\$a:\"$defaut\").'";
1120 1117
 	}
1121 1118
 	$annee = $params ? array_shift($params) : "";
1122
-	$annee = "\n" . 'sprintf("%04d", ($x = ' .
1123
-		calculer_liste($annee, array(), $boucles, $parent) .
1119
+	$annee = "\n".'sprintf("%04d", ($x = '.
1120
+		calculer_liste($annee, array(), $boucles, $parent).
1124 1121
 		') ? $x : date("Y"))';
1125 1122
 
1126 1123
 	$mois = $params ? array_shift($params) : "";
1127
-	$mois = "\n" . 'sprintf("%02d", ($x = ' .
1128
-		calculer_liste($mois, array(), $boucles, $parent) .
1124
+	$mois = "\n".'sprintf("%02d", ($x = '.
1125
+		calculer_liste($mois, array(), $boucles, $parent).
1129 1126
 		') ? $x : date("m"))';
1130 1127
 
1131 1128
 	$jour = $params ? array_shift($params) : "";
1132
-	$jour = "\n" . 'sprintf("%02d", ($x = ' .
1133
-		calculer_liste($jour, array(), $boucles, $parent) .
1129
+	$jour = "\n".'sprintf("%02d", ($x = '.
1130
+		calculer_liste($jour, array(), $boucles, $parent).
1134 1131
 		') ? $x : date("d"))';
1135 1132
 
1136 1133
 	$annee2 = $params ? array_shift($params) : "";
1137
-	$annee2 = "\n" . 'sprintf("%04d", ($x = ' .
1138
-		calculer_liste($annee2, array(), $boucles, $parent) .
1134
+	$annee2 = "\n".'sprintf("%04d", ($x = '.
1135
+		calculer_liste($annee2, array(), $boucles, $parent).
1139 1136
 		') ? $x : date("Y"))';
1140 1137
 
1141 1138
 	$mois2 = $params ? array_shift($params) : "";
1142
-	$mois2 = "\n" . 'sprintf("%02d", ($x = ' .
1143
-		calculer_liste($mois2, array(), $boucles, $parent) .
1139
+	$mois2 = "\n".'sprintf("%02d", ($x = '.
1140
+		calculer_liste($mois2, array(), $boucles, $parent).
1144 1141
 		') ? $x : date("m"))';
1145 1142
 
1146 1143
 	$jour2 = $params ? array_shift($params) : "";
1147
-	$jour2 = "\n" . 'sprintf("%02d", ($x = ' .
1148
-		calculer_liste($jour2, array(), $boucles, $parent) .
1144
+	$jour2 = "\n".'sprintf("%02d", ($x = '.
1145
+		calculer_liste($jour2, array(), $boucles, $parent).
1149 1146
 		') ? $x : date("d"))';
1150 1147
 
1151
-	$date = $boucle->id_table . ".$date";
1148
+	$date = $boucle->id_table.".$date";
1152 1149
 
1153
-	$quote_end = ",'" . $boucle->sql_serveur . "','text'";
1150
+	$quote_end = ",'".$boucle->sql_serveur."','text'";
1154 1151
 	if ($type == 'jour') {
1155 1152
 		$boucle->where[] = array(
1156 1153
 			"'='",
@@ -1222,14 +1219,13 @@  discard block
 block discarded – undo
1222 1219
 	list($a21, $a22) = calculer_critere_parties_aux($idb, $boucles, $a2);
1223 1220
 
1224 1221
 	if (($op == ',') && (is_numeric($a11) && (is_numeric($a21)))) {
1225
-		$boucle->limit = $a11 . ',' . $a21;
1222
+		$boucle->limit = $a11.','.$a21;
1226 1223
 	} else {
1227 1224
 		// 3 dans {1/3}, {2,3} ou {1,n-3}
1228 1225
 		$boucle->total_parties = ($a21 != 'n') ? $a21 : $a22;
1229 1226
 		// 2 dans {2/3}, {2,5}, {n-2,1}
1230 1227
 		$partie = ($a11 != 'n') ? $a11 : $a12;
1231
-		$mode = (($op == '/') ? '/' :
1232
-			(($a11 == 'n') ? '-' : '+') . (($a21 == 'n') ? '-' : '+'));
1228
+		$mode = (($op == '/') ? '/' : (($a11 == 'n') ? '-' : '+').(($a21 == 'n') ? '-' : '+'));
1233 1229
 		// cas simple {0,#ENV{truc}} compilons le en LIMIT :
1234 1230
 		if ($a11 !== 'n' and $a21 !== 'n' and $mode == "++" and $op == ',') {
1235 1231
 			$boucle->limit =
@@ -1275,8 +1271,7 @@  discard block
 block discarded – undo
1275 1271
 	// {1/3}
1276 1272
 	if ($op1 == '/') {
1277 1273
 		$pmoins1 = is_numeric($debut) ? ($debut - 1) : "($debut-1)";
1278
-		$totpos = is_numeric($total_parties) ? ($total_parties) :
1279
-			"($total_parties ? $total_parties : 1)";
1274
+		$totpos = is_numeric($total_parties) ? ($total_parties) : "($total_parties ? $total_parties : 1)";
1280 1275
 		$fin = "ceil(($nombre_boucle * $debut )/$totpos) - 1";
1281 1276
 		$debut = !$pmoins1 ? 0 : "ceil(($nombre_boucle * $pmoins1)/$totpos);";
1282 1277
 	} else {
@@ -1287,15 +1282,13 @@  discard block
 block discarded – undo
1287 1282
 
1288 1283
 		// cas {x,n-1}
1289 1284
 		if ($op2 == '-') {
1290
-			$fin = '$debut_boucle + ' . $nombre_boucle . ' - '
1291
-				. (is_numeric($total_parties) ? ($total_parties + 1) :
1292
-					($total_parties . ' - 1'));
1285
+			$fin = '$debut_boucle + '.$nombre_boucle.' - '
1286
+				. (is_numeric($total_parties) ? ($total_parties + 1) : ($total_parties.' - 1'));
1293 1287
 		} else {
1294 1288
 			// {x,1} ou {pagination}
1295 1289
 			$fin = '$debut_boucle'
1296 1290
 				. (is_numeric($total_parties) ?
1297
-					(($total_parties == 1) ? "" : (' + ' . ($total_parties - 1))) :
1298
-					('+' . $total_parties . ' - 1'));
1291
+					(($total_parties == 1) ? "" : (' + '.($total_parties - 1))) : ('+'.$total_parties.' - 1'));
1299 1292
 		}
1300 1293
 
1301 1294
 		// {pagination}, gerer le debut_xx=-1 pour tout voir
@@ -1313,11 +1306,11 @@  discard block
 block discarded – undo
1313 1306
 	// Utiliser min pour rabattre $fin_boucle sur total_boucle.
1314 1307
 
1315 1308
 	$boucles[$id_boucle]->mode_partie = "\n\t"
1316
-		. '$debut_boucle = ' . $debut . ";\n	"
1309
+		. '$debut_boucle = '.$debut.";\n	"
1317 1310
 		. "\$debut_boucle = intval(\$debut_boucle);\n	"
1318
-		. '$fin_boucle = min(' . $fin . ", \$Numrows['$id_boucle']['total'] - 1);\n	"
1319
-		. '$Numrows[\'' . $id_boucle . "']['grand_total'] = \$Numrows['$id_boucle']['total'];\n	"
1320
-		. '$Numrows[\'' . $id_boucle . '\']["total"] = max(0,$fin_boucle - $debut_boucle + 1);'
1311
+		. '$fin_boucle = min('.$fin.", \$Numrows['$id_boucle']['total'] - 1);\n	"
1312
+		. '$Numrows[\''.$id_boucle."']['grand_total'] = \$Numrows['$id_boucle']['total'];\n	"
1313
+		. '$Numrows[\''.$id_boucle.'\']["total"] = max(0,$fin_boucle - $debut_boucle + 1);'
1321 1314
 		. "\n\tif (\$debut_boucle>0"
1322 1315
 		. " AND \$debut_boucle < \$Numrows['$id_boucle']['grand_total']"
1323 1316
 		. " AND \$iter->seek(\$debut_boucle,'continue'))"
@@ -1402,16 +1395,16 @@  discard block
 block discarded – undo
1402 1395
 		// critere personnalise ?
1403 1396
 		if (
1404 1397
 			(!$serveur or
1405
-				((!function_exists($f = "critere_" . $serveur . "_" . $table . "_" . $critere))
1406
-					and (!function_exists($f = $f . "_dist"))
1407
-					and (!function_exists($f = "critere_" . $serveur . "_" . $critere))
1408
-					and (!function_exists($f = $f . "_dist"))
1398
+				((!function_exists($f = "critere_".$serveur."_".$table."_".$critere))
1399
+					and (!function_exists($f = $f."_dist"))
1400
+					and (!function_exists($f = "critere_".$serveur."_".$critere))
1401
+					and (!function_exists($f = $f."_dist"))
1409 1402
 				)
1410 1403
 			)
1411
-			and (!function_exists($f = "critere_" . $table . "_" . $critere))
1412
-			and (!function_exists($f = $f . "_dist"))
1413
-			and (!function_exists($f = "critere_" . $critere))
1414
-			and (!function_exists($f = $f . "_dist"))
1404
+			and (!function_exists($f = "critere_".$table."_".$critere))
1405
+			and (!function_exists($f = $f."_dist"))
1406
+			and (!function_exists($f = "critere_".$critere))
1407
+			and (!function_exists($f = $f."_dist"))
1415 1408
 		) {
1416 1409
 			// fonction critere standard
1417 1410
 			$f = $defaut;
@@ -1444,9 +1437,9 @@  discard block
 block discarded – undo
1444 1437
  */
1445 1438
 function kwote($lisp, $serveur = '', $type = '') {
1446 1439
 	if (preg_match(_CODE_QUOTE, $lisp, $r)) {
1447
-		return $r[1] . "\"" . sql_quote(str_replace(array("\\'", "\\\\"), array("'", "\\"), $r[2]), $serveur, $type) . "\"";
1440
+		return $r[1]."\"".sql_quote(str_replace(array("\\'", "\\\\"), array("'", "\\"), $r[2]), $serveur, $type)."\"";
1448 1441
 	} else {
1449
-		return "sql_quote($lisp, '$serveur', '" . str_replace("'", "\\'", $type) . "')";
1442
+		return "sql_quote($lisp, '$serveur', '".str_replace("'", "\\'", $type)."')";
1450 1443
 	}
1451 1444
 }
1452 1445
 
@@ -1468,7 +1461,7 @@  discard block
 block discarded – undo
1468 1461
 function critere_IN_dist($idb, &$boucles, $crit) {
1469 1462
 	$r = calculer_critere_infixe($idb, $boucles, $crit);
1470 1463
 	if (!$r) {
1471
-		return (array('zbug_critere_inconnu', array('critere' => $crit->op . " ?")));
1464
+		return (array('zbug_critere_inconnu', array('critere' => $crit->op." ?")));
1472 1465
 	}
1473 1466
 	list($arg, $op, $val, $col, $where_complement) = $r;
1474 1467
 
@@ -1495,8 +1488,8 @@  discard block
 block discarded – undo
1495 1488
 				"'NOT'",
1496 1489
 				array(
1497 1490
 					"'IN'",
1498
-					"'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'",
1499
-					array("'SELF'", "'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'", $where)
1491
+					"'".$boucles[$idb]->id_table.".".$boucles[$idb]->primary."'",
1492
+					array("'SELF'", "'".$boucles[$idb]->id_table.".".$boucles[$idb]->primary."'", $where)
1500 1493
 				)
1501 1494
 			);
1502 1495
 		}
@@ -1515,22 +1508,22 @@  discard block
 block discarded – undo
1515 1508
 	$descr = $boucles[$idb]->descr;
1516 1509
 	$cpt = &$num[$descr['nom']][$descr['gram']][$idb];
1517 1510
 
1518
-	$var = '$in' . $cpt++;
1511
+	$var = '$in'.$cpt++;
1519 1512
 	$x = "\n\t$var = array();";
1520 1513
 	foreach ($val as $k => $v) {
1521 1514
 		if (preg_match(",^(\n//.*\n)?'(.*)'$,", $v, $r)) {
1522 1515
 			// optimiser le traitement des constantes
1523 1516
 			if (is_numeric($r[2])) {
1524
-				$x .= "\n\t$var" . "[]= $r[2];";
1517
+				$x .= "\n\t$var"."[]= $r[2];";
1525 1518
 			} else {
1526
-				$x .= "\n\t$var" . "[]= " . sql_quote($r[2]) . ";";
1519
+				$x .= "\n\t$var"."[]= ".sql_quote($r[2]).";";
1527 1520
 			}
1528 1521
 		} else {
1529 1522
 			// Pour permettre de passer des tableaux de valeurs
1530 1523
 			// on repere l'utilisation brute de #ENV**{X},
1531 1524
 			// c'est-a-dire sa  traduction en ($PILE[0][X]).
1532 1525
 			// et on deballe mais en rajoutant l'anti XSS
1533
-			$x .= "\n\tif (!(is_array(\$a = ($v))))\n\t\t$var" . "[]= \$a;\n\telse $var = array_merge($var, \$a);";
1526
+			$x .= "\n\tif (!(is_array(\$a = ($v))))\n\t\t$var"."[]= \$a;\n\telse $var = array_merge($var, \$a);";
1534 1527
 		}
1535 1528
 	}
1536 1529
 
@@ -1544,7 +1537,7 @@  discard block
 block discarded – undo
1544 1537
 		$boucles[$idb]->default_order[] = "((!sql_quote($var) OR sql_quote($var)===\"''\") ? 0 : ('FIELD($arg,' . sql_quote($var) . ')'))";
1545 1538
 	}
1546 1539
 
1547
-	return "sql_in('$arg',sql_quote($var)" . ($crit2 == 'NOT' ? ",'NOT'" : "") . ")";
1540
+	return "sql_in('$arg',sql_quote($var)".($crit2 == 'NOT' ? ",'NOT'" : "").")";
1548 1541
 }
1549 1542
 
1550 1543
 /**
@@ -1648,7 +1641,7 @@  discard block
 block discarded – undo
1648 1641
 	// Les champs id_xx de la table demandée
1649 1642
 	$champs = array_filter(
1650 1643
 		array_keys($desc['field']),
1651
-		function($champ){
1644
+		function($champ) {
1652 1645
 			return
1653 1646
 				strpos($champ, 'id_') === 0
1654 1647
 				or (in_array($champ, array('objet')));
@@ -1851,8 +1844,8 @@  discard block
 block discarded – undo
1851 1844
 				"'NOT'",
1852 1845
 				array(
1853 1846
 					"'IN'",
1854
-					"'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'",
1855
-					array("'SELF'", "'" . $boucles[$idb]->id_table . "." . $boucles[$idb]->primary . "'", $where)
1847
+					"'".$boucles[$idb]->id_table.".".$boucles[$idb]->primary."'",
1848
+					array("'SELF'", "'".$boucles[$idb]->id_table.".".$boucles[$idb]->primary."'", $where)
1856 1849
 				)
1857 1850
 			);
1858 1851
 		}
@@ -1863,7 +1856,7 @@  discard block
 block discarded – undo
1863 1856
 	if ($crit->cond) {
1864 1857
 		$pred = calculer_argument_precedent($idb, $col, $boucles);
1865 1858
 		if ($col == "date" or $col == "date_redac") {
1866
-			if ($pred == "\$Pile[0]['" . $col . "']") {
1859
+			if ($pred == "\$Pile[0]['".$col."']") {
1867 1860
 				$pred = "(\$Pile[0]['{$col}_default']?'':$pred)";
1868 1861
 			}
1869 1862
 		}
@@ -2024,7 +2017,7 @@  discard block
 block discarded – undo
2024 2017
 		// defaire le quote des int et les passer dans sql_quote avec le bon type de champ si on le connait, int sinon
2025 2018
 		// prendre en compte le debug ou la valeur arrive avec un commentaire PHP en debut
2026 2019
 		if (preg_match(",^\\A(\s*//.*?$\s*)?\"'(-?\d+)'\"\\z,ms", $val[0], $r)) {
2027
-			$val[0] = $r[1] . '"' . sql_quote($r[2], $boucle->sql_serveur, $type_cast_quote) . '"';
2020
+			$val[0] = $r[1].'"'.sql_quote($r[2], $boucle->sql_serveur, $type_cast_quote).'"';
2028 2021
 		}
2029 2022
 		// sinon expliciter les
2030 2023
 		// sql_quote(truc) en sql_quote(truc,'',type)
@@ -2035,22 +2028,22 @@  discard block
 block discarded – undo
2035 2028
 		// sql_quote(truc,'','varchar')
2036 2029
 		elseif (preg_match('/\Asql_quote[(](.*?)(,[^)]*?)?(,[^)]*(?:\(\d+\)[^)]*)?)?[)]\s*\z/ms', $val[0], $r)
2037 2030
 			// si pas deja un type
2038
-			and (!isset($r[3]) or !$r[3] or !trim($r[3],", '"))
2031
+			and (!isset($r[3]) or !$r[3] or !trim($r[3], ", '"))
2039 2032
 		) {
2040 2033
 			$r = $r[1]
2041 2034
 				. ((isset($r[2]) and $r[2]) ? $r[2] : ",''")
2042
-				. ",'" . addslashes($type_cast_quote) . "'";
2035
+				. ",'".addslashes($type_cast_quote)."'";
2043 2036
 			$val[0] = "sql_quote($r)";
2044 2037
 		}
2045
-		elseif(strpos($val[0], '@@defaultcast@@') !== false
2038
+		elseif (strpos($val[0], '@@defaultcast@@') !== false
2046 2039
 		  and preg_match("/'@@defaultcast@@'\s*\)\s*\z/ms", $val[0], $r)) {
2047
-			$val[0] = substr($val[0], 0, -strlen($r[0])) . "'" . addslashes($type_cast_quote) . "')";
2040
+			$val[0] = substr($val[0], 0, -strlen($r[0]))."'".addslashes($type_cast_quote)."')";
2048 2041
 		}
2049 2042
 	}
2050 2043
 
2051
-	if(strpos($val[0], '@@defaultcast@@') !== false
2044
+	if (strpos($val[0], '@@defaultcast@@') !== false
2052 2045
 	  and preg_match("/'@@defaultcast@@'\s*\)\s*\z/ms", $val[0], $r)) {
2053
-		$val[0] = substr($val[0], 0, -strlen($r[0])) . "'char')";
2046
+		$val[0] = substr($val[0], 0, -strlen($r[0]))."'char')";
2054 2047
 	}
2055 2048
 
2056 2049
 	// Indicateur pour permettre aux fonctionx boucle_X de modifier
@@ -2075,7 +2068,7 @@  discard block
 block discarded – undo
2075 2068
 	// inserer le nom de la table SQL devant le nom du champ
2076 2069
 	if ($table) {
2077 2070
 		if ($col[0] == "`") {
2078
-			$arg = "$table." . substr($col, 1, -1);
2071
+			$arg = "$table.".substr($col, 1, -1);
2079 2072
 		} else {
2080 2073
 			$arg = "$table.$col";
2081 2074
 		}
@@ -2209,9 +2202,9 @@  discard block
 block discarded – undo
2209 2202
  **/
2210 2203
 function primary_doublee($decompose, $table) {
2211 2204
 	$e1 = reset($decompose);
2212
-	$e2 = "sql_quote('" . end($decompose) . "')";
2205
+	$e2 = "sql_quote('".end($decompose)."')";
2213 2206
 
2214
-	return array("'='", "'$table." . $e1 . "'", $e2);
2207
+	return array("'='", "'$table.".$e1."'", $e2);
2215 2208
 }
2216 2209
 
2217 2210
 /**
@@ -2249,7 +2242,7 @@  discard block
 block discarded – undo
2249 2242
 	if ($checkarrivee
2250 2243
 		and is_string($checkarrivee)
2251 2244
 		and $a = table_objet($checkarrivee)
2252
-		and in_array($a . '_liens', $joints)
2245
+		and in_array($a.'_liens', $joints)
2253 2246
 	) {
2254 2247
 		if ($res = calculer_lien_externe_init($boucle, $joints, $col, $desc, $cond, $checkarrivee)) {
2255 2248
 			return $res;
@@ -2269,12 +2262,12 @@  discard block
 block discarded – undo
2269 2262
 				// la table est déjà dans le FROM, on vérifie si le champ est utilisé.
2270 2263
 				$joindre = false;
2271 2264
 				foreach ($cols as $col) {
2272
-					$c = '/\b' . $t . ".$col" . '\b/';
2265
+					$c = '/\b'.$t.".$col".'\b/';
2273 2266
 					if (trouver_champ($c, $boucle->where)) {
2274 2267
 						$joindre = true;
2275 2268
 					} else {
2276 2269
 						// mais ca peut etre dans le FIELD pour le Having
2277
-						$c = "/FIELD.$t" . ".$col,/";
2270
+						$c = "/FIELD.$t".".$col,/";
2278 2271
 						if (trouver_champ($c, $boucle->select)) {
2279 2272
 							$joindre = true;
2280 2273
 						}
@@ -2321,7 +2314,7 @@  discard block
 block discarded – undo
2321 2314
 	$primary_arrivee = id_table_objet($checkarrivee);
2322 2315
 
2323 2316
 	// [FIXME] $checkarrivee peut-il arriver avec false ????
2324
-	$intermediaire = trouver_champ_exterieur($primary_arrivee, $joints, $boucle, $checkarrivee . "_liens");
2317
+	$intermediaire = trouver_champ_exterieur($primary_arrivee, $joints, $boucle, $checkarrivee."_liens");
2325 2318
 	$arrivee = trouver_champ_exterieur($col, $joints, $boucle, $checkarrivee);
2326 2319
 
2327 2320
 	if (!$intermediaire or !$arrivee) {
@@ -2419,7 +2412,7 @@  discard block
 block discarded – undo
2419 2412
 			} elseif ($crit->cond and ($col == "date" or $col == "date_redac")) {
2420 2413
 				// un critere conditionnel sur date est traite a part
2421 2414
 				// car la date est mise d'office par SPIP,
2422
-				$defaut = "(\$Pile[0]['{$col}_default']?'':\$Pile[0]['" . $col . "'])";
2415
+				$defaut = "(\$Pile[0]['{$col}_default']?'':\$Pile[0]['".$col."'])";
2423 2416
 			}
2424 2417
 
2425 2418
 			$val = calculer_argument_precedent($idb, $val, $boucles, $defaut);
@@ -2451,7 +2444,7 @@  discard block
 block discarded – undo
2451 2444
 			and (($p == "'") or ($p == '"'))
2452 2445
 			and $params[0][1]->type == 'champ'
2453 2446
 		) {
2454
-			$val[] = "$p\\$p#" . $params[0][1]->nom_champ . "\\$p$p";
2447
+			$val[] = "$p\\$p#".$params[0][1]->nom_champ."\\$p$p";
2455 2448
 		} else {
2456 2449
 			foreach ((($op != 'IN') ? $params : calculer_vieux_in($params)) as $p) {
2457 2450
 				$a = calculer_liste($p, $desc, $boucles, $parent);
@@ -2467,7 +2460,7 @@  discard block
 block discarded – undo
2467 2460
 	$fct = $args_sql = '';
2468 2461
 	// fonction SQL ?
2469 2462
 	// chercher FONCTION(champ) tel que CONCAT(titre,descriptif)
2470
-	if (preg_match('/^(.*)' . SQL_ARGS . '$/', $col, $m)) {
2463
+	if (preg_match('/^(.*)'.SQL_ARGS.'$/', $col, $m)) {
2471 2464
 		$fct = $m[1];
2472 2465
 		preg_match('/^\(([^,]*)(.*)\)$/', $m[2], $a);
2473 2466
 		$col = $a[1];
@@ -2557,7 +2550,7 @@  discard block
 block discarded – undo
2557 2550
 		# si oui choisir ce champ, sinon choisir xxxx
2558 2551
 
2559 2552
 		if (isset($table['field']["date$suite"])) {
2560
-			$date_orig = 'date' . $suite;
2553
+			$date_orig = 'date'.$suite;
2561 2554
 		} else {
2562 2555
 			$date_orig = substr($suite, 1);
2563 2556
 		}
@@ -2568,12 +2561,12 @@  discard block
 block discarded – undo
2568 2561
 		}
2569 2562
 	}
2570 2563
 
2571
-	$date_compare = "\"' . normaliser_date(" .
2572
-		calculer_argument_precedent($idb, $pred, $boucles) .
2564
+	$date_compare = "\"' . normaliser_date(".
2565
+		calculer_argument_precedent($idb, $pred, $boucles).
2573 2566
 		") . '\"";
2574 2567
 
2575 2568
 	$col_vraie = $date_orig;
2576
-	$date_orig = $boucle->id_table . '.' . $date_orig;
2569
+	$date_orig = $boucle->id_table.'.'.$date_orig;
2577 2570
 
2578 2571
 	switch ($col) {
2579 2572
 		case 'date':
@@ -2593,26 +2586,26 @@  discard block
 block discarded – undo
2593 2586
 			break;
2594 2587
 		case 'age':
2595 2588
 			$col = calculer_param_date("NOW()", $date_orig);
2596
-			$col_vraie = "";// comparer a un int (par defaut)
2589
+			$col_vraie = ""; // comparer a un int (par defaut)
2597 2590
 			break;
2598 2591
 		case 'age_relatif':
2599 2592
 			$col = calculer_param_date($date_compare, $date_orig);
2600
-			$col_vraie = "";// comparer a un int (par defaut)
2593
+			$col_vraie = ""; // comparer a un int (par defaut)
2601 2594
 			break;
2602 2595
 		case 'jour_relatif':
2603
-			$col = "(TO_DAYS(" . $date_compare . ")-TO_DAYS(" . $date_orig . "))";
2604
-			$col_vraie = "";// comparer a un int (par defaut)
2596
+			$col = "(TO_DAYS(".$date_compare.")-TO_DAYS(".$date_orig."))";
2597
+			$col_vraie = ""; // comparer a un int (par defaut)
2605 2598
 			break;
2606 2599
 		case 'mois_relatif':
2607
-			$col = "MONTH(" . $date_compare . ")-MONTH(" .
2608
-				$date_orig . ")+12*(YEAR(" . $date_compare .
2609
-				")-YEAR(" . $date_orig . "))";
2610
-			$col_vraie = "";// comparer a un int (par defaut)
2600
+			$col = "MONTH(".$date_compare.")-MONTH(".
2601
+				$date_orig.")+12*(YEAR(".$date_compare.
2602
+				")-YEAR(".$date_orig."))";
2603
+			$col_vraie = ""; // comparer a un int (par defaut)
2611 2604
 			break;
2612 2605
 		case 'annee_relatif':
2613
-			$col = "YEAR(" . $date_compare . ")-YEAR(" .
2614
-				$date_orig . ")";
2615
-			$col_vraie = "";// comparer a un int (par defaut)
2606
+			$col = "YEAR(".$date_compare.")-YEAR(".
2607
+				$date_orig.")";
2608
+			$col_vraie = ""; // comparer a un int (par defaut)
2616 2609
 			break;
2617 2610
 	}
2618 2611
 
@@ -2671,10 +2664,10 @@  discard block
 block discarded – undo
2671 2664
 	}
2672 2665
 
2673 2666
 	$boucle->hash .= '
2674
-	$command[\'sourcemode\'] = ' . array_shift($args) . ";\n";
2667
+	$command[\'sourcemode\'] = ' . array_shift($args).";\n";
2675 2668
 
2676 2669
 	$boucle->hash .= '
2677
-	$command[\'source\'] = array(' . join(', ', $args) . ");\n";
2670
+	$command[\'source\'] = array(' . join(', ', $args).");\n";
2678 2671
 }
2679 2672
 
2680 2673
 
@@ -2692,8 +2685,8 @@  discard block
 block discarded – undo
2692 2685
 function critere_DATA_datasource_dist($idb, &$boucles, $crit) {
2693 2686
 	$boucle = &$boucles[$idb];
2694 2687
 	$boucle->hash .= '
2695
-	$command[\'source\'] = array(' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent) . ');
2696
-	$command[\'sourcemode\'] = ' . calculer_liste($crit->param[1], array(), $boucles, $boucles[$idb]->id_parent) . ';';
2688
+	$command[\'source\'] = array(' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent).');
2689
+	$command[\'sourcemode\'] = ' . calculer_liste($crit->param[1], array(), $boucles, $boucles[$idb]->id_parent).';';
2697 2690
 }
2698 2691
 
2699 2692
 
@@ -2713,7 +2706,7 @@  discard block
 block discarded – undo
2713 2706
 function critere_DATA_datacache_dist($idb, &$boucles, $crit) {
2714 2707
 	$boucle = &$boucles[$idb];
2715 2708
 	$boucle->hash .= '
2716
-	$command[\'datacache\'] = ' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent) . ';';
2709
+	$command[\'datacache\'] = ' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent).';';
2717 2710
 }
2718 2711
 
2719 2712
 
@@ -2732,7 +2725,7 @@  discard block
 block discarded – undo
2732 2725
 	$boucle->hash .= '$command[\'args\']=array();';
2733 2726
 	foreach ($crit->param as $param) {
2734 2727
 		$boucle->hash .= '
2735
-			$command[\'args\'][] = ' . calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent) . ';';
2728
+			$command[\'args\'][] = ' . calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent).';';
2736 2729
 	}
2737 2730
 }
2738 2731
 
@@ -2751,10 +2744,10 @@  discard block
 block discarded – undo
2751 2744
  */
2752 2745
 function critere_DATA_liste_dist($idb, &$boucles, $crit) {
2753 2746
 	$boucle = &$boucles[$idb];
2754
-	$boucle->hash .= "\n\t" . '$command[\'liste\'] = array();' . "\n";
2747
+	$boucle->hash .= "\n\t".'$command[\'liste\'] = array();'."\n";
2755 2748
 	foreach ($crit->param as $param) {
2756
-		$boucle->hash .= "\t" . '$command[\'liste\'][] = ' . calculer_liste($param, array(), $boucles,
2757
-				$boucles[$idb]->id_parent) . ";\n";
2749
+		$boucle->hash .= "\t".'$command[\'liste\'][] = '.calculer_liste($param, array(), $boucles,
2750
+				$boucles[$idb]->id_parent).";\n";
2758 2751
 	}
2759 2752
 }
2760 2753
 
@@ -2781,10 +2774,10 @@  discard block
 block discarded – undo
2781 2774
  */
2782 2775
 function critere_DATA_enum_dist($idb, &$boucles, $crit) {
2783 2776
 	$boucle = &$boucles[$idb];
2784
-	$boucle->hash .= "\n\t" . '$command[\'enum\'] = array();' . "\n";
2777
+	$boucle->hash .= "\n\t".'$command[\'enum\'] = array();'."\n";
2785 2778
 	foreach ($crit->param as $param) {
2786
-		$boucle->hash .= "\t" . '$command[\'enum\'][] = ' . calculer_liste($param, array(), $boucles,
2787
-				$boucles[$idb]->id_parent) . ";\n";
2779
+		$boucle->hash .= "\t".'$command[\'enum\'][] = '.calculer_liste($param, array(), $boucles,
2780
+				$boucles[$idb]->id_parent).";\n";
2788 2781
 	}
2789 2782
 }
2790 2783
 
@@ -2803,7 +2796,7 @@  discard block
 block discarded – undo
2803 2796
 	$boucle = &$boucles[$idb];
2804 2797
 	foreach ($crit->param as $param) {
2805 2798
 		$boucle->hash .= '
2806
-			$command[\'datapath\'][] = ' . calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent) . ';';
2799
+			$command[\'datapath\'][] = ' . calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent).';';
2807 2800
 	}
2808 2801
 }
2809 2802
 
@@ -2844,7 +2837,7 @@  discard block
 block discarded – undo
2844 2837
 	if ($crit->param) {
2845 2838
 		foreach ($crit->param as $param) {
2846 2839
 			$boucle->hash .= "\t\$command['si'][] = "
2847
-				. calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent) . ";\n";
2840
+				. calculer_liste($param, array(), $boucles, $boucles[$idb]->id_parent).";\n";
2848 2841
 		}
2849 2842
 		// interdire {si 0} aussi !
2850 2843
 	} else {
@@ -2867,7 +2860,7 @@  discard block
 block discarded – undo
2867 2860
 function critere_POUR_tableau_dist($idb, &$boucles, $crit) {
2868 2861
 	$boucle = &$boucles[$idb];
2869 2862
 	$boucle->hash .= '
2870
-	$command[\'source\'] = array(' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent) . ');
2863
+	$command[\'source\'] = array(' . calculer_liste($crit->param[0], array(), $boucles, $boucles[$idb]->id_parent).');
2871 2864
 	$command[\'sourcemode\'] = \'table\';';
2872 2865
 }
2873 2866
 
@@ -2900,11 +2893,10 @@  discard block
 block discarded – undo
2900 2893
 	$table_sql = table_objet_sql(objet_type($table));
2901 2894
 
2902 2895
 	$id_parent = isset($GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent']) ?
2903
-		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] :
2904
-		'id_parent';
2896
+		$GLOBALS['exceptions_des_tables'][$boucle->id_table]['id_parent'] : 'id_parent';
2905 2897
 
2906 2898
 	$in = "IN";
2907
-	$where = array("'IN'", "'$boucle->id_table." . "$primary'", "'('.sql_get_select('$id_parent', '$table_sql').')'");
2899
+	$where = array("'IN'", "'$boucle->id_table."."$primary'", "'('.sql_get_select('$id_parent', '$table_sql').')'");
2908 2900
 	if ($not) {
2909 2901
 		$where = array("'NOT'", $where);
2910 2902
 	}
Please login to merge, or discard this patch.