MED fichier
MEDfieldInterpWr.c
Aller à la documentation de ce fichier.
1 /* This file is part of MED.
2  *
3  * COPYRIGHT (C) 1999 - 2023 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 
19 #include <med.h>
20 #include <med_config.h>
21 #include <med_outils.h>
22 #include <hdf5.h>
23 #include <string.h>
24 
35 med_err
37  const char* const fieldname,
38  const char* const interpname
39  )
40 {
41  med_err _ret=-1;
42  med_idt _fieldinterpid=0,_fieldid=0,_interpid=0;
44 
45  /*
46  * On inhibe le gestionnaire d'erreur HDF 5
47  */
49  if (_MEDcheckVersion30(fid) < 0) goto ERROR;
50 
51  /*
52  * On ouvre le champ /MED_CHA_INTERP
53  */
54  if ((_fieldinterpid = _MEDdatagroupOpen(fid,MED_CHA_INTERP)) < 0)
55  if ((_fieldinterpid = _MEDdatagroupCreer(fid,MED_CHA_INTERP)) < 0) {
57  goto ERROR;
58  }
59 
60  NOFINALBLANK(interpname,ERROR);
61  strcat(_path,fieldname);
62 
63  /*
64  * On ouvre le champ /MED_CHA_INTERP/<fieldname>
65  */
66  if ((_fieldid = _MEDdatagroupOuvrir(_fieldinterpid,fieldname)) < 0)
67  if ((_fieldid = _MEDdatagroupCreer(_fieldinterpid,fieldname)) < 0) {
69  goto ERROR;
70  }
71 
72  /*
73  * Si le DataGroup /MED_CHA_INTERP/<fieldname>/<interpname> n'existe pas, on le cree
74  */
75  if ((_interpid = _MEDdatagroupOpen(_fieldid,interpname)) < 0)
76  if ((_interpid = _MEDdatagroupCreer(_fieldid,interpname)) < 0) {
77  MED_ERR_(_ret,MED_ERR_CREATE,MED_ERR_DATAGROUP,interpname);
78  SSCRUTE(_path);
79  goto ERROR;
80  }
81 
82  _ret = 0;
83 
84  ERROR:
85 
86  if (_interpid>0) if (_MEDdatagroupFermer(_interpid) < 0) {
87  MED_ERR_(_ret,MED_ERR_CLOSE,MED_ERR_DATAGROUP,interpname);
88  SSCRUTE(_path); ISCRUTE_id(_interpid);
89  }
90 
91  if (_fieldid>0) if (_MEDdatagroupFermer(_fieldid) < 0) {
93  SSCRUTE(_path);ISCRUTE_id(_fieldid);
94  }
95 
96  if (_fieldinterpid>0) if (_MEDdatagroupFermer(_fieldinterpid) < 0) {
98  SSCRUTE(_path); ISCRUTE_id(_fieldinterpid);
99  }
100 
101 
102  return _ret;
103 }
104 
MED_ERR_CREATE
#define MED_ERR_CREATE
Definition: med_err.h:27
MED_CHA_INTERP
#define MED_CHA_INTERP
Definition: med_outils.h:184
ISCRUTE_id
#define ISCRUTE_id(entier)
Definition: med_utils.h:319
med_idt
hid_t med_idt
Definition: med.h:333
MED_ERR_
#define MED_ERR_(rt, r1, r2, r3)
Definition: med_utils.h:160
_MEDdatagroupOpen
MEDC_EXPORT med_idt _MEDdatagroupOpen(const med_idt pid, const char *const name)
med_err
herr_t med_err
Definition: med.h:334
med_outils.h
MED_ERR_CLOSE
#define MED_ERR_CLOSE
Definition: med_err.h:30
med_config.h
MED_TAILLE_CHA_INTERP
#define MED_TAILLE_CHA_INTERP
Definition: med_outils.h:185
MED_ERR_DATAGROUP
#define MED_ERR_DATAGROUP
Definition: med_err.h:99
_MEDdatagroupCreer
MEDC_EXPORT med_idt _MEDdatagroupCreer(med_idt pid, const char *const nom)
SSCRUTE
#define SSCRUTE(chaine)
Definition: med_utils.h:323
MED_NAME_SIZE
#define MED_NAME_SIZE
Definition: med.h:83
_MEDcheckVersion30
MEDC_EXPORT med_err _MEDcheckVersion30(med_idt fid)
med.h
NOFINALBLANK
#define NOFINALBLANK(chaine, label)
Definition: med_utils.h:311
_MEDdatagroupOuvrir
MEDC_EXPORT med_idt _MEDdatagroupOuvrir(med_idt pid, const char *const nom)
_MEDmodeErreurVerrouiller
MEDC_EXPORT void _MEDmodeErreurVerrouiller(void)
MEDfieldInterpWr
med_err MEDfieldInterpWr(const med_idt fid, const char *const fieldname, const char *const interpname)
Cette routine associe une fonction d'interpolation interpname au champ résultat fieldname.
Definition: MEDfieldInterpWr.c:36
_MEDdatagroupFermer
MEDC_EXPORT med_err _MEDdatagroupFermer(med_idt id)