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
00083
00084 #ifdef __cplusplus
00085 extern "C" void _MEDmodeErreurVerrouiller(void);
00086 #endif
00087
00088
00089
00090 int MEDimport(char * filein, char * fileout) {
00091
00092 med_idt fid, gid;
00093 med_err ret;
00094 med_int majeur, mineur, release;
00095 med_bool hdfok=MED_FALSE;
00096 med_bool medok=MED_FALSE;
00097 char *_fileout,*tmp=NULL;
00098 int _fileoutsize;
00099 bool hasfileout=false;
00100 char *commande;
00101 med_int nprofil;
00102 char chemin_profils[MED_TAILLE_PROFILS+1];
00103 char chemin_liens[MED_TAILLE_LIENS+1];
00104 char version[9];
00105 int MAJ_21_22 = 0, MAJ_231_232 = 0, MAJ_236_300 = 0;
00106 #ifdef PPRO_NT
00107 char *drive, *dir, *ext;
00108 #endif
00109 unsigned char reponse='o';
00110 med_bool _noversion=MED_FALSE;
00111
00112 EXIT_IF(filein == NULL,"Le nom du fichier d'entrée est vide : ", filein);
00113
00114 hasfileout = strcmp(fileout,"");
00115 if ( hasfileout ) {
00116 _fileoutsize = strlen(fileout);
00117 _fileout = fileout;
00118 } else {
00119 _fileoutsize = strlen(filein)+strlen(PACKAGE_VERSION);
00120 tmp = (char *) malloc(sizeof(char)*(_fileoutsize+1));
00121 strcpy(tmp,filein);
00122 strcat(tmp,PACKAGE_VERSION);
00123 #ifdef PPRO_NT
00124 _splitpath( tmp, drive, dir, _fileout, ext );
00125 #else
00126 _fileout = basename(tmp);
00127 #endif
00128 _fileoutsize = strlen(_fileout);
00129
00130 }
00131
00132
00133
00134 ret = MEDfileCompatibility(filein,&hdfok,&medok);
00135
00136 if (ret < 0 ) {
00137 fprintf(stdout,">>> Attention le fichier %s ne contient pas de numéro de version. \n",filein);
00138 fprintf(stdout,">>> Le fichier %s est supposé être en version 2.1.1. \n",filein);
00139
00140
00141
00142 if ( (reponse != 'o') && (reponse != 'O') && (reponse != 'y') && (reponse != 'Y') ) {
00143 EXIT_IF(MEDfileCompatibility(filein,&hdfok,&medok) < 0,
00144 "Erreur d'appel de MEDfileCompatibility : ", filein);
00145 }
00146 _noversion = MED_TRUE;
00147 }
00148 EXIT_IF( !hdfok ,
00149 "Le fichier d'entrée n'est pas dans un format HDF compatible : ", filein);
00150
00151
00152
00153
00154
00155 commande = (char *) malloc(sizeof(char)*(strlen("cp ")+strlen(filein)+
00156 strlen(" ")+_fileoutsize + 4 +1 ) );
00157 EXIT_IF(commande == NULL,NULL,NULL);
00158 strcpy(commande,"cp \"");
00159 strcat(commande,filein);
00160 strcat(commande,"\" \"");
00161 strcat(commande,_fileout);
00162 strcat(commande,"\"");
00163 fprintf(stdout,">>> Creation du fichier %s : %s \n",_fileout,commande);
00164 system(commande);
00165 free(commande);
00166 commande = (char *) malloc(sizeof(char)*(strlen("chmod u+w \"") + _fileoutsize +1 +1 ) );
00167 EXIT_IF(commande == NULL,NULL,NULL);
00168 strcpy(commande,"chmod u+w \"");
00169 strcat(commande,_fileout);
00170 strcat(commande,"\"");
00171 fprintf(stdout,">>> Chmod +w du fichier %s : %s \n",_fileout,commande);
00172 system(commande);
00173 free(commande);
00174
00175 fid = MEDfileOpen(_fileout,MED_ACC_RDWR);
00176 EXIT_IF(fid < 0,"Ouverture du fichier : ", _fileout);
00177
00178
00179 if (! _noversion)
00180 ret = MEDfileNumVersionRd(fid,&majeur,&mineur,&release);
00181 else {
00182 ret=0;
00183 majeur=2;
00184 mineur=1;
00185 release=1;
00186 }
00187 sprintf(version, IFORMAT"_"IFORMAT"_"IFORMAT, majeur, mineur, release);
00188 EXIT_IF(ret < 0,"Lecture du numero de version de MED-fichier",NULL);
00189 if (strcmp(version, "2_2_0") < 0)
00190 MAJ_21_22 = 1;
00191 if (strcmp(version, "2_3_2") < 0)
00192 MAJ_231_232 = 1;
00193 if (strcmp(version, "3_0_0") < 0)
00194 MAJ_236_300 = 1;
00195
00196
00197
00198 if (MAJ_236_300 == 0) {
00199 fprintf(stdout,"Le fichier %s est déjà au bon format !!! \n",_fileout);
00200 ret = MEDfileClose(fid);
00201 EXIT_IF(ret < 0,"Fermeture du fichier",filein);
00202 return 0;
00203 }
00204
00205
00206 fprintf(stdout,">>> Lancement de la normalisation du fichier selon le format " PACKAGE_VERSION " ...\n");
00207
00208
00209 _MEDmodeErreurVerrouiller();
00210
00211
00212 fprintf(stdout,"- Lancement de la mise à jour du numéro de version ... \n");
00213
00214
00215
00216 MAJ_write_version_num(fid,2,3,6);
00217 fprintf(stdout," Numéro de version : ... OK ... \n");
00218
00219 if (MAJ_21_22) {
00220
00221
00222 fprintf(stdout,"- Lancement de la mise à jour des maillages ... \n");
00223 MAJ_21_22_maillages(fid);
00224 fprintf(stdout," Maillage(s) : ... OK ...\n");
00225
00226
00227 fprintf(stdout,"- Lancement de la mise à jour des champs de résultats ... \n");
00228 MAJ_21_22_champs(fid);
00229 fprintf(stdout," Champs(s) : ... OK ...\n");
00230
00231
00232 nprofil = MEDnProfil(fid);
00233 if (nprofil > 0) {
00234 fprintf(stdout,"- Lancement de la mise à jour des profils ... \n");
00235 MAJ_21_22_profils(fid,nprofil);
00236 fprintf(stdout," Profils(s) : ... OK ...\n");
00237 } else {
00238 strncpy(chemin_profils,MED_PROFILS,MED_TAILLE_PROFILS-1);
00239 chemin_profils[MED_TAILLE_PROFILS-1] = '\0';
00240 gid = _MEDdatagroupCreer(fid,chemin_profils);
00241 EXIT_IF(gid < 0,"Creation du groupe HDF sur les profils",chemin_profils);
00242 ret = _MEDdatagroupFermer(gid);
00243 EXIT_IF(ret < 0,"Fermeture du groupe HDF sur les profils",chemin_profils);
00244 }
00245
00246
00247 strncpy(chemin_liens,MED_LIENS,MED_TAILLE_LIENS-1);
00248 chemin_liens[MED_TAILLE_LIENS-1] = '\0';
00249 gid = _MEDdatagroupCreer(fid,chemin_liens);
00250 EXIT_IF(gid < 0,"Creation du groupe HDF sur les liens",chemin_liens);
00251 ret = _MEDdatagroupFermer(gid);
00252 EXIT_IF(ret < 0,"Fermeture du groupe HDF sur les liens",chemin_liens);
00253 }
00254
00255 if (MAJ_231_232) {
00256
00257 fprintf(stdout,"- Lancement de la mise à jour des champs de résultats ... \n");
00258 MAJ_231_232_champs(fid);
00259 fprintf(stdout," Champs(s) : ... OK ...\n");
00260 fprintf(stdout,"- Lancement de la mise à jour des noms de maillages ... \n");
00261 MAJ_231_232_maillages(fid);
00262 fprintf(stdout," Noms(s) de maillage(s): ... OK ...\n");
00263 }
00264
00265 if (MAJ_236_300) {
00266
00267
00268 _MEDfileVersion(fid);
00269
00270
00271 fprintf(stdout,"- Lancement de la mise à jour des champs de résultats ... \n");
00272 MAJ_236_300_champs(fid);
00273 fprintf(stdout," Champs(s) : ... OK ...\n");
00274
00275 MAJ_version(fid);
00276
00277 fprintf(stdout,"- Lancement de la mise à jour des maillages ... \n");
00278 MAJ_236_300_maillages(fid);
00279 fprintf(stdout," Maillage(s): ... OK ...\n");
00280
00281 MAJ_version(fid);
00282
00283 }
00284
00285 MAJ_write_version_num(fid,MED_NUM_MAJEUR,MED_NUM_MINEUR,MED_NUM_RELEASE);
00286
00287
00288 ret = MEDfileClose(fid);
00289 EXIT_IF(ret < 0,"Fermeture du fichier",_fileout);
00290
00291
00292 fprintf(stdout,">>> Conversion du fichier %s au format MED V" PACKAGE_VERSION " terminée\n",
00293 _fileout);
00294
00295
00296 if (!hasfileout) free(tmp);
00297
00298 return 0;
00299 }
00300