MEDmeshGridTypeWr.c
Aller à la documentation de ce fichier.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
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
00036 med_err
00037 MEDmeshGridTypeWr(const med_idt fid,
00038 const char * const meshname,
00039 const med_grid_type gridtype)
00040 {
00041 med_err _ret=-1;
00042 med_idt _meshid=0;
00043 char _path[MED_TAILLE_MAA+MED_NAME_SIZE+1]=MED_MAA;
00044 med_mesh_type _meshtype;
00045 med_int _intmeshtype=MED_UNDEF_MESH_TYPE;
00046 med_int _intgridtype=gridtype;
00047
00048
00049
00050
00051 _MEDmodeErreurVerrouiller();
00052 if (_MEDcheckVersion30(fid) < 0) goto ERROR;
00053
00054
00055
00056
00057 strcat(_path,meshname);
00058 if ((_meshid = _MEDdatagroupOuvrir(fid,_path)) < 0) {
00059 MED_ERR_(_ret,MED_ERR_OPEN,MED_ERR_DATAGROUP,_path);
00060 ISCRUTE_id(_meshid);goto ERROR;
00061 }
00062
00063
00064
00065
00066 if ( _MEDattrEntierLire(_meshid,MED_NOM_TYP,&_intmeshtype) < 0) {
00067 MED_ERR_(_ret,MED_ERR_READ,MED_ERR_ATTRIBUTE,MED_ERR_MESH_MSG);
00068 SSCRUTE(meshname);SSCRUTE(MED_NOM_TYP); goto ERROR;
00069 }
00070 _meshtype = (med_mesh_type) (_intmeshtype);
00071
00072 if (_meshtype == MED_UNSTRUCTURED_MESH) {
00073 MED_ERR_(_ret,MED_ERR_INVALID,MED_ERR_ATTRIBUTE,MED_ERR_MESH_MSG);
00074 SSCRUTE(meshname);SSCRUTE(MED_NOM_TYP);ISCRUTE_int(_meshtype); goto ERROR;
00075 }
00076
00077
00078
00079
00080
00081 if ( _MEDattributeIntWr(_meshid,MED_NOM_GTY,&_intgridtype) < 0) {
00082 MED_ERR_(_ret,MED_ERR_WRITE,MED_ERR_ATTRIBUTE,MED_ERR_MESH_MSG);
00083 SSCRUTE(meshname);SSCRUTE(MED_NOM_GTY);
00084 ISCRUTE(_intgridtype);goto ERROR;
00085 }
00086
00087 _ret = 0;
00088
00089 ERROR:
00090
00091 if (_meshid>0) if (_MEDdatagroupFermer(_meshid) < 0) {
00092 MED_ERR_(_ret,MED_ERR_CLOSE,MED_ERR_DATAGROUP,_path);
00093 ISCRUTE_id(_meshid);
00094 }
00095
00096 return _ret;
00097 }