libmedimport.c

Aller à la documentation de ce fichier.
00001 /*  This file is part of MED.
00002  *
00003  *  COPYRIGHT (C) 1999 - 2015  EDF R&D, CEA/DEN
00004  *  MED is free software: you can redistribute it and/or modify
00005  *  it under the terms of the GNU Lesser General Public License as published by
00006  *  the Free Software Foundation, either version 3 of the License, or
00007  *  (at your option) any later version.
00008  *
00009  *  MED is distributed in the hope that it will be useful,
00010  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00011  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00012  *  GNU Lesser General Public License for more details.
00013  *
00014  *  You should have received a copy of the GNU Lesser General Public License
00015  *  along with MED.  If not, see <http://www.gnu.org/licenses/>.
00016  */
00017 
00018 /* L'utilisation des med_utils n'est pas optionelle
00019    dans l'outil medimport, elle revet cependant deux
00020    formes :
00021    - Si -DWITH_EXCEPTION EXITIF renvoie une exception MEDerreur
00022    - Sinon exécute l'instruction return */
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 /* #ifdef __cplusplus */
00042 /* extern "C" { */
00043 /* #endif */
00044 
00045 /* Pour faciliter la detection autotools */
00046 int HAVE_MEDimport=1;
00047 
00048 /*Inclusion des .h de la version de la bibliothèque courante*/
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 /*TODO : En attendant une conversion totale de l'outil libmedimport en 3.0*/
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 /* #ifdef __cplusplus */
00068 /* } */
00069 /* #endif */
00070 
00071 /*Inclusion des .h spécifiques à medimport */
00072 
00073 /* Interface publique de l'outil medimport */
00074 /* MEDimport.h == MEDimport.hxx */
00075 #include "MEDimport.h"
00076 #include "MAJ_version.h"
00077 
00078 /* Interfaces privées à l'outil medimport  */
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   /* Test du format du fichier */
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     /* PAs d'interactif dans une bibliothèque !*/
00141 /*     fprintf(stdout,">>> Voulez-vous essayer une conversion d'un fichier  < 2.2 (o/n) ? "); */
00142 /*     scanf("%c",&reponse); */
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 /*   EXIT_IF( !medok , */
00153 /*        "MEDimport ne gère pas le format  MED de ce fichier : ", filein); */
00154 
00155   /* Creation et ouverture du fichier que l'on va convertir au format MED actuel */
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   /* Verification du numero de version */
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   /* Ne pas oublier que la version cible du fichier à convertir est celui de la bibliothèque. */
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   /* On avertit qu'on commence la conversion */
00208   fprintf(stdout,">>> Lancement de la normalisation du fichier selon le format " PACKAGE_VERSION " ...\n");
00209 
00210   /* On inhibe le gestionnaire d'erreur HDF5 */
00211   _MEDmodeErreurVerrouiller();
00212 
00213   /* Mise a jour du numero de version */
00214   fprintf(stdout,"- Lancement de la mise à jour du numéro de version ... \n");
00215   /*   La mise à jour MAJ_version(fid); doit être différée pour que les majs des fichiers anciens
00216        fonctionnent correctement*/
00217   /*   MAJ_version(fid); */
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     /* Mise a jour des maillages : type = MED_NON_STRUCTURE, description, ... */
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     /* Mise a jour des champs */
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     /* Mise a jour des profils eventuels */
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     /* On cree le groupe HDF pour les liens */
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     /* Mise a jour des champs */
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     /* Le système de cache de version a été developpé à partir de la 3.0*/
00269     /* Initialise le cache sur une 2.3.6 (cas d'absence d'INFO)*/
00270     _MEDfileVersion(fid);
00271 
00272     /* Mise a jour des champs */
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     /* MAJ_version(fid); */
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     /* MAJ_version(fid);  */
00284 
00285   }
00286 
00287   if (MAJ_300_310) {
00288     /* Le système de cache de version a été developpé à partir de la 3.0*/
00289     /* Initialise le cache sur une 3.0.8 (cas d'absence d'INFO)*/
00290     /* s'il n'a pas été instanciée ds MAJ_236_300 */
00291     MAJ_write_version_num(fid,3,0,8);
00292     _MEDfileVersion(fid);
00293     /* Si le cache était dèjà instancié, met à jour le cache */
00294     MAJ_version_num(fid,3,0,8);
00295 
00296     /* Mise a jour des champs */
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   /* A l'écriture d'une nouvelle version de MAJ ex 310_320,
00305    il est necessaire de revisiter les appels à MAJ_version(fid) pour
00306    les remplacer par les appels MAJ_version(fid,3,1,Lastest31z) */
00307 
00308   MAJ_version(fid);  
00309   MAJ_write_version_num(fid,MED_NUM_MAJEUR,MED_NUM_MINEUR,MED_NUM_RELEASE);
00310 
00311   /* Fermeture du fichier */
00312   ret = MEDfileClose(fid);
00313   EXIT_IF(ret < 0,"Fermeture du fichier",_fileout);
00314 
00315   /* On avertit que c'est fini */
00316   fprintf(stdout,">>> Conversion du fichier %s au format MED V" PACKAGE_VERSION " terminée\n",
00317           _fileout);
00318 
00319   /* On libere la memoire */
00320   if (!hasfileout) free(tmp);
00321 
00322   return 0;
00323 }
00324 

Généré le Thu Oct 8 14:26:16 2015 pour MED fichier par  doxygen 1.6.1