Completed
Push — master ( c76770...babdec )
by cam
01:26
created
ecrire/src/Compilateur/Noeud/Boucle.php 1 patch
Indentation   +363 added lines, -363 removed lines patch added patch discarded remove patch
@@ -7,367 +7,367 @@
 block discarded – undo
7 7
  */
8 8
 class Boucle
9 9
 {
10
-	/** Type de noeud */
11
-	public string $type = 'boucle';
12
-
13
-	/** Identifiant de la boucle */
14
-	public string $id_boucle;
15
-
16
-	/** Identifiant de la boucle parente */
17
-	public string $id_parent = '';
18
-
19
-	/** Un nom explicite qui peut être affecté manuellement à certaines boucles générées */
20
-	public string $nom = '';
21
-
22
-	/**
23
-	 * Partie avant toujours affichee
24
-	 *
25
-	 * @var string|array
26
-	 */
27
-	public $preaff = '';
28
-
29
-	/**
30
-	 * Partie optionnelle avant
31
-	 *
32
-	 * @var string|array
33
-	 */
34
-	public $avant = '';
35
-
36
-	/**
37
-	 * Pour chaque élément
38
-	 *
39
-	 * @var string|array
40
-	 */
41
-	public $milieu = '';
42
-
43
-	/**
44
-	 * Partie optionnelle après
45
-	 *
46
-	 * @var string|array
47
-	 */
48
-	public $apres = '';
49
-
50
-	/**
51
-	 * Partie alternative, si pas de résultat dans la boucle
52
-	 *
53
-	 * @var string|array
54
-	 */
55
-	public $altern = '';
56
-
57
-	/**
58
-	 * Partie apres toujours affichee
59
-	 *
60
-	 * @var string|array
61
-	 */
62
-	public $postaff = '';
63
-
64
-
65
-	/**
66
-	 * La boucle doit-elle sélectionner la langue ?
67
-	 *
68
-	 * Valeurs : '', 'oui', 'non'
69
-	 */
70
-	public string $lang_select = '';
71
-
72
-	/**
73
-	 * Alias de table d'application de la requête ou nom complet de la table SQL
74
-	 *
75
-	 * FIXME: un seul typage (string ?)
76
-	 *
77
-	 * @var string|false|null
78
-	 */
79
-	public $type_requete = null;
80
-
81
-	/**
82
-	 * La table est elle optionnelle ?
83
-	 *
84
-	 * Si oui, aucune erreur ne sera générée si la table demandée n'est pas présente
85
-	 */
86
-	public bool $table_optionnelle = false;
87
-
88
-	/**
89
-	 * Nom du fichier de connexion
90
-	 */
91
-	public string $sql_serveur = '';
92
-
93
-	/**
94
-	 * Paramètres de la boucle
95
-	 *
96
-	 * Description des paramètres passés à la boucle, qui servent ensuite
97
-	 * au calcul des critères
98
-	 *
99
-	 * FIXME: type unique.
100
-	 * @var false|array
101
-	 *     - false: erreur de syntaxe
102
-	 */
103
-	public $param = [];
104
-
105
-	/**
106
-	 * Critères de la boucle
107
-	 *
108
-	 * FIXME: type array unique.
109
-	 *
110
-	 * @var string|Critere[]
111
-	 * - string: phrasage (code brut). Il reste si erreur de critère
112
-	 * - array: analyse correcte des critères...
113
-	 */
114
-	public $criteres = [];
115
-
116
-	/**
117
-	 * Textes insérés entre 2 éléments de boucle (critère inter)
118
-	 *
119
-	 * @var string[]
120
-	 */
121
-	public array $separateur = [];
122
-
123
-	/**
124
-	 * Liste des jointures possibles avec cette table
125
-	 *
126
-	 * Les jointures par défaut de la table sont complétées en priorité
127
-	 * des jointures déclarées explicitement sur la boucle
128
-	 *
129
-	 * @see base_trouver_table_dist()
130
-	 */
131
-	public array $jointures = [];
132
-
133
-	/**
134
-	 * Jointures explicites avec cette table
135
-	 *
136
-	 * Ces jointures sont utilisées en priorité par rapport aux jointures
137
-	 * normales possibles pour retrouver les colonnes demandées extérieures
138
-	 * à la boucle.
139
-	 *
140
-	 * @var string|bool
141
-	 */
142
-	public $jointures_explicites = false;
143
-
144
-	/**
145
-	 * Nom de la variable PHP stockant le noms de doublons utilisés "$doublons_index"
146
-	 */
147
-	public string $doublons = '';
148
-
149
-	/**
150
-	 * Code PHP ajouté au début de chaque itération de boucle.
151
-	 *
152
-	 * Utilisé entre autre par les critères {pagination}, {n-a,b}, {a/b}...
153
-	 */
154
-	public string $partie = '';
155
-
156
-	/**
157
-	 * Nombre de divisions de la boucle, d'éléments à afficher,
158
-	 * ou de soustractions d'éléments à faire
159
-	 *
160
-	 * Dans les critères limitant le nombre d'éléments affichés
161
-	 * {a,b}, {a,n-b}, {a/b}, {pagination b}, b est affecté à total_parties.
162
-	 */
163
-	public string $total_parties = '';
164
-
165
-	/**
166
-	 * Code PHP ajouté avant l'itération de boucle.
167
-	 *
168
-	 * Utilisé entre autre par les critères {pagination}, {a,b}, {a/b}
169
-	 * pour initialiser les variables de début et de fin d'itération.
170
-	 */
171
-	public string $mode_partie = '';
172
-
173
-	/**
174
-	 * Identifiant d'une boucle qui appelle celle-ci de manière récursive
175
-	 *
176
-	 * Si une boucle est appelée de manière récursive quelque part par
177
-	 * une autre boucle comme <BOUCLE_rec(boucle_identifiant) />, cette
178
-	 * boucle (identifiant) reçoit dans cette propriété l'identifiant
179
-	 * de l'appelant (rec)
180
-	 */
181
-	public string $externe = '';
182
-
183
-	// champs pour la construction de la requete SQL
184
-
185
-	/**
186
-	 * Liste des champs à récupérer par la boucle
187
-	 *
188
-	 * Expression 'table.nom_champ' ou calculée 'nom_champ AS x'
189
-	 *
190
-	 * @var string[]
191
-	 */
192
-	public array $select = [];
193
-
194
-	/**
195
-	 * Liste des alias / tables SQL utilisées dans la boucle
196
-	 *
197
-	 * L'index est un identifiant (xx dans spip_xx assez souvent) qui servira
198
-	 * d'alias au nom de la table ; la valeur est le nom de la table SQL désirée.
199
-	 *
200
-	 * L'index 0 peut définir le type de sources de données de l'itérateur DATA
201
-	 *
202
-	 * @var string[]
203
-	 */
204
-	public array $from = [];
205
-
206
-	/**
207
-	 * Liste des alias / type de jointures utilisées dans la boucle
208
-	 *
209
-	 * L'index est le nom d'alias (comme pour la propriété $from), et la valeur
210
-	 * un type de jointure parmi 'INNER', 'LEFT', 'RIGHT', 'OUTER'.
211
-	 *
212
-	 * Lorsque le type n'est pas déclaré pour un alias, c'est 'INNER'
213
-	 * qui sera utilisé par défaut (créant donc un INNER JOIN).
214
-	 *
215
-	 * @var string[]
216
-	 */
217
-	public array $from_type = [];
218
-
219
-	/**
220
-	 * Liste des conditions WHERE de la boucle
221
-	 *
222
-	 * Permet de restreindre les éléments retournés par une boucle
223
-	 * en fonctions des conditions transmises dans ce tableau.
224
-	 *
225
-	 * Ce tableau peut avoir plusieurs niveaux de profondeur.
226
-	 *
227
-	 * Les éléments du premier niveau sont reliés par des AND, donc
228
-	 * chaque élément ajouté directement au where par
229
-	 * $boucle->where[] = array(...) ou $boucle->where[] = "'expression'"
230
-	 * est une condition AND en plus.
231
-	 *
232
-	 * Par contre, lorsqu'on indique un tableau, il peut décrire des relations
233
-	 * internes différentes. Soit $expr un tableau d'expressions quelconques de 3 valeurs :
234
-	 * $expr = array(operateur, val1, val2)
235
-	 *
236
-	 * Ces 3 valeurs sont des expressions PHP. L'index 0 désigne l'opérateur
237
-	 * à réaliser tel que :
238
-	 *
239
-	 * - "'='" , "'>='", "'<'", "'IN'", "'REGEXP'", "'LIKE'", ... :
240
-	 *    val1 et val2 sont des champs et valeurs à utiliser dans la comparaison
241
-	 *    suivant cet ordre : "val1 operateur val2".
242
-	 *    Exemple : $boucle->where[] = array("'='", "'articles.statut'", "'\"publie\"'");
243
-	 * - "'AND'", "'OR'", "'NOT'" :
244
-	 *    dans ce cas val1 et val2 sont également des expressions
245
-	 *    de comparaison complètes, et peuvent être eux-même des tableaux comme $expr
246
-	 *    Exemples :
247
-	 *    $boucle->where[] = array("'OR'", $expr1, $expr2);
248
-	 *    $boucle->where[] = array("'NOT'", $expr); // val2 n'existe pas avec NOT
249
-	 *
250
-	 * D'autres noms sont possibles pour l'opérateur (le nombre de valeurs diffère) :
251
-	 * - "'SELF'", "'SUBSELECT'" : indiquent des sous requêtes
252
-	 * - "'?'" : indique une condition à faire évaluer (val1 ? val2 : val3)
253
-	 */
254
-	public array $where = [];
255
-
256
-	public array $join = [];
257
-	public array $having = [];
258
-	public $limit = '';
259
-	public array $group = [];
260
-	public array $order = [];
261
-	public array $default_order = [];
262
-	public string $date = 'date';
263
-	public string $hash = '';
264
-	public $in = '';
265
-	public bool $sous_requete = false;
266
-
267
-	/**
268
-	 * Code PHP qui sera ajouté en tout début de la fonction de boucle
269
-	 *
270
-	 * Il sert à insérer le code calculant une hierarchie
271
-	 */
272
-	public string $hierarchie = '';
273
-
274
-	// champs pour la construction du corps PHP
275
-
276
-	/**
277
-	 * Description des sources de données de la boucle
278
-	 *
279
-	 * Description des données de la boucle issu de trouver_table
280
-	 * dans le cadre de l'itérateur SQL et contenant au moins l'index 'field'.
281
-	 *
282
-	 * @see base_trouver_table_dist()
283
-	 */
284
-	public array $show = [];
285
-
286
-	/**
287
-	 * Nom de la table SQL principale de la boucle, sans son préfixe
288
-	 */
289
-	public string $id_table = '';
290
-
291
-	/**
292
-	 * Nom de la clé primaire de la table SQL principale de la boucle
293
-	 */
294
-	public string $primary = '';
295
-
296
-	/**
297
-	 * Code PHP compilé de la boucle
298
-	 *
299
-	 * FIXME: un seul type (string ?)
300
-	 *
301
-	 * - false: boucle fautive ?
302
-	 *
303
-	 * @var string|false
304
-	 */
305
-	public $return = '';
306
-
307
-	public $numrows = false;
308
-	public $cptrows = false;
309
-
310
-	/**
311
-	 * Description du squelette
312
-	 *
313
-	 * Sert pour la gestion d'erreur et la production de code dependant du contexte
314
-	 *
315
-	 * Peut contenir les index :
316
-	 *
317
-	 * - nom : Nom du fichier de cache
318
-	 * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
319
-	 * - sourcefile : Chemin du squelette
320
-	 * - squelette : Code du squelette
321
-	 * - id_mere : Identifiant de la boucle parente
322
-	 * - documents : Pour embed et img dans les textes
323
-	 * - session : Pour un cache sessionné par auteur
324
-	 * - niv : Niveau de tabulation
325
-	 */
326
-	public array $descr = [];
327
-
328
-	/** Numéro de ligne dans le code source du squelette */
329
-	public int $ligne = 0;
330
-
331
-
332
-	/**
333
-	 * table pour stocker les modificateurs de boucle tels que tout, plat ...,
334
-	 * utilisable par les plugins egalement
335
-	 *
336
-	 * @var array<string, mixed>
337
-	 */
338
-	public array $modificateur = [];
339
-
340
-	/**
341
-	 * Type d'itérateur utilisé pour cette boucle
342
-	 *
343
-	 * - 'SQL' dans le cadre d'une boucle sur une table SQL
344
-	 * - 'DATA' pour l'itérateur DATA, ...
345
-	 *
346
-	 * @var string
347
-	 */
348
-	public string $iterateur = ''; // type d'iterateur
349
-
350
-	/**
351
-	 * @var array $debug Textes qui seront insérés dans l’entête de boucle du mode debug
352
-	 */
353
-	public array $debug = [];
354
-
355
-	/**
356
-	 * Index de la boucle dont le champ présent dans cette boucle est originaire,
357
-	 * notamment si le champ a été trouve dans une boucle parente
358
-	 *
359
-	 * Tableau nom du champ => index de boucle
360
-	*/
361
-	public array $index_champ = [];
362
-
363
-	/** Résultat de la compilation (?) (sert au débusqueur) */
364
-	public string $code = '';
365
-
366
-	/** Source des filtres (compatibilité) (?) */
367
-	public array $fonctions = [];
368
-
369
-	// obsoletes, conserves provisoirement pour compatibilite
370
-	public $tout = false;
371
-	public $plat = false;
372
-	public $lien = false;
10
+    /** Type de noeud */
11
+    public string $type = 'boucle';
12
+
13
+    /** Identifiant de la boucle */
14
+    public string $id_boucle;
15
+
16
+    /** Identifiant de la boucle parente */
17
+    public string $id_parent = '';
18
+
19
+    /** Un nom explicite qui peut être affecté manuellement à certaines boucles générées */
20
+    public string $nom = '';
21
+
22
+    /**
23
+     * Partie avant toujours affichee
24
+     *
25
+     * @var string|array
26
+     */
27
+    public $preaff = '';
28
+
29
+    /**
30
+     * Partie optionnelle avant
31
+     *
32
+     * @var string|array
33
+     */
34
+    public $avant = '';
35
+
36
+    /**
37
+     * Pour chaque élément
38
+     *
39
+     * @var string|array
40
+     */
41
+    public $milieu = '';
42
+
43
+    /**
44
+     * Partie optionnelle après
45
+     *
46
+     * @var string|array
47
+     */
48
+    public $apres = '';
49
+
50
+    /**
51
+     * Partie alternative, si pas de résultat dans la boucle
52
+     *
53
+     * @var string|array
54
+     */
55
+    public $altern = '';
56
+
57
+    /**
58
+     * Partie apres toujours affichee
59
+     *
60
+     * @var string|array
61
+     */
62
+    public $postaff = '';
63
+
64
+
65
+    /**
66
+     * La boucle doit-elle sélectionner la langue ?
67
+     *
68
+     * Valeurs : '', 'oui', 'non'
69
+     */
70
+    public string $lang_select = '';
71
+
72
+    /**
73
+     * Alias de table d'application de la requête ou nom complet de la table SQL
74
+     *
75
+     * FIXME: un seul typage (string ?)
76
+     *
77
+     * @var string|false|null
78
+     */
79
+    public $type_requete = null;
80
+
81
+    /**
82
+     * La table est elle optionnelle ?
83
+     *
84
+     * Si oui, aucune erreur ne sera générée si la table demandée n'est pas présente
85
+     */
86
+    public bool $table_optionnelle = false;
87
+
88
+    /**
89
+     * Nom du fichier de connexion
90
+     */
91
+    public string $sql_serveur = '';
92
+
93
+    /**
94
+     * Paramètres de la boucle
95
+     *
96
+     * Description des paramètres passés à la boucle, qui servent ensuite
97
+     * au calcul des critères
98
+     *
99
+     * FIXME: type unique.
100
+     * @var false|array
101
+     *     - false: erreur de syntaxe
102
+     */
103
+    public $param = [];
104
+
105
+    /**
106
+     * Critères de la boucle
107
+     *
108
+     * FIXME: type array unique.
109
+     *
110
+     * @var string|Critere[]
111
+     * - string: phrasage (code brut). Il reste si erreur de critère
112
+     * - array: analyse correcte des critères...
113
+     */
114
+    public $criteres = [];
115
+
116
+    /**
117
+     * Textes insérés entre 2 éléments de boucle (critère inter)
118
+     *
119
+     * @var string[]
120
+     */
121
+    public array $separateur = [];
122
+
123
+    /**
124
+     * Liste des jointures possibles avec cette table
125
+     *
126
+     * Les jointures par défaut de la table sont complétées en priorité
127
+     * des jointures déclarées explicitement sur la boucle
128
+     *
129
+     * @see base_trouver_table_dist()
130
+     */
131
+    public array $jointures = [];
132
+
133
+    /**
134
+     * Jointures explicites avec cette table
135
+     *
136
+     * Ces jointures sont utilisées en priorité par rapport aux jointures
137
+     * normales possibles pour retrouver les colonnes demandées extérieures
138
+     * à la boucle.
139
+     *
140
+     * @var string|bool
141
+     */
142
+    public $jointures_explicites = false;
143
+
144
+    /**
145
+     * Nom de la variable PHP stockant le noms de doublons utilisés "$doublons_index"
146
+     */
147
+    public string $doublons = '';
148
+
149
+    /**
150
+     * Code PHP ajouté au début de chaque itération de boucle.
151
+     *
152
+     * Utilisé entre autre par les critères {pagination}, {n-a,b}, {a/b}...
153
+     */
154
+    public string $partie = '';
155
+
156
+    /**
157
+     * Nombre de divisions de la boucle, d'éléments à afficher,
158
+     * ou de soustractions d'éléments à faire
159
+     *
160
+     * Dans les critères limitant le nombre d'éléments affichés
161
+     * {a,b}, {a,n-b}, {a/b}, {pagination b}, b est affecté à total_parties.
162
+     */
163
+    public string $total_parties = '';
164
+
165
+    /**
166
+     * Code PHP ajouté avant l'itération de boucle.
167
+     *
168
+     * Utilisé entre autre par les critères {pagination}, {a,b}, {a/b}
169
+     * pour initialiser les variables de début et de fin d'itération.
170
+     */
171
+    public string $mode_partie = '';
172
+
173
+    /**
174
+     * Identifiant d'une boucle qui appelle celle-ci de manière récursive
175
+     *
176
+     * Si une boucle est appelée de manière récursive quelque part par
177
+     * une autre boucle comme <BOUCLE_rec(boucle_identifiant) />, cette
178
+     * boucle (identifiant) reçoit dans cette propriété l'identifiant
179
+     * de l'appelant (rec)
180
+     */
181
+    public string $externe = '';
182
+
183
+    // champs pour la construction de la requete SQL
184
+
185
+    /**
186
+     * Liste des champs à récupérer par la boucle
187
+     *
188
+     * Expression 'table.nom_champ' ou calculée 'nom_champ AS x'
189
+     *
190
+     * @var string[]
191
+     */
192
+    public array $select = [];
193
+
194
+    /**
195
+     * Liste des alias / tables SQL utilisées dans la boucle
196
+     *
197
+     * L'index est un identifiant (xx dans spip_xx assez souvent) qui servira
198
+     * d'alias au nom de la table ; la valeur est le nom de la table SQL désirée.
199
+     *
200
+     * L'index 0 peut définir le type de sources de données de l'itérateur DATA
201
+     *
202
+     * @var string[]
203
+     */
204
+    public array $from = [];
205
+
206
+    /**
207
+     * Liste des alias / type de jointures utilisées dans la boucle
208
+     *
209
+     * L'index est le nom d'alias (comme pour la propriété $from), et la valeur
210
+     * un type de jointure parmi 'INNER', 'LEFT', 'RIGHT', 'OUTER'.
211
+     *
212
+     * Lorsque le type n'est pas déclaré pour un alias, c'est 'INNER'
213
+     * qui sera utilisé par défaut (créant donc un INNER JOIN).
214
+     *
215
+     * @var string[]
216
+     */
217
+    public array $from_type = [];
218
+
219
+    /**
220
+     * Liste des conditions WHERE de la boucle
221
+     *
222
+     * Permet de restreindre les éléments retournés par une boucle
223
+     * en fonctions des conditions transmises dans ce tableau.
224
+     *
225
+     * Ce tableau peut avoir plusieurs niveaux de profondeur.
226
+     *
227
+     * Les éléments du premier niveau sont reliés par des AND, donc
228
+     * chaque élément ajouté directement au where par
229
+     * $boucle->where[] = array(...) ou $boucle->where[] = "'expression'"
230
+     * est une condition AND en plus.
231
+     *
232
+     * Par contre, lorsqu'on indique un tableau, il peut décrire des relations
233
+     * internes différentes. Soit $expr un tableau d'expressions quelconques de 3 valeurs :
234
+     * $expr = array(operateur, val1, val2)
235
+     *
236
+     * Ces 3 valeurs sont des expressions PHP. L'index 0 désigne l'opérateur
237
+     * à réaliser tel que :
238
+     *
239
+     * - "'='" , "'>='", "'<'", "'IN'", "'REGEXP'", "'LIKE'", ... :
240
+     *    val1 et val2 sont des champs et valeurs à utiliser dans la comparaison
241
+     *    suivant cet ordre : "val1 operateur val2".
242
+     *    Exemple : $boucle->where[] = array("'='", "'articles.statut'", "'\"publie\"'");
243
+     * - "'AND'", "'OR'", "'NOT'" :
244
+     *    dans ce cas val1 et val2 sont également des expressions
245
+     *    de comparaison complètes, et peuvent être eux-même des tableaux comme $expr
246
+     *    Exemples :
247
+     *    $boucle->where[] = array("'OR'", $expr1, $expr2);
248
+     *    $boucle->where[] = array("'NOT'", $expr); // val2 n'existe pas avec NOT
249
+     *
250
+     * D'autres noms sont possibles pour l'opérateur (le nombre de valeurs diffère) :
251
+     * - "'SELF'", "'SUBSELECT'" : indiquent des sous requêtes
252
+     * - "'?'" : indique une condition à faire évaluer (val1 ? val2 : val3)
253
+     */
254
+    public array $where = [];
255
+
256
+    public array $join = [];
257
+    public array $having = [];
258
+    public $limit = '';
259
+    public array $group = [];
260
+    public array $order = [];
261
+    public array $default_order = [];
262
+    public string $date = 'date';
263
+    public string $hash = '';
264
+    public $in = '';
265
+    public bool $sous_requete = false;
266
+
267
+    /**
268
+     * Code PHP qui sera ajouté en tout début de la fonction de boucle
269
+     *
270
+     * Il sert à insérer le code calculant une hierarchie
271
+     */
272
+    public string $hierarchie = '';
273
+
274
+    // champs pour la construction du corps PHP
275
+
276
+    /**
277
+     * Description des sources de données de la boucle
278
+     *
279
+     * Description des données de la boucle issu de trouver_table
280
+     * dans le cadre de l'itérateur SQL et contenant au moins l'index 'field'.
281
+     *
282
+     * @see base_trouver_table_dist()
283
+     */
284
+    public array $show = [];
285
+
286
+    /**
287
+     * Nom de la table SQL principale de la boucle, sans son préfixe
288
+     */
289
+    public string $id_table = '';
290
+
291
+    /**
292
+     * Nom de la clé primaire de la table SQL principale de la boucle
293
+     */
294
+    public string $primary = '';
295
+
296
+    /**
297
+     * Code PHP compilé de la boucle
298
+     *
299
+     * FIXME: un seul type (string ?)
300
+     *
301
+     * - false: boucle fautive ?
302
+     *
303
+     * @var string|false
304
+     */
305
+    public $return = '';
306
+
307
+    public $numrows = false;
308
+    public $cptrows = false;
309
+
310
+    /**
311
+     * Description du squelette
312
+     *
313
+     * Sert pour la gestion d'erreur et la production de code dependant du contexte
314
+     *
315
+     * Peut contenir les index :
316
+     *
317
+     * - nom : Nom du fichier de cache
318
+     * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
319
+     * - sourcefile : Chemin du squelette
320
+     * - squelette : Code du squelette
321
+     * - id_mere : Identifiant de la boucle parente
322
+     * - documents : Pour embed et img dans les textes
323
+     * - session : Pour un cache sessionné par auteur
324
+     * - niv : Niveau de tabulation
325
+     */
326
+    public array $descr = [];
327
+
328
+    /** Numéro de ligne dans le code source du squelette */
329
+    public int $ligne = 0;
330
+
331
+
332
+    /**
333
+     * table pour stocker les modificateurs de boucle tels que tout, plat ...,
334
+     * utilisable par les plugins egalement
335
+     *
336
+     * @var array<string, mixed>
337
+     */
338
+    public array $modificateur = [];
339
+
340
+    /**
341
+     * Type d'itérateur utilisé pour cette boucle
342
+     *
343
+     * - 'SQL' dans le cadre d'une boucle sur une table SQL
344
+     * - 'DATA' pour l'itérateur DATA, ...
345
+     *
346
+     * @var string
347
+     */
348
+    public string $iterateur = ''; // type d'iterateur
349
+
350
+    /**
351
+     * @var array $debug Textes qui seront insérés dans l’entête de boucle du mode debug
352
+     */
353
+    public array $debug = [];
354
+
355
+    /**
356
+     * Index de la boucle dont le champ présent dans cette boucle est originaire,
357
+     * notamment si le champ a été trouve dans une boucle parente
358
+     *
359
+     * Tableau nom du champ => index de boucle
360
+     */
361
+    public array $index_champ = [];
362
+
363
+    /** Résultat de la compilation (?) (sert au débusqueur) */
364
+    public string $code = '';
365
+
366
+    /** Source des filtres (compatibilité) (?) */
367
+    public array $fonctions = [];
368
+
369
+    // obsoletes, conserves provisoirement pour compatibilite
370
+    public $tout = false;
371
+    public $plat = false;
372
+    public $lien = false;
373 373
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Inclure.php 1 patch
Indentation   +52 added lines, -52 removed lines patch added patch discarded remove patch
@@ -7,63 +7,63 @@
 block discarded – undo
7 7
  **/
8 8
 class Inclure
9 9
 {
10
-	/** Type de noeud */
11
-	public string $type = 'include';
10
+    /** Type de noeud */
11
+    public string $type = 'include';
12 12
 
13
-	/**
14
-	 * Nom d'un fichier inclu
15
-	 *
16
-	 * - Objet Texte si inclusion d'un autre squelette
17
-	 * - chaîne si inclusion d'un fichier PHP directement
18
-	 *
19
-	 * @var string|Texte
20
-	 */
21
-	public $texte;
13
+    /**
14
+     * Nom d'un fichier inclu
15
+     *
16
+     * - Objet Texte si inclusion d'un autre squelette
17
+     * - chaîne si inclusion d'un fichier PHP directement
18
+     *
19
+     * @var string|Texte
20
+     */
21
+    public $texte;
22 22
 
23
-	/**
24
-	 * Inutilisé, propriété générique de l'AST
25
-	 *
26
-	 * @var string|array
27
-	 */
28
-	public $avant = '';
23
+    /**
24
+     * Inutilisé, propriété générique de l'AST
25
+     *
26
+     * @var string|array
27
+     */
28
+    public $avant = '';
29 29
 
30
-	/**
31
-	 * Inutilisé, propriété générique de l'AST
32
-	 *
33
-	 * @var string|array
34
-	 */
35
-	public $apres = '';
30
+    /**
31
+     * Inutilisé, propriété générique de l'AST
32
+     *
33
+     * @var string|array
34
+     */
35
+    public $apres = '';
36 36
 
37
-	/** Numéro de ligne dans le code source du squelette */
38
-	public int $ligne = 0;
37
+    /** Numéro de ligne dans le code source du squelette */
38
+    public int $ligne = 0;
39 39
 
40
-	/**
41
-	 * Valeurs des paramètres
42
-	 *
43
-	 * FIXME: type unique.
44
-	 * @var false|array
45
-	 *     - false: erreur de syntaxe
46
-	 */
47
-	public $param = [];
40
+    /**
41
+     * Valeurs des paramètres
42
+     *
43
+     * FIXME: type unique.
44
+     * @var false|array
45
+     *     - false: erreur de syntaxe
46
+     */
47
+    public $param = [];
48 48
 
49
-	/** Source des filtres (compatibilité) (?) */
50
-	public array $fonctions = [];
49
+    /** Source des filtres (compatibilité) (?) */
50
+    public array $fonctions = [];
51 51
 
52
-	/**
53
-	 * Description du squelette
54
-	 *
55
-	 * Sert pour la gestion d'erreur et la production de code dependant du contexte
56
-	 *
57
-	 * Peut contenir les index :
58
-	 *
59
-	 * - nom : Nom du fichier de cache
60
-	 * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
61
-	 * - sourcefile : Chemin du squelette
62
-	 * - squelette : Code du squelette
63
-	 * - id_mere : Identifiant de la boucle parente
64
-	 * - documents : Pour embed et img dans les textes
65
-	 * - session : Pour un cache sessionné par auteur
66
-	 * - niv : Niveau de tabulation
67
-	 */
68
-	public array $descr = [];
52
+    /**
53
+     * Description du squelette
54
+     *
55
+     * Sert pour la gestion d'erreur et la production de code dependant du contexte
56
+     *
57
+     * Peut contenir les index :
58
+     *
59
+     * - nom : Nom du fichier de cache
60
+     * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
61
+     * - sourcefile : Chemin du squelette
62
+     * - squelette : Code du squelette
63
+     * - id_mere : Identifiant de la boucle parente
64
+     * - documents : Pour embed et img dans les textes
65
+     * - session : Pour un cache sessionné par auteur
66
+     * - niv : Niveau de tabulation
67
+     */
68
+    public array $descr = [];
69 69
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Texte.php 1 patch
Indentation   +22 added lines, -22 removed lines patch added patch discarded remove patch
@@ -7,30 +7,30 @@
 block discarded – undo
7 7
  **/
8 8
 class Texte
9 9
 {
10
-	/** Type de noeud */
11
-	public string $type = 'texte';
10
+    /** Type de noeud */
11
+    public string $type = 'texte';
12 12
 
13
-	/** Le texte */
14
-	public string $texte;
13
+    /** Le texte */
14
+    public string $texte;
15 15
 
16
-	/**
17
-	 * Contenu avant le texte.
18
-	 *
19
-	 * Vide ou apostrophe simple ou double si le texte en était entouré
20
-	 *
21
-	 * @var string|array
22
-	 */
23
-	public $avant = '';
16
+    /**
17
+     * Contenu avant le texte.
18
+     *
19
+     * Vide ou apostrophe simple ou double si le texte en était entouré
20
+     *
21
+     * @var string|array
22
+     */
23
+    public $avant = '';
24 24
 
25
-	/**
26
-	 * Contenu après le texte.
27
-	 *
28
-	 * Vide ou apostrophe simple ou double si le texte en était entouré
29
-	 *
30
-	 * @var string|array
31
-	 */
32
-	public $apres = '';
25
+    /**
26
+     * Contenu après le texte.
27
+     *
28
+     * Vide ou apostrophe simple ou double si le texte en était entouré
29
+     *
30
+     * @var string|array
31
+     */
32
+    public $apres = '';
33 33
 
34
-	/** Numéro de ligne dans le code source du squelette */
35
-	public int $ligne = 0;
34
+    /** Numéro de ligne dans le code source du squelette */
35
+    public int $ligne = 0;
36 36
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Critere.php 1 patch
Indentation   +28 added lines, -28 removed lines patch added patch discarded remove patch
@@ -8,32 +8,32 @@
 block discarded – undo
8 8
  * Sous-noeud de Boucle
9 9
  **/
10 10
 class Critere {
11
-	/** Type de noeud */
12
-	public string $type = 'critere';
13
-
14
-	/** Opérateur (>, <, >=, IN, ...) */
15
-	public ?string $op;
16
-
17
-	/** Présence d'une négation (truc !op valeur) */
18
-	public bool $not = false;
19
-
20
-	/** Présence d'une exclusion (!truc op valeur) */
21
-	public string $exclus = '';
22
-
23
-	/** Présence d'une condition dans le critère (truc ?) */
24
-	public bool $cond = false;
25
-
26
-	/**
27
-	 * Paramètres du critère
28
-	 * - $param[0] : élément avant l'opérateur
29
-	 * - $param[1..n] : éléments après l'opérateur
30
-	 *
31
-	 * FIXME: type unique.
32
-	 * @var false|array
33
-	 *     - false: erreur de syntaxe
34
-	 */
35
-	public $param = [];
36
-
37
-	/** Numéro de ligne dans le code source du squelette */
38
-	public int $ligne = 0;
11
+    /** Type de noeud */
12
+    public string $type = 'critere';
13
+
14
+    /** Opérateur (>, <, >=, IN, ...) */
15
+    public ?string $op;
16
+
17
+    /** Présence d'une négation (truc !op valeur) */
18
+    public bool $not = false;
19
+
20
+    /** Présence d'une exclusion (!truc op valeur) */
21
+    public string $exclus = '';
22
+
23
+    /** Présence d'une condition dans le critère (truc ?) */
24
+    public bool $cond = false;
25
+
26
+    /**
27
+     * Paramètres du critère
28
+     * - $param[0] : élément avant l'opérateur
29
+     * - $param[1..n] : éléments après l'opérateur
30
+     *
31
+     * FIXME: type unique.
32
+     * @var false|array
33
+     *     - false: erreur de syntaxe
34
+     */
35
+    public $param = [];
36
+
37
+    /** Numéro de ligne dans le code source du squelette */
38
+    public int $ligne = 0;
39 39
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Polyglotte.php 1 patch
Indentation   +10 added lines, -10 removed lines patch added patch discarded remove patch
@@ -9,16 +9,16 @@
 block discarded – undo
9 9
  **/
10 10
 class Polyglotte
11 11
 {
12
-	/** Type de noeud */
13
-	public string $type = 'polyglotte';
12
+    /** Type de noeud */
13
+    public string $type = 'polyglotte';
14 14
 
15
-	/**
16
-	 * Tableau des traductions possibles classées par langue
17
-	 *
18
-	 * Tableau code de langue => texte
19
-	 */
20
-	public array $traductions = [];
15
+    /**
16
+     * Tableau des traductions possibles classées par langue
17
+     *
18
+     * Tableau code de langue => texte
19
+     */
20
+    public array $traductions = [];
21 21
 
22
-	/** Numéro de ligne dans le code source du squelette */
23
-	public int $ligne = 0;
22
+    /** Numéro de ligne dans le code source du squelette */
23
+    public int $ligne = 0;
24 24
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Contexte.php 1 patch
Indentation   +25 added lines, -25 removed lines patch added patch discarded remove patch
@@ -14,33 +14,33 @@
 block discarded – undo
14 14
  */
15 15
 class Contexte
16 16
 {
17
-	/**
18
-	 * Description du squelette
19
-	 *
20
-	 * Sert pour la gestion d'erreur et la production de code dependant du contexte
21
-	 *
22
-	 * Peut contenir les index :
23
-	 *
24
-	 * - nom : Nom du fichier de cache
25
-	 * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
26
-	 * - sourcefile : Chemin du squelette
27
-	 * - squelette : Code du squelette
28
-	 * - id_mere : Identifiant de la boucle parente
29
-	 * - documents : Pour embed et img dans les textes
30
-	 * - session : Pour un cache sessionné par auteur
31
-	 * - niv : Niveau de tabulation
32
-	 */
33
-	public array $descr = [];
17
+    /**
18
+     * Description du squelette
19
+     *
20
+     * Sert pour la gestion d'erreur et la production de code dependant du contexte
21
+     *
22
+     * Peut contenir les index :
23
+     *
24
+     * - nom : Nom du fichier de cache
25
+     * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
26
+     * - sourcefile : Chemin du squelette
27
+     * - squelette : Code du squelette
28
+     * - id_mere : Identifiant de la boucle parente
29
+     * - documents : Pour embed et img dans les textes
30
+     * - session : Pour un cache sessionné par auteur
31
+     * - niv : Niveau de tabulation
32
+     */
33
+    public array $descr = [];
34 34
 
35
-	/** Identifiant de la boucle */
36
-	public string $id_boucle = '';
35
+    /** Identifiant de la boucle */
36
+    public string $id_boucle = '';
37 37
 
38
-	/** Numéro de ligne dans le code source du squelette */
39
-	public int $ligne = 0;
38
+    /** Numéro de ligne dans le code source du squelette */
39
+    public int $ligne = 0;
40 40
 
41
-	/** Langue d'exécution */
42
-	public string $lang = '';
41
+    /** Langue d'exécution */
42
+    public string $lang = '';
43 43
 
44
-	/** Résultat de la compilation: toujours une expression PHP */
45
-	public string $code = '';
44
+    /** Résultat de la compilation: toujours une expression PHP */
45
+    public string $code = '';
46 46
 }
Please login to merge, or discard this patch.
ecrire/src/Compilateur/Noeud/Idiome.php 1 patch
Indentation   +81 added lines, -81 removed lines patch added patch discarded remove patch
@@ -7,85 +7,85 @@
 block discarded – undo
7 7
  **/
8 8
 class Idiome
9 9
 {
10
-	/** Type de noeud */
11
-	public string $type = 'idiome';
12
-
13
-	/** Clé de traduction demandée. Exemple 'item_oui' */
14
-	public string $nom_champ = '';
15
-
16
-	/** Module de langue où chercher la clé de traduction. Exemple 'medias' */
17
-	public string $module = '';
18
-
19
-	/** Arguments à passer à la chaîne */
20
-	public array $arg = [];
21
-
22
-	/**
23
-	 * Filtres à appliquer au résultat
24
-	 *
25
-	 *
26
-	 * * FIXME: type unique.
27
-	 * @var false|array
28
-	 *     - false: erreur de syntaxe
29
-	 */
30
-	public $param = [];
31
-
32
-	/** Source des filtres (compatibilité) (?) */
33
-	public array $fonctions = [];
34
-
35
-	/**
36
-	 * Inutilisé, propriété générique de l'AST
37
-	 *
38
-	 * @var string|array
39
-	 */
40
-	public $avant = '';
41
-
42
-	/**
43
-	 * Inutilisé, propriété générique de l'AST
44
-	 *
45
-	 * @var string|array
46
-	 */
47
-	public $apres = '';
48
-
49
-	/** Identifiant de la boucle */
50
-	public string $id_boucle = '';
51
-
52
-	/**
53
-	 * AST du squelette, liste de toutes les boucles
54
-	 *
55
-	 * @var Boucle[]
56
-	 */
57
-	public array $boucles;
58
-
59
-	/** Alias de table d'application de la requête ou nom complet de la table SQL */
60
-	public ?string $type_requete;
61
-
62
-	/** Résultat de la compilation: toujours une expression PHP */
63
-	public string $code = '';
64
-
65
-	/**
66
-	 * Interdire les scripts
67
-	 *
68
-	 * @see interdire_scripts()
69
-	 */
70
-	public bool $interdire_scripts = false;
71
-
72
-	/**
73
-	 * Description du squelette
74
-	 *
75
-	 * Sert pour la gestion d'erreur et la production de code dependant du contexte
76
-	 *
77
-	 * Peut contenir les index :
78
-	 * - nom : Nom du fichier de cache
79
-	 * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
80
-	 * - sourcefile : Chemin du squelette
81
-	 * - squelette : Code du squelette
82
-	 * - id_mere : Identifiant de la boucle parente
83
-	 * - documents : Pour embed et img dans les textes
84
-	 * - session : Pour un cache sessionné par auteur
85
-	 * - niv : Niveau de tabulation
86
-	 */
87
-	public array $descr = [];
88
-
89
-	/** Numéro de ligne dans le code source du squelette */
90
-	public int $ligne = 0;
10
+    /** Type de noeud */
11
+    public string $type = 'idiome';
12
+
13
+    /** Clé de traduction demandée. Exemple 'item_oui' */
14
+    public string $nom_champ = '';
15
+
16
+    /** Module de langue où chercher la clé de traduction. Exemple 'medias' */
17
+    public string $module = '';
18
+
19
+    /** Arguments à passer à la chaîne */
20
+    public array $arg = [];
21
+
22
+    /**
23
+     * Filtres à appliquer au résultat
24
+     *
25
+     *
26
+     * * FIXME: type unique.
27
+     * @var false|array
28
+     *     - false: erreur de syntaxe
29
+     */
30
+    public $param = [];
31
+
32
+    /** Source des filtres (compatibilité) (?) */
33
+    public array $fonctions = [];
34
+
35
+    /**
36
+     * Inutilisé, propriété générique de l'AST
37
+     *
38
+     * @var string|array
39
+     */
40
+    public $avant = '';
41
+
42
+    /**
43
+     * Inutilisé, propriété générique de l'AST
44
+     *
45
+     * @var string|array
46
+     */
47
+    public $apres = '';
48
+
49
+    /** Identifiant de la boucle */
50
+    public string $id_boucle = '';
51
+
52
+    /**
53
+     * AST du squelette, liste de toutes les boucles
54
+     *
55
+     * @var Boucle[]
56
+     */
57
+    public array $boucles;
58
+
59
+    /** Alias de table d'application de la requête ou nom complet de la table SQL */
60
+    public ?string $type_requete;
61
+
62
+    /** Résultat de la compilation: toujours une expression PHP */
63
+    public string $code = '';
64
+
65
+    /**
66
+     * Interdire les scripts
67
+     *
68
+     * @see interdire_scripts()
69
+     */
70
+    public bool $interdire_scripts = false;
71
+
72
+    /**
73
+     * Description du squelette
74
+     *
75
+     * Sert pour la gestion d'erreur et la production de code dependant du contexte
76
+     *
77
+     * Peut contenir les index :
78
+     * - nom : Nom du fichier de cache
79
+     * - gram : Nom de la grammaire du squelette (détermine le phraseur à utiliser)
80
+     * - sourcefile : Chemin du squelette
81
+     * - squelette : Code du squelette
82
+     * - id_mere : Identifiant de la boucle parente
83
+     * - documents : Pour embed et img dans les textes
84
+     * - session : Pour un cache sessionné par auteur
85
+     * - niv : Niveau de tabulation
86
+     */
87
+    public array $descr = [];
88
+
89
+    /** Numéro de ligne dans le code source du squelette */
90
+    public int $ligne = 0;
91 91
 }
Please login to merge, or discard this patch.
ecrire/src/Admin/Bouton.php 1 patch
Indentation   +52 added lines, -52 removed lines patch added patch discarded remove patch
@@ -7,57 +7,57 @@
 block discarded – undo
7 7
  * privée ou dans un de ses sous menus
8 8
  */
9 9
 class Bouton {
10
-	/** L'icone à mettre dans le bouton */
11
-	public string $icone;
12
-
13
-	/** Le nom de l'entrée d'i18n associé */
14
-	public string $libelle;
15
-
16
-	/** @var null|string L'URL de la page (null => ?exec=nom) */
17
-	public $url = null;
18
-
19
-	/** @var null|string|array Arguments supplementaires de l'URL */
20
-	public $urlArg = null;
21
-
22
-	/** @var null|string URL du javascript */
23
-	public $url2 = null;
24
-
25
-	/** @var null|string Pour ouvrir dans une fenetre a part */
26
-	public $target = null;
27
-
28
-	/** Sous-barre de boutons / onglets */
29
-	public array $sousmenu = [];
30
-
31
-	/** Position dans le menu */
32
-	public int $position = 0;
33
-
34
-	/** Entrée favorite (sa position dans les favoris) ? */
35
-	public int $favori = 0;
36
-
37
-
38
-	/**
39
-	 * Définit un bouton
40
-	 *
41
-	 * @param string $icone
42
-	 *    L'icone à mettre dans le bouton
43
-	 * @param string $libelle
44
-	 *    Le nom de l'entrée i18n associé
45
-	 * @param null|string $url
46
-	 *    L'URL de la page
47
-	 * @param null|string|array $urlArg
48
-	 *    Arguments supplémentaires de l'URL
49
-	 * @param null|string $url2
50
-	 *    URL du javascript
51
-	 * @param null|mixed $target
52
-	 *    Pour ouvrir une fenêtre à part
53
-	 */
54
-	public function __construct($icone, $libelle, $url = null, $urlArg = null, $url2 = null, $target = null) {
55
-		$this->icone = $icone;
56
-		$this->libelle = $libelle;
57
-		$this->url = $url;
58
-		$this->urlArg = $urlArg;
59
-		$this->url2 = $url2;
60
-		$this->target = $target;
61
-	}
10
+    /** L'icone à mettre dans le bouton */
11
+    public string $icone;
12
+
13
+    /** Le nom de l'entrée d'i18n associé */
14
+    public string $libelle;
15
+
16
+    /** @var null|string L'URL de la page (null => ?exec=nom) */
17
+    public $url = null;
18
+
19
+    /** @var null|string|array Arguments supplementaires de l'URL */
20
+    public $urlArg = null;
21
+
22
+    /** @var null|string URL du javascript */
23
+    public $url2 = null;
24
+
25
+    /** @var null|string Pour ouvrir dans une fenetre a part */
26
+    public $target = null;
27
+
28
+    /** Sous-barre de boutons / onglets */
29
+    public array $sousmenu = [];
30
+
31
+    /** Position dans le menu */
32
+    public int $position = 0;
33
+
34
+    /** Entrée favorite (sa position dans les favoris) ? */
35
+    public int $favori = 0;
36
+
37
+
38
+    /**
39
+     * Définit un bouton
40
+     *
41
+     * @param string $icone
42
+     *    L'icone à mettre dans le bouton
43
+     * @param string $libelle
44
+     *    Le nom de l'entrée i18n associé
45
+     * @param null|string $url
46
+     *    L'URL de la page
47
+     * @param null|string|array $urlArg
48
+     *    Arguments supplémentaires de l'URL
49
+     * @param null|string $url2
50
+     *    URL du javascript
51
+     * @param null|mixed $target
52
+     *    Pour ouvrir une fenêtre à part
53
+     */
54
+    public function __construct($icone, $libelle, $url = null, $urlArg = null, $url2 = null, $target = null) {
55
+        $this->icone = $icone;
56
+        $this->libelle = $libelle;
57
+        $this->url = $url;
58
+        $this->urlArg = $urlArg;
59
+        $this->url2 = $url2;
60
+        $this->target = $target;
61
+    }
62 62
 }
63 63
 
Please login to merge, or discard this patch.
ecrire/src/I18n/Description.php 1 patch
Indentation   +12 added lines, -12 removed lines patch added patch discarded remove patch
@@ -3,16 +3,16 @@
 block discarded – undo
3 3
 namespace Spip\I18n;
4 4
 
5 5
 class Description {
6
-	/** @var string code de langue (hors module) */
7
-	public $code;
8
-	/** @var string nom du module de langue */
9
-	public $module;
10
-	/** @var string langue de la traduction */
11
-	public $langue;
12
-	/** @var string traduction */
13
-	public $texte;
14
-	/** @var string var mode particulier appliqué ? */
15
-	public $mode;
16
-	/** @var bool Corrections des textes appliqué ? */
17
-	public $corrections = false;
6
+    /** @var string code de langue (hors module) */
7
+    public $code;
8
+    /** @var string nom du module de langue */
9
+    public $module;
10
+    /** @var string langue de la traduction */
11
+    public $langue;
12
+    /** @var string traduction */
13
+    public $texte;
14
+    /** @var string var mode particulier appliqué ? */
15
+    public $mode;
16
+    /** @var bool Corrections des textes appliqué ? */
17
+    public $corrections = false;
18 18
 }
Please login to merge, or discard this patch.