MEDprofilEcr.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 
00019 #include <med.h>
00020 #include <med_config.h>
00021 #include <med_outils.h>
00022 
00023 #include <string.h>
00024 #include <stdlib.h>
00025 
00026 med_err
00027 MEDprofilEcr(med_idt fid,med_int *pflval,med_int n,char *profilname)
00028 {
00029   med_idt gid, chid;
00030   med_size dimd[1];
00031   med_err ret=-1;
00032   char chemin[MED_TAILLE_PROFILS+1];
00033   med_mode_acces MED_MODE_ACCES;
00034 
00035   /*
00036    * On inhibe le gestionnaire d'erreur HDF 5
00037    */
00038   _MEDmodeErreurVerrouiller();
00039 if (MEDcheckVersion(fid) < 0) return -1;
00040 
00041 
00042   if ( (MED_MODE_ACCES = _MEDmodeAcces(fid) ) == MED_UNDEF_MODE_ACCES ) {
00043     MESSAGE("Impossible de déterminer le mode d'acces au fichier ");
00044     goto ERROR;
00045   }
00046 
00047   /* 
00048    * Si le groupe "PROFILS" n'existe pas, on le cree
00049    */
00050   strncpy(chemin,MED_PROFILS,MED_TAILLE_PROFILS-1);
00051   chemin[MED_TAILLE_PROFILS-1] = '\0';
00052   if ((gid = _MEDdatagroupOuvrir(fid,chemin)) < 0)
00053     if ((gid = _MEDdatagroupCreer(fid,chemin)) < 0) {
00054       MESSAGE("Impossible de creer le groupe MED_PROFILS : ");
00055       SSCRUTE(chemin); goto ERROR;
00056     }
00057 
00058   /* 
00059    * Si le groupe "profilname" n'existe pas, on le cree
00060    * Sinon => erreur
00061    */
00062   NOFINALBLANK(profilname,ERROR);
00063   if ((chid = _MEDdatagroupOuvrir(gid,profilname)) >= 0) {
00064     if ( MED_MODE_ACCES != MED_LECTURE_ECRITURE ) {
00065       MESSAGE("Le profil existe déjà : ");
00066       SSCRUTE(profilname); goto ERROR;
00067     }
00068   } else
00069     if ((chid = _MEDdatagroupCreer(gid,profilname)) < 0)
00070       goto ERROR;
00071 
00072   /*
00073    * On stocke "n" sous forme d'attribut
00074    */
00075   if ((ret = _MEDattrEntierEcrire(chid,MED_NOM_NBR,&n)) < 0) {
00076     MESSAGE("Erreur à l'écriture de l'attribut MED_NOM_NBR : ");
00077     ISCRUTE(n); goto ERROR;
00078   };
00079 
00080   /*
00081    * On stocke le profil dans un dataset
00082    */
00083   dimd[0] = n;
00084 #if defined(HAVE_F77INT64)
00085   ret =  _MEDdatasetNumEcrire(chid,MED_NOM_PFL,MED_INT64,MED_NO_INTERLACE,MED_DIM1,MED_ALL,MED_NOPF,MED_NO_PFLMOD,0,0,MED_NOPG,dimd,
00086                               (unsigned char*) pflval);
00087 #else
00088   ret =  _MEDdatasetNumEcrire(chid,MED_NOM_PFL,MED_INT32,MED_NO_INTERLACE,MED_DIM1,MED_ALL,MED_NOPF,MED_NO_PFLMOD,0,0,MED_NOPG,dimd,
00089                               (unsigned char*) pflval);
00090 #endif
00091   if (ret < 0 ) {
00092     MESSAGE("Impossible d'ecrire le dataset pflval de taille  : ");
00093     ISCRUTE(n); goto ERROR;
00094   }
00095 
00096   ret = 0;
00097  ERROR:
00098   /*
00099    * On ferme tout
00100    */
00101   if (chid>0)     if (_MEDdatagroupFermer(chid) < 0) {
00102     MESSAGE("Impossible de fermer le datagroup : ");
00103     ISCRUTE_id(chid); ret = -1;
00104   }
00105 
00106   if (gid>0)     if (_MEDdatagroupFermer(gid) < 0) {
00107     MESSAGE("Impossible de fermer le datagroup : ");
00108     ISCRUTE_id(gid); ret = -1;
00109   }
00110 
00111   return ret;
00112 }
00113 
00114 
00115 
00116 

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