MED fichier
libmedimport.c
Aller à la documentation de ce fichier.
1 /* This file is part of MED.
2  *
3  * COPYRIGHT (C) 1999 - 2017 EDF R&D, CEA/DEN
4  * MED is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU Lesser General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  *
9  * MED is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public License
15  * along with MED. If not, see <http://www.gnu.org/licenses/>.
16  */
17 
18 /* L'utilisation des med_utils n'est pas optionelle
19  dans l'outil medimport, elle revet cependant deux
20  formes :
21  - Si -DWITH_EXCEPTION EXITIF renvoie une exception MEDerreur
22  - Sinon exécute l'instruction return */
23 
24 
25 #ifdef HAVE_STDBOOL_H
26 # include <stdbool.h>
27 #else
28 # ifndef HAVE__BOOL
29 # ifdef __cplusplus
30 typedef bool _Bool;
31 # else
32 # define _Bool signed char
33 # endif
34 # endif
35 # define bool _Bool
36 # define false 0
37 # define true 1
38 # define __bool_true_false_are_defined 1
39 #endif
40 
41 /* #ifdef __cplusplus */
42 /* extern "C" { */
43 /* #endif */
44 
45 /* Pour faciliter la detection autotools */
47 
48 /*Inclusion des .h de la version de la bibliothèque courante*/
49 #include <med_config.h>
50 #include <med.h>
51 #include <med_outils.h>
52 
53 #include <stdio.h>
54 #include <string.h>
55 
56 /*TODO : En attendant une conversion totale de l'outil libmedimport en 3.0*/
57 #include <2.3.6/med23v30.h>
58 #include <2.3.6/med23v30_proto.h>
59 #include "2.3.6/med23v30_misc.h"
60 
61 #ifdef PPRO_NT
62 # include <stdlib.h>
63 #else
64 # include <libgen.h>
65 #endif
66 
67 /* #ifdef __cplusplus */
68 /* } */
69 /* #endif */
70 
71 /*Inclusion des .h spécifiques à medimport */
72 
73 /* Interface publique de l'outil medimport */
74 /* MEDimport.h == MEDimport.hxx */
75 #include "MEDimport.h"
76 #include "MAJ_version.h"
77 
78 /* Interfaces privées à l'outil medimport */
79 #include "MAJ_21_22.h"
80 #include "MAJ_231_232.h"
81 #include "MAJ_236_300.h"
82 #include "MAJ_300_310.h"
83 #include "MAJ_310_320.h"
84 #include "MAJ_320_330.h"
85 
86 
87 #ifdef __cplusplus
88 extern "C" void _MEDmodeErreurVerrouiller(void);
89 #endif
90 
91 
92 
93 int MEDimport(char * filein, char * fileout) {
94 
95  med_idt fid, gid;
96  med_err ret;
97  med_int majeur, mineur, release;
98  med_bool hdfok=MED_FALSE;
99  med_bool medok=MED_FALSE;
100  char *_fileout,*tmp=NULL;
101  int _fileoutsize;
102  bool hasfileout=false;
103  char *commande;
104  med_int nprofil;
105  char chemin_profils[MED_PROFILE_GRP_SIZE+1];
106  char chemin_liens[MED_TAILLE_LIENS+1];
107  char version[9];
108  int MAJ_21_22 = 0, MAJ_231_232 = 0, MAJ_236_300 = 0, MAJ_300_310 = 0, MAJ_310_320 = 0, MAJ_320_330 = 0 ;
109 #ifdef PPRO_NT
110  char *drive, *dir, *ext;
111 #endif
112  unsigned char reponse='o';
113  med_bool _noversion=MED_FALSE;
114 
115  EXIT_IF(filein == NULL,"Le nom du fichier d'entrée est vide : ", filein);
116 
117  hasfileout = strcmp(fileout,"");
118  if ( hasfileout ) {
119  _fileoutsize = strlen(fileout);
120  _fileout = fileout;
121  } else {
122  _fileoutsize = strlen(filein)+strlen(PACKAGE_VERSION);
123  tmp = (char *) malloc(sizeof(char)*(_fileoutsize+1));
124  strcpy(tmp,filein);
125  strcat(tmp,PACKAGE_VERSION);
126 #ifdef PPRO_NT
127  _splitpath( tmp, drive, dir, _fileout, ext );
128 #else
129  _fileout = basename(tmp);
130 #endif
131  _fileoutsize = strlen(_fileout);
132 
133  }
134 
135  /* Test du format du fichier */
136 
137  ret = MEDfileCompatibility(filein,&hdfok,&medok);
138 
139  if (ret < 0 ) {
140  fprintf(stdout,">>> Attention le fichier %s ne contient pas de numéro de version. \n",filein);
141  fprintf(stdout,">>> Le fichier %s est supposé être en version 2.1.1. \n",filein);
142  /* PAs d'interactif dans une bibliothèque !*/
143 /* fprintf(stdout,">>> Voulez-vous essayer une conversion d'un fichier < 2.2 (o/n) ? "); */
144 /* scanf("%c",&reponse); */
145  if ( (reponse != 'o') && (reponse != 'O') && (reponse != 'y') && (reponse != 'Y') ) {
146  EXIT_IF(MEDfileCompatibility(filein,&hdfok,&medok) < 0,
147  "Erreur d'appel de MEDfileCompatibility : ", filein);
148  }
149  _noversion = MED_TRUE;
150  }
151  EXIT_IF( !hdfok ,
152  "Le fichier d'entrée n'est pas dans un format HDF compatible : ", filein);
153 
154 /* EXIT_IF( !medok , */
155 /* "MEDimport ne gère pas le format MED de ce fichier : ", filein); */
156 
157  /* Creation et ouverture du fichier que l'on va convertir au format MED actuel */
158  commande = (char *) malloc(sizeof(char)*(strlen("cp ")+strlen(filein)+
159  strlen(" ")+_fileoutsize + 4 +1 ) );
160  EXIT_IF(commande == NULL,NULL,NULL);
161  strcpy(commande,"cp \"");
162  strcat(commande,filein);
163  strcat(commande,"\" \"");
164  strcat(commande,_fileout);
165  strcat(commande,"\"");
166  fprintf(stdout,">>> Creation du fichier %s : %s \n",_fileout,commande);
167  system(commande);
168  free(commande);
169  commande = (char *) malloc(sizeof(char)*(strlen("chmod u+w \"") + _fileoutsize +1 +1 ) );
170  EXIT_IF(commande == NULL,NULL,NULL);
171  strcpy(commande,"chmod u+w \"");
172  strcat(commande,_fileout);
173  strcat(commande,"\"");
174  fprintf(stdout,">>> Chmod +w du fichier %s : %s \n",_fileout,commande);
175  system(commande);
176  free(commande);
177 
178  fid = MEDfileOpen(_fileout,MED_ACC_RDWR);
179  EXIT_IF(fid < 0,"Ouverture du fichier : ", _fileout);
180 
181  /* Verification du numero de version */
182  if (! _noversion)
183  ret = MEDfileNumVersionRd(fid,&majeur,&mineur,&release);
184  else {
185  ret=0;
186  majeur=2;
187  mineur=1;
188  release=1;
189  }
190  sprintf(version, IFORMAT"_"IFORMAT"_"IFORMAT, majeur, mineur, release);
191  EXIT_IF(ret < 0,"Lecture du numero de version de MED-fichier",NULL);
192  if (strcmp(version, "2_2_0") < 0)
193  MAJ_21_22 = 1;
194  if (strcmp(version, "2_3_2") < 0)
195  MAJ_231_232 = 1;
196  if (strcmp(version, "3_0_0") < 0)
197  MAJ_236_300 = 1;
198  if (strcmp(version, "3_1_0") < 0)
199  MAJ_300_310 = 1;
200  if (strcmp(version, "3_2_0") < 0)
201  MAJ_310_320 = 1;
202  if (strcmp(version, "3_3_0") < 0)
203  MAJ_320_330 = 1;
204 
205  /* Ne pas oublier que la version cible du fichier à convertir est celui de la bibliothèque. */
206  if (MAJ_320_330 == 0) {
207  fprintf(stdout,"Le fichier %s est déjà au bon format !!! \n",_fileout);
208  ret = MEDfileClose(fid);
209  EXIT_IF(ret < 0,"Fermeture du fichier",filein);
210  return 0;
211  }
212 
213  /* On avertit qu'on commence la conversion */
214  fprintf(stdout,">>> Lancement de la normalisation du fichier selon le format " PACKAGE_VERSION " ...\n");
215 
216  /* On inhibe le gestionnaire d'erreur HDF5 */
218 
219  /* Mise a jour du numero de version */
220  fprintf(stdout,"- Lancement de la mise à jour du numéro de version ... \n");
221  /* La mise à jour MAJ_version(fid); doit être différée pour que les majs des fichiers anciens
222  fonctionnent correctement*/
223  /* MAJ_version(fid); */
224  MAJ_write_version_num(fid,2,3,6);
225  fprintf(stdout," Numéro de version : ... OK ... \n");
226 
227  if (MAJ_21_22) {
228 
229  /* Mise a jour des maillages : type = MED_NON_STRUCTURE, description, ... */
230  fprintf(stdout,"- Lancement de la mise à jour des maillages (21_22)... \n");
231  MAJ_21_22_maillages(fid);
232  fprintf(stdout," Maillage(s) : ... OK ...\n");
233 
234  /* Mise a jour des champs */
235  fprintf(stdout,"- Lancement de la mise à jour des champs de résultats (21_22)... \n");
236  MAJ_21_22_champs(fid);
237  fprintf(stdout," Champs(s) : ... OK ...\n");
238 
239  /* Mise a jour des profils eventuels */
240  nprofil = MEDnProfil(fid);
241  if (nprofil > 0) {
242  fprintf(stdout,"- Lancement de la mise à jour des profils (21_22)... \n");
243  MAJ_21_22_profils(fid,nprofil);
244  fprintf(stdout," Profils(s) : ... OK ...\n");
245  } else {
246  strncpy(chemin_profils,MED_PROFILE_GRP,MED_PROFILE_GRP_SIZE-1);
247  chemin_profils[MED_PROFILE_GRP_SIZE-1] = '\0';
248  gid = _MEDdatagroupCreer(fid,chemin_profils);
249  EXIT_IF(gid < 0,"Creation du groupe HDF sur les profils",chemin_profils);
250  ret = _MEDdatagroupFermer(gid);
251  EXIT_IF(ret < 0,"Fermeture du groupe HDF sur les profils",chemin_profils);
252  }
253 
254  /* On cree le groupe HDF pour les liens */
255  strncpy(chemin_liens,MED_LIENS,MED_TAILLE_LIENS-1);
256  chemin_liens[MED_TAILLE_LIENS-1] = '\0';
257  gid = _MEDdatagroupCreer(fid,chemin_liens);
258  EXIT_IF(gid < 0,"Creation du groupe HDF sur les liens",chemin_liens);
259  ret = _MEDdatagroupFermer(gid);
260  EXIT_IF(ret < 0,"Fermeture du groupe HDF sur les liens",chemin_liens);
261  }
262 
263  if (MAJ_231_232) {
264  /* Mise a jour des champs */
265  fprintf(stdout,"- Lancement de la mise à jour des champs de résultats (231_232)... \n");
266  MAJ_231_232_champs(fid);
267  fprintf(stdout," Champs(s) : ... OK ...\n");
268  fprintf(stdout,"- Lancement de la mise à jour des noms de maillages (231_232)... \n");
270  fprintf(stdout," Noms(s) de maillage(s): ... OK ...\n");
271  }
272 
273  if (MAJ_236_300) {
274  /* Le système de cache de version a été developpé à partir de la 3.0*/
275  /* Initialise le cache sur une 2.3.6 (cas d'absence d'INFO)*/
276  _MEDfileVersion(fid);
277 
278  /* Mise a jour des champs */
279  fprintf(stdout,"- Lancement de la mise à jour des champs de résultats (236_300)... \n");
280  MAJ_236_300_champs(fid);
281  fprintf(stdout," Champs(s) : ... OK ...\n");
282 
283  /* MAJ_version(fid); */
284 
285  fprintf(stdout,"- Lancement de la mise à jour des maillages (236_300)... \n");
287  fprintf(stdout," Maillage(s): ... OK ...\n");
288 
289  /* MAJ_version(fid); */
290 
291  }
292 
293  if (MAJ_300_310) {
294  /* Le système de cache de version a été developpé à partir de la 3.0*/
295  /* Initialise le cache sur une 3.0.8 (cas d'absence d'INFO)*/
296  /* s'il n'a pas déjà été instanciée ds les MAJ précédentes */
297  MAJ_write_version_num(fid,3,0,8);
298  _MEDfileVersion(fid);
299  /* Si le cache était dèjà instancié, met à jour le cache */
300  MAJ_version_num(fid,3,0,8);
301 
302  /* Mise a jour des champs */
303  fprintf(stdout,"- Lancement de la mise à jour des champs de résultats (300_310) ... \n");
304  MAJ_300_310_champs(fid);
305  fprintf(stdout," Champs(s) : ... OK ...\n");
306 
307 
308  }
309 
310  if (MAJ_310_320) {
311  /* Le système de cache de version a été developpé à partir de la 3.0*/
312  /* Initialise le cache sur une 3.1.0 (cas d'absence d'INFO)*/
313  /* s'il n'a pas été déjà été instanciée ds les MAJ_ précédentes */
314  MAJ_write_version_num(fid,3,1,0);
315  _MEDfileVersion(fid);
316  /* Si le cache était dèjà instancié, met à jour le cache */
317  MAJ_version_num(fid,3,1,0);
318 
319  /* Mise a jour des familles/groupes */
320  fprintf(stdout,"- Lancement de la mise à jour des familles/groupes (310_320) ... \n");
322  fprintf(stdout," Famille(s)/Groupe(s) : ... OK ...\n");
323  }
324 
325  if (MAJ_320_330) {
326  /* Le système de cache de version a été developpé à partir de la 3.0*/
327  /* Initialise le cache sur une 3.2.1 (cas d'absence d'INFO)*/
328  /* s'il n'a pas été déjà été instanciée ds les MAJ_ précédentes */
329  MAJ_write_version_num(fid,3,2,1);
330  _MEDfileVersion(fid);
331  /* Si le cache était dèjà instancié, met à jour le cache */
332  MAJ_version_num(fid,3,2,1);
333 
334  /* Mise a jour des familles/groupes */
335  fprintf(stdout,"- Lancement de la mise à jour des champs entiers (321_330) ... \n");
336  MAJ_320_330_champs(fid);
337  fprintf(stdout," Champs entiers : ... OK ...\n");
338  }
339 
340  /* A l'écriture d'une nouvelle version de MAJ ex 310_320,
341  il est necessaire de revisiter les appels à MAJ_version(fid) pour
342  les remplacer par les appels MAJ_version(fid,3,1,Lastest31z) */
343 
344  MAJ_version(fid);
346 
347  /* Fermeture du fichier */
348  ret = MEDfileClose(fid);
349  EXIT_IF(ret < 0,"Fermeture du fichier",_fileout);
350 
351  /* On avertit que c'est fini */
352  fprintf(stdout,">>> Conversion du fichier %s au format MED V" PACKAGE_VERSION " terminée\n",
353  _fileout);
354 
355  /* On libere la memoire */
356  if (!hasfileout) free(tmp);
357 
358  return 0;
359 }
360 
MEDC_EXPORT med_err _MEDdatagroupFermer(med_idt id)
#define MED_PROFILE_GRP
Definition: med_outils.h:224
int med_int
Definition: med.h:335
MEDC_EXPORT med_err MEDfileNumVersionRd(const med_idt fid, med_int *const major, med_int *const minor, med_int *const release)
Lecture du numéro de version de la bibliothèque MED utilisée pour créer le fichier.
#define _Bool
Definition: libmedimport.c:32
#define MED_NUM_MINEUR
Definition: med.h:62
void MAJ_300_310_champs(med_idt fid)
hid_t med_idt
Definition: med.h:324
void MAJ_310_320_familles(med_idt fid)
MEDC_EXPORT med_idt _MEDdatagroupCreer(med_idt pid, const char *const nom)
void MAJ_version(med_idt fid)
Definition: MAJ_version.c:60
void MAJ_231_232_maillages(med_idt fid)
#define MED_LIENS
Definition: med_outils.h:238
#define MED_TAILLE_LIENS
Definition: med_outils.h:239
void MAJ_21_22_profils(med_idt fid, med_int nprofil)
int MEDimport(char *filein, char *fileout)
Definition: libmedimport.c:93
void MAJ_21_22_champs(med_idt fid)
void MAJ_236_300_maillages(med_idt fid)
void MAJ_320_330_champs(med_idt fid)
void MAJ_236_300_champs(med_idt fid)
Definition: med.h:255
#define MED_NUM_MAJEUR
Definition: med.h:61
MEDC_EXPORT med_file_version _MEDfileVersion(const med_idt oid)
int HAVE_MEDimport
Definition: libmedimport.c:46
#define MED_PROFILE_GRP_SIZE
Definition: med_outils.h:225
herr_t med_err
Definition: med.h:325
#define EXIT_IF(expression, message, arg)
Definition: med_utils.h:335
#define MED_NUM_RELEASE
Definition: med.h:63
MEDC_EXPORT void _MEDmodeErreurVerrouiller(void)
void MAJ_21_22_maillages(med_idt fid)
void MAJ_write_version_num(med_idt fid, const int majeur, const int mineur, const int release)
Definition: MAJ_version.c:36
void MAJ_231_232_champs(med_idt fid)
MEDC_EXPORT med_idt MEDfileOpen(const char *const filename, const med_access_mode accessmode)
Ouverture d&#39;un fichier MED.
Definition: MEDfileOpen.c:41
med_bool
Definition: med.h:255
Definition: med.h:255
MEDC_EXPORT med_err MEDfileClose(med_idt fid)
Fermeture d&#39;un fichier MED.
Definition: MEDfileClose.c:30
#define PACKAGE_VERSION
Definition: med_config.h:161
void MAJ_version_num(med_idt fid, const int majeur, const int mineur, const int release)
Definition: MAJ_version.c:23
#define IFORMAT
Definition: med_utils.h:144
MEDC_EXPORT med_err MEDfileCompatibility(const char *const filename, med_bool *const hdfok, med_bool *const medok)
Vérification de la compatibilité d&#39;un fichier avec HDF et MED.