00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025 #ifdef HAVE_STDBOOL_H
00026 # include <stdbool.h>
00027 #else
00028 # ifndef HAVE__BOOL
00029 # ifdef __cplusplus
00030 typedef bool _Bool;
00031 # else
00032 # define _Bool signed char
00033 # endif
00034 # endif
00035 # define bool _Bool
00036 # define false 0
00037 # define true 1
00038 # define __bool_true_false_are_defined 1
00039 #endif
00040
00041
00042
00043
00044
00045
00046 int HAVE_MEDimport=1;
00047
00048
00049 #include <med_config.h>
00050 #include <med.h>
00051 #include <med_outils.h>
00052
00053 #include <stdio.h>
00054 #include <string.h>
00055
00056
00057 #include <2.3.6/med23v30.h>
00058 #include <2.3.6/med23v30_proto.h>
00059 #include "2.3.6/med23v30_misc.h"
00060
00061 #ifdef PPRO_NT
00062 # include <stdlib.h>
00063 #else
00064 # include <libgen.h>
00065 #endif
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075 #include "MEDimport.h"
00076 #include "MAJ_version.h"
00077
00078
00079 #include "MAJ_21_22.h"
00080 #include "MAJ_231_232.h"
00081 #include "MAJ_236_300.h"
00082 #include "MAJ_300_310.h"
00083
00084
00085 #ifdef __cplusplus
00086 extern "C" void _MEDmodeErreurVerrouiller(void);
00087 #endif
00088
00089
00090
00091 int MEDimport(char * filein, char * fileout) {
00092
00093 med_idt fid, gid;
00094 med_err ret;
00095 med_int majeur, mineur, release;
00096 med_bool hdfok=MED_FALSE;
00097 med_bool medok=MED_FALSE;
00098 char *_fileout,*tmp=NULL;
00099 int _fileoutsize;
00100 bool hasfileout=false;
00101 char *commande;
00102 med_int nprofil;
00103 char chemin_profils[MED_TAILLE_PROFILS+1];
00104 char chemin_liens[MED_TAILLE_LIENS+1];
00105 char version[9];
00106 int MAJ_21_22 = 0, MAJ_231_232 = 0, MAJ_236_300 = 0, MAJ_300_310 = 0 ;
00107 #ifdef PPRO_NT
00108 char *drive, *dir, *ext;
00109 #endif
00110 unsigned char reponse='o';
00111 med_bool _noversion=MED_FALSE;
00112
00113 EXIT_IF(filein == NULL,"Le nom du fichier d'entrée est vide : ", filein);
00114
00115 hasfileout = strcmp(fileout,"");
00116 if ( hasfileout ) {
00117 _fileoutsize = strlen(fileout);
00118 _fileout = fileout;
00119 } else {
00120 _fileoutsize = strlen(filein)+strlen(PACKAGE_VERSION);
00121 tmp = (char *) malloc(sizeof(char)*(_fileoutsize+1));
00122 strcpy(tmp,filein);
00123 strcat(tmp,PACKAGE_VERSION);
00124 #ifdef PPRO_NT
00125 _splitpath( tmp, drive, dir, _fileout, ext );
00126 #else
00127 _fileout = basename(tmp);
00128 #endif
00129 _fileoutsize = strlen(_fileout);
00130
00131 }
00132
00133
00134
00135 ret = MEDfileCompatibility(filein,&hdfok,&medok);
00136
00137 if (ret < 0 ) {
00138 fprintf(stdout,">>> Attention le fichier %s ne contient pas de numéro de version. \n",filein);
00139 fprintf(stdout,">>> Le fichier %s est supposé être en version 2.1.1. \n",filein);
00140
00141
00142
00143 if ( (reponse != 'o') && (reponse != 'O') && (reponse != 'y') && (reponse != 'Y') ) {
00144 EXIT_IF(MEDfileCompatibility(filein,&hdfok,&medok) < 0,
00145 "Erreur d'appel de MEDfileCompatibility : ", filein);
00146 }
00147 _noversion = MED_TRUE;
00148 }
00149 EXIT_IF( !hdfok ,
00150 "Le fichier d'entrée n'est pas dans un format HDF compatible : ", filein);
00151
00152
00153
00154
00155
00156 commande = (char *) malloc(sizeof(char)*(strlen("cp ")+strlen(filein)+
00157 strlen(" ")+_fileoutsize + 4 +1 ) );
00158 EXIT_IF(commande == NULL,NULL,NULL);
00159 strcpy(commande,"cp \"");
00160 strcat(commande,filein);
00161 strcat(commande,"\" \"");
00162 strcat(commande,_fileout);
00163 strcat(commande,"\"");
00164 fprintf(stdout,">>> Creation du fichier %s : %s \n",_fileout,commande);
00165 system(commande);
00166 free(commande);
00167 commande = (char *) malloc(sizeof(char)*(strlen("chmod u+w \"") + _fileoutsize +1 +1 ) );
00168 EXIT_IF(commande == NULL,NULL,NULL);
00169 strcpy(commande,"chmod u+w \"");
00170 strcat(commande,_fileout);
00171 strcat(commande,"\"");
00172 fprintf(stdout,">>> Chmod +w du fichier %s : %s \n",_fileout,commande);
00173 system(commande);
00174 free(commande);
00175
00176 fid = MEDfileOpen(_fileout,MED_ACC_RDWR);
00177 EXIT_IF(fid < 0,"Ouverture du fichier : ", _fileout);
00178
00179
00180 if (! _noversion)
00181 ret = MEDfileNumVersionRd(fid,&majeur,&mineur,&release);
00182 else {
00183 ret=0;
00184 majeur=2;
00185 mineur=1;
00186 release=1;
00187 }
00188 sprintf(version, IFORMAT"_"IFORMAT"_"IFORMAT, majeur, mineur, release);
00189 EXIT_IF(ret < 0,"Lecture du numero de version de MED-fichier",NULL);
00190 if (strcmp(version, "2_2_0") < 0)
00191 MAJ_21_22 = 1;
00192 if (strcmp(version, "2_3_2") < 0)
00193 MAJ_231_232 = 1;
00194 if (strcmp(version, "3_0_0") < 0)
00195 MAJ_236_300 = 1;
00196 if (strcmp(version, "3_1_0") < 0)
00197 MAJ_300_310 = 1;
00198
00199
00200 if (MAJ_300_310 == 0) {
00201 fprintf(stdout,"Le fichier %s est déjà au bon format !!! \n",_fileout);
00202 ret = MEDfileClose(fid);
00203 EXIT_IF(ret < 0,"Fermeture du fichier",filein);
00204 return 0;
00205 }
00206
00207
00208 fprintf(stdout,">>> Lancement de la normalisation du fichier selon le format " PACKAGE_VERSION " ...\n");
00209
00210
00211 _MEDmodeErreurVerrouiller();
00212
00213
00214 fprintf(stdout,"- Lancement de la mise à jour du numéro de version ... \n");
00215
00216
00217
00218 MAJ_write_version_num(fid,2,3,6);
00219 fprintf(stdout," Numéro de version : ... OK ... \n");
00220
00221 if (MAJ_21_22) {
00222
00223
00224 fprintf(stdout,"- Lancement de la mise à jour des maillages (21_22)... \n");
00225 MAJ_21_22_maillages(fid);
00226 fprintf(stdout," Maillage(s) : ... OK ...\n");
00227
00228
00229 fprintf(stdout,"- Lancement de la mise à jour des champs de résultats (21_22)... \n");
00230 MAJ_21_22_champs(fid);
00231 fprintf(stdout," Champs(s) : ... OK ...\n");
00232
00233
00234 nprofil = MEDnProfil(fid);
00235 if (nprofil > 0) {
00236 fprintf(stdout,"- Lancement de la mise à jour des profils (21_22)... \n");
00237 MAJ_21_22_profils(fid,nprofil);
00238 fprintf(stdout," Profils(s) : ... OK ...\n");
00239 } else {
00240 strncpy(chemin_profils,MED_PROFILS,MED_TAILLE_PROFILS-1);
00241 chemin_profils[MED_TAILLE_PROFILS-1] = '\0';
00242 gid = _MEDdatagroupCreer(fid,chemin_profils);
00243 EXIT_IF(gid < 0,"Creation du groupe HDF sur les profils",chemin_profils);
00244 ret = _MEDdatagroupFermer(gid);
00245 EXIT_IF(ret < 0,"Fermeture du groupe HDF sur les profils",chemin_profils);
00246 }
00247
00248
00249 strncpy(chemin_liens,MED_LIENS,MED_TAILLE_LIENS-1);
00250 chemin_liens[MED_TAILLE_LIENS-1] = '\0';
00251 gid = _MEDdatagroupCreer(fid,chemin_liens);
00252 EXIT_IF(gid < 0,"Creation du groupe HDF sur les liens",chemin_liens);
00253 ret = _MEDdatagroupFermer(gid);
00254 EXIT_IF(ret < 0,"Fermeture du groupe HDF sur les liens",chemin_liens);
00255 }
00256
00257 if (MAJ_231_232) {
00258
00259 fprintf(stdout,"- Lancement de la mise à jour des champs de résultats (231_232)... \n");
00260 MAJ_231_232_champs(fid);
00261 fprintf(stdout," Champs(s) : ... OK ...\n");
00262 fprintf(stdout,"- Lancement de la mise à jour des noms de maillages (231_232)... \n");
00263 MAJ_231_232_maillages(fid);
00264 fprintf(stdout," Noms(s) de maillage(s): ... OK ...\n");
00265 }
00266
00267 if (MAJ_236_300) {
00268
00269
00270 _MEDfileVersion(fid);
00271
00272
00273 fprintf(stdout,"- Lancement de la mise à jour des champs de résultats (236_300)... \n");
00274 MAJ_236_300_champs(fid);
00275 fprintf(stdout," Champs(s) : ... OK ...\n");
00276
00277
00278
00279 fprintf(stdout,"- Lancement de la mise à jour des maillages (236_300)... \n");
00280 MAJ_236_300_maillages(fid);
00281 fprintf(stdout," Maillage(s): ... OK ...\n");
00282
00283
00284
00285 }
00286
00287 if (MAJ_300_310) {
00288
00289
00290
00291 MAJ_write_version_num(fid,3,0,8);
00292 _MEDfileVersion(fid);
00293
00294 MAJ_version_num(fid,3,0,8);
00295
00296
00297 fprintf(stdout,"- Lancement de la mise à jour des champs de résultats (300_310) ... \n");
00298 MAJ_300_310_champs(fid);
00299 fprintf(stdout," Champs(s) : ... OK ...\n");
00300
00301
00302 }
00303
00304
00305
00306
00307
00308 MAJ_version(fid);
00309 MAJ_write_version_num(fid,MED_NUM_MAJEUR,MED_NUM_MINEUR,MED_NUM_RELEASE);
00310
00311
00312 ret = MEDfileClose(fid);
00313 EXIT_IF(ret < 0,"Fermeture du fichier",_fileout);
00314
00315
00316 fprintf(stdout,">>> Conversion du fichier %s au format MED V" PACKAGE_VERSION " terminée\n",
00317 _fileout);
00318
00319
00320 if (!hasfileout) free(tmp);
00321
00322 return 0;
00323 }
00324