MED fichier
MEDfieldComputingStepMeshWr.c
Aller à la documentation de ce fichier.
1 /* This file is part of MED.
2  *
3  * COPYRIGHT (C) 1999 - 2021 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 <string.h>
23 
35 med_err
37  const char * const fieldname,
38  const med_int numdt,
39  const med_int numit,
40  const med_int meshnumdt,
41  const med_int meshnumit) {
42 
43  med_access_mode _MED_ACCESS_MODE;
44  med_err _ret=-1;
45  med_idt _gid=0;
47 
48  /* char _datagroupname1[2*MED_MAX_PARA+1]=""; */
49  /* char _cstpname[2*MED_MAX_PARA+1]=""; */
50 
51  /*
52  * On inhibe le gestionnaire d'erreur HDF 5
53  */
55 if (_MEDcheckVersion30(fid) < 0) goto ERROR;
56 
57  if ( (_MED_ACCESS_MODE = _MEDmodeAcces(fid) ) == MED_ACC_UNDEF ) {
59  goto ERROR;
60  }
61 
62  if ( _MED_ACCESS_MODE == MED_ACC_RDONLY) {
64  ISCRUTE_int(_MED_ACCESS_MODE);
65  goto ERROR;
66  }
67 
68  /*
69  * On construit le nom du datagroup
70  */
71  strcat(_path,fieldname);
72  strcat(_path,"/");
73  _MEDgetComputationStepName(MED_SORT_DTIT,numdt,numit,&_path[strlen(_path)]);
74 
75 
76  if ((_gid = _MEDdatagroupOuvrir(fid,_path)) < 0) {
78  goto ERROR;
79  }
80 
81 
82  /*
83  * Ecriture des attributs
84  */
85 
86  if (_MEDattributeIntWr(_gid,MED_NOM_RDT, &meshnumdt) < 0) {
88  SSCRUTE(_path);ISCRUTE(meshnumdt);goto ERROR;
89  }
90 
91  if (_MEDattributeIntWr(_gid,MED_NOM_ROR, &meshnumit) < 0) {
93  SSCRUTE(_path);ISCRUTE(meshnumit);goto ERROR;
94  }
95 
96 
97  _ret = 0;
98 
99  ERROR:
100 
101 
102  if (_gid>0) if (_MEDdatagroupFermer(_gid) < 0) {
104  ISCRUTE_id(_gid);
105  }
106 
107  return _ret;
108 }
MED_FIELD_GRP_SIZE
#define MED_FIELD_GRP_SIZE
Definition: med_outils.h:170
MED_SORT_DTIT
Definition: med.h:309
_MEDdatagroupFermer
MEDC_EXPORT med_err _MEDdatagroupFermer(med_idt id)
ISCRUTE_id
#define ISCRUTE_id(entier)
Definition: med_utils.h:319
MED_NOM_RDT
#define MED_NOM_RDT
Definition: med_outils.h:143
_MEDmodeAcces
MEDC_EXPORT med_access_mode _MEDmodeAcces(med_idt oid)
ISCRUTE_int
#define ISCRUTE_int(entier)
Definition: med_utils.h:314
med_idt
hid_t med_idt
Definition: med.h:331
MED_ERR_
#define MED_ERR_(rt, r1, r2, r3)
Definition: med_utils.h:160
_MEDattributeIntWr
#define _MEDattributeIntWr(w, x, y)
Definition: med_hdfi.h:45
MED_ACC_RDONLY
Definition: med.h:120
MED_ERR_INVALID
#define MED_ERR_INVALID
Definition: med_err.h:40
MED_ERR_ATTRIBUTE
#define MED_ERR_ATTRIBUTE
Definition: med_err.h:100
med_err
herr_t med_err
Definition: med.h:332
MED_MAX_PARA
#define MED_MAX_PARA
Definition: med.h:76
MED_ERR_CLOSE
#define MED_ERR_CLOSE
Definition: med_err.h:30
MED_ERR_OPEN
#define MED_ERR_OPEN
Definition: med_err.h:37
med_int
int med_int
Definition: med.h:342
MED_ERR_WRITE
#define MED_ERR_WRITE
Definition: med_err.h:29
_MEDgetComputationStepName
MEDC_EXPORT med_err _MEDgetComputationStepName(const med_sorting_type sortingtype, const med_int numdt, const med_int numit, char *const datagroupname)
med.h
ISCRUTE
#define ISCRUTE(entier)
Definition: med_utils.h:313
MED_NOM_ROR
#define MED_NOM_ROR
Definition: med_outils.h:146
med_access_mode
med_access_mode
Definition: med.h:120
MED_ERR_ACCESSMODE
#define MED_ERR_ACCESSMODE
Definition: med_err.h:104
SSCRUTE
#define SSCRUTE(chaine)
Definition: med_utils.h:323
MED_ERR_DATAGROUP
#define MED_ERR_DATAGROUP
Definition: med_err.h:99
MEDfieldComputingStepMeshWr
med_err MEDfieldComputingStepMeshWr(const med_idt fid, const char *const fieldname, const med_int numdt, const med_int numit, const med_int meshnumdt, const med_int meshnumit)
Cette fonction permet de définir l'étape de calcul ( meshnumdit , meshnumit ) à utiliser pour le mail...
Definition: MEDfieldComputingStepMeshWr.c:36
MED_NAME_SIZE
#define MED_NAME_SIZE
Definition: med.h:81
_MEDcheckVersion30
MEDC_EXPORT med_err _MEDcheckVersion30(med_idt fid)
med_outils.h
med_config.h
MED_FIELD_GRP
#define MED_FIELD_GRP
Definition: med_outils.h:169
MED_ERR_UNRECOGNIZED
#define MED_ERR_UNRECOGNIZED
Definition: med_err.h:39
MED_ERR_FILE_MSG
#define MED_ERR_FILE_MSG
Definition: med_err.h:132
_MEDdatagroupOuvrir
MEDC_EXPORT med_idt _MEDdatagroupOuvrir(med_idt pid, const char *const nom)
_MEDmodeErreurVerrouiller
MEDC_EXPORT void _MEDmodeErreurVerrouiller(void)
MED_ACC_UNDEF
Definition: med.h:124