Subversion Repositories eFlore/Projets.eflore-projets

Rev

Rev 487 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
469 jpm 1
<?php
2
class Index {
3
 
4
	const DOSSIER_V0 = '../../../donnees/coste/0.00/';
5
	const DOSSIER_V2 = '../../../donnees/coste/2.00/';
6
 
7
	private $conteneur = null;
8
	private $outils = null;
9
	private $messages = null;
487 jpm 10
	private $generateur = null;
469 jpm 11
	private $dossierBase = '';
12
	private $spIndex = array();
13
	private $supraSpIndex = array();
487 jpm 14
	private $imgIndex = array();
469 jpm 15
	private $indexFinal = array();
16
	private $tableauParDefaut = array();
471 jpm 17
	private $nbreTaxonInf = array();
469 jpm 18
	private $enteteFinal = array(
19
		'num_nom',
20
		'num_nom_retenu',
21
		'num_tax_sup',
22
		'rang',
23
		'nom_sci',
487 jpm 24
		'nom_supra_generique',
25
		'genre',
26
		'epithete_infra_generique',
27
		'epithete_sp',
28
		'type_epithete',
29
		'epithete_infra_sp',
30
		'cultivar_groupe',
31
		'cultivar',
32
		'nom_commercial',
469 jpm 33
		'auteur',
34
		'annee',
35
		'biblio_origine',
487 jpm 36
		'notes',
37
		'nom_addendum',
469 jpm 38
		'nom_francais',
39
		'nom_coste',
40
		'auteur_coste',
41
		'biblio_coste',
42
		'num_nom_coste',
43
		'num_nom_retenu_coste',
44
		'num_tax_sup_coste',
45
		'synonymie_coste',
46
		'tome',
47
		'page',
471 jpm 48
		'nbre_taxons',
487 jpm 49
		'flore_bdtfx_nn',
50
		'flore_bdtfx_nt',
471 jpm 51
		'image',
487 jpm 52
		'image_auteur',
471 jpm 53
		'page_wiki_dsc',
487 jpm 54
		'page_wiki_cle',
55
		'nom_sci_html');
469 jpm 56
 
57
	public function __construct(Conteneur $conteneur) {
58
		mb_internal_encoding('UTF-8');
59
		setlocale(LC_ALL, 'fr_FR.UTF-8');
60
		$this->conteneur = $conteneur;
61
		$this->outils = $conteneur->getOutils();
62
		$this->messages = $conteneur->getMessages();
487 jpm 63
		$this->generateur = $conteneur->getGenerateurNomSciHtml();
469 jpm 64
		$this->dossierBase = dirname(__FILE__).'/';
65
	}
66
 
67
	public function fusionnerIndex() {
68
		$this->chargerIndexSp();
69
		$this->chargerIndexSupraSp();
70
		$this->initialiserTableauLigneIndexFinal();
71
		$this->creerIndexFinal();
72
		$this->ajouterChampsDansIndexFinal();
487 jpm 73
		$this->ajouteurAuteurImage();
74
		$this->decomposerNomSci();
75
		$this->ajouteurNomSciHtml();
493 jpm 76
		$this->ajouterCorrections();
469 jpm 77
		$this->creerFichierCsvIndexFinal();
78
	}
79
 
80
	private function chargerIndexSp() {
81
		$spIndexFichier = $this->dossierBase.self::DOSSIER_V0.'index_general_sp.tsv';
476 jpm 82
		$index = $this->outils->transformerTxtTsvEnTableau($spIndexFichier);
469 jpm 83
		$index = $this->reindexerParNumNomCoste($index);
84
		foreach ($index as $numNomCoste => $infos) {
85
			$numTaxSup = '';
86
			if ($infos['num_nom_coste'] == $infos['num_nom_retenu_coste']) {
87
				$numTaxSup = $infos['num_tax_sup_coste'];
88
			} else {
89
				$infosNomRetenu = $index[$infos['num_nom_retenu_coste']];
90
				$numTaxSup = $infosNomRetenu['num_tax_sup_coste'];
91
			}
92
			$this->spIndex[$numTaxSup][] = $infos;
93
		}
94
	}
95
 
96
	private function reindexerParNumNomCoste($index) {
97
		$nouvelIndex = array();
98
		foreach ($index as $infos) {
99
			$nouvelIndex[$infos['num_nom_coste']] = $infos;
100
		}
101
		return $nouvelIndex;
102
	}
103
 
104
	private function chargerIndexSupraSp() {
105
		$infraSpIndexFichier = $this->dossierBase.self::DOSSIER_V0.'index_general.tsv';
476 jpm 106
		$this->supraSpIndex = $this->outils->transformerTxtTsvEnTableau($infraSpIndexFichier);
469 jpm 107
		foreach ($this->supraSpIndex as $cle => $infos) {
108
			$this->supraSpIndex[$cle]['num_nom_retenu_coste'] = $infos['num_nom_coste'];
109
		}
110
	}
111
 
112
	private function initialiserTableauLigneIndexFinal() {
113
		$this->tableauParDefaut = array();
114
		foreach ($this->enteteFinal as $cle) {
115
			$this->tableauParDefaut[$cle] = '';
116
		}
117
	}
118
 
119
	private function creerIndexFinal() {
120
		foreach ($this->supraSpIndex as $infos) {
121
			$this->ajouterDansIndexFinal($infos);
122
			if (preg_match('/^G[0-9]+$/', $infos['num_nom_coste'])) {
123
				foreach ($this->spIndex[$infos['num_nom_coste']] as $infosSp) {
124
					$this->ajouterDansIndexFinal($infosSp);
125
				}
126
			}
127
		}
128
	}
129
 
130
	private function ajouterDansIndexFinal($infos) {
131
		$infos = array_merge($this->tableauParDefaut, $infos);
471 jpm 132
		$infos['num_nom'] = (count($this->indexFinal) + 1);
469 jpm 133
		$this->indexFinal[$infos['num_nom_coste']] = $infos;
134
	}
135
 
136
	private function ajouterChampsDansIndexFinal() {
471 jpm 137
		$this->genererNbreTaxons();
469 jpm 138
		foreach ($this->indexFinal as $nnc => $infos) {
139
			if ($infos['num_nom_coste'] == $infos['num_nom_retenu_coste']) {
140
				$infos['num_nom_retenu'] = $infos['num_nom'];
141
				if ($nnc != 'R') {
142
					$nomSuperieur = $this->indexFinal[$infos['num_tax_sup_coste']];
143
					$infos['num_tax_sup'] = $nomSuperieur['num_nom'];
144
				}
471 jpm 145
				$nomRetenu = $infos;
469 jpm 146
			} else {
147
				$nomRetenu = $this->indexFinal[$infos['num_nom_retenu_coste']];
148
				$infos['num_nom_retenu'] = $nomRetenu['num_nom'];
149
			}
471 jpm 150
			$infos['image'] = $this->obtenirNomFichierImg($nomRetenu);
151
			$infos['nbre_taxons'] = $this->obtenirNbreTaxon($infos);
476 jpm 152
			$nomRetenu['nbre_taxons'] = $infos['nbre_taxons'];
471 jpm 153
			$infos['page_wiki_dsc'] = $this->genererPageWikiDsc($nomRetenu);
154
			$infos['page_wiki_cle'] = $this->genererPageWikiCle($nomRetenu);
155
 
469 jpm 156
			$this->indexFinal[$nnc] = $infos;
157
		}
158
	}
159
 
471 jpm 160
	private function genererNbreTaxons() {
161
		foreach ($this->indexFinal as $infos) {
162
			if ($infos['num_tax_sup_coste'] != '') {
163
				if (isset($this->nbreTaxonInf[$infos['num_tax_sup_coste']])) {
164
					$this->nbreTaxonInf[$infos['num_tax_sup_coste']] += 1;
165
				} else {
166
					$this->nbreTaxonInf[$infos['num_tax_sup_coste']] = 1;
167
				}
168
			}
169
		}
170
	}
171
 
172
	private function genererPageWikiDsc($infos) {
173
		$prefixe = $this->genererPrefixePage($infos);
487 jpm 174
		if ($infos['rang'] == '180') {
175
			$nomSci = str_replace(' ', '', ucwords(strtolower($infos['nom_coste'])));
176
		} else {
177
			$nomSci = str_replace(' ', '', ucwords(strtolower($infos['nom_sci'])));
178
		}
471 jpm 179
		$pageWiki = $prefixe.$nomSci;
180
		return $pageWiki;
181
	}
182
 
183
	private function genererPageWikiCle($infos) {
184
		$pageWiki = '';
185
		if ($infos['nbre_taxons'] > 1) {
186
			$prefixe = $this->genererPrefixePage($infos);
487 jpm 187
			if ($infos['rang'] == '20') {
188
				$pageWiki = $prefixe.'TabClaEtEmb';
189
			} elseif ($infos['rang'] == '40' && ($infos['num_nom_coste'] == 'E2' || $infos['num_nom_coste'] == 'E3')) {
190
				$pageWiki = $prefixe.'TabFam';
191
			} else if ($infos['rang'] == '80') {
192
				$pageWiki = $prefixe.'TabFam';
193
			} else if ($infos['rang'] == '180') {
471 jpm 194
				$pageWiki = $prefixe.'TabGen';
195
			} else if ($infos['rang'] == '220') {
196
				$pageWiki = $prefixe.'TabSp';
197
			}
198
		}
199
		return $pageWiki;
200
	}
201
 
202
	private function genererPrefixePage($infos) {
203
		$prefixe = '';
204
		$num = preg_replace('/^[a-z]*([0-9.]+)$/i', '$1', $infos['num_nom_coste']);
205
		if (preg_match('/^([0-9]+)[.][0-9]+$/i', $infos['num_nom_coste'], $match)) {
206
			$num = sprintf('%04s', $match[1]);
487 jpm 207
		} else if ($infos['rang'] == 20 ) {
208
			$num = '';
471 jpm 209
		} else if ($infos['rang'] < 80 ) {
210
			$num = sprintf('%02s', $num);
211
		} else if ($infos['rang'] < 290 ) {
212
			$num = sprintf('%03s', $num);
213
		} else {
214
			$num = sprintf('%04s', $num);
215
		}
216
		$rangsTxt = array('20' => 'Reg', '40' => 'Emb', '80' => 'Cla', '180' => 'Fam', '220' => 'Gen', '290' => 'Esp', '340' => 'Var');
217
		$rang = $rangsTxt[$infos['rang']];
218
 
219
		$prefixe = $rang.$num;
220
		return $prefixe;
221
	}
222
 
223
	private function obtenirNbreTaxon($infos) {
224
		$nbre = '';
487 jpm 225
		if (isset($this->nbreTaxonInf[$infos['num_nom_coste']])) {
226
			$nbre = $this->nbreTaxonInf[$infos['num_nom_coste']];
471 jpm 227
		}
228
		return $nbre;
229
	}
230
 
231
	private function obtenirNomFichierImg($infos) {
232
		$img = '';
233
		if ($infos['rang'] == '290' && ($infos['num_nom'] == $infos['num_nom_retenu'])) {
234
			$img = $infos['num_nom_coste'].'.png';
235
		}
236
		return $img;
237
	}
238
 
487 jpm 239
	private function ajouteurAuteurImage() {
240
		$this->chargerAuteurImg();
241
		foreach ($this->indexFinal as $nnc => $infos) {
242
			$infos['image_auteur'] = $this->imgIndex[$infos['image']];
243
			$this->indexFinal[$nnc] = $infos;
244
		}
245
	}
246
 
247
	private function chargerAuteurImg() {
248
		$imgIndexFichier = $this->dossierBase.self::DOSSIER_V0.'coste_images_auteur_correspondance_bdnff.tsv';
249
		$index = $this->outils->transformerTxtTsvEnTableau($imgIndexFichier);
250
		foreach ($index as $infos) {
251
			$id = $infos['id_image'];
252
			$this->imgIndex[$id] = $infos['auteur'];
253
		}
254
	}
255
 
256
	private function decomposerNomSci() {
257
		$majuscule = "[ÆŒA-Z]";
258
		$epithete = "[æœïa-z-]+";
259
		foreach ($this->indexFinal as $nnc => $infos) {
260
			$id = $infos['num_nom_coste'];
261
			$nomSci = $infos['nom_sci'];
262
			$rang = $infos['rang'];
263
			if ($rang < 220) {
264
				$infos['nom_supra_generique'] = $nomSci;
265
			} else if ($rang == 220) {
266
				$infos['genre'] = $nomSci;
267
			} else if ($rang == 290) {
268
				if (preg_match("/^($majuscule$epithete) ($epithete)$/", $nomSci, $match)) {
269
					$infos['genre'] = $match[1];
270
					$infos['epithete_sp'] = $match[2];
271
				} else {
272
					$this->messages->traiterErreur("Le nom $nomSci ($id) de rang $rang n'est pas standard.");
273
				}
274
			} else if ($rang == 340) {
275
				if (preg_match("/^($majuscule$epithete) ($epithete) (var[.]) ($epithete)$/", $nomSci, $match)) {
276
					$infos['genre'] = $match[1];
277
					$infos['epithete_sp'] = $match[2];
278
					$infos['type_epithete'] = $match[3];
279
					$infos['epithete_infra_sp'] = $match[4];
280
				} else {
281
					$this->messages->traiterErreur("Le nom $nomSci ($id) de rang $rang n'est pas standard.");
282
				}
283
			}
284
 
285
			$this->indexFinal[$nnc] = $infos;
286
			$this->messages->afficherAvancement("Décomposition des noms scientifiques en cours");
287
		}
288
		echo "\n";
289
	}
290
 
291
	private function ajouteurNomSciHtml() {
292
		foreach ($this->indexFinal as $nnc => $infos) {
293
			$this->indexFinal[$nnc]['nom_sci_html'] = $this->generateur->genererNomSciHtml($infos);
294
			$this->messages->afficherAvancement("Création des noms scientifiques HTML en cours");
295
		}
296
		echo "\n";
297
	}
298
 
493 jpm 299
	private function ajouterCorrections() {
300
		$correctionsFichier = $this->dossierBase.self::DOSSIER_V2.'coste_v2_00_corrections.tsv';
301
		$corrections = $this->outils->transformerTxtTsvEnTableau($correctionsFichier);
302
		foreach ($corrections as $infos) {
303
			$nnc = $infos['num_nom_coste'];
304
			$infosACorriger = $this->indexFinal[$nnc];
305
			foreach ($corrections as $champ => $valeur) {
306
				$infosACorriger[$champ] = $valeur;
307
			}
308
			$this->indexFinal[$nnc] = $infosACorriger;
309
		}
310
	}
311
 
469 jpm 312
	private function creerFichierCsvIndexFinal() {
313
		$lignes = array();
314
		array_unshift($this->indexFinal, $this->enteteFinal);
315
		foreach ($this->indexFinal as $infos) {
493 jpm 316
			$lignes[] = implode("\t", $infos);
469 jpm 317
		}
318
 
319
		$txt = '';
320
		$txt = implode("\n", $lignes);
321
 
478 jpm 322
		$fichierTsvIndexFinal = $this->dossierBase.self::DOSSIER_V2.'coste_v2_00.tsv';
469 jpm 323
		file_put_contents($fichierTsvIndexFinal, $txt);
324
	}
325
}
326
?>