MEDstructElementGeotype.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
00026
00037 med_geometry_type
00038 MEDstructElementGeotype(const med_idt fid,
00039 const char * const modelname) {
00040
00041 med_idt _elemid=0;
00042 char _path[MED_TAILLE_STRCT+MED_NAME_SIZE+1]=MED_STRCT;
00043 med_geometry_type _ret=-1;
00044 med_int _medintstructelementtype=MED_NONE;
00045
00046 #ifdef _DEBUG_
00047 SSCRUTE(modelname);
00048 #endif
00049
00050
00051
00052
00053 _MEDmodeErreurVerrouiller();
00054 strcat(_path,modelname);
00055
00056
00057
00058
00059 if ((_elemid = _MEDdatagroupOpen(fid,_path)) < 0) {
00060 MED_ERR_(_ret,MED_ERR_OPEN,MED_ERR_DATAGROUP,_path);
00061 goto ERROR;
00062 }
00063
00064
00065
00066 if ( _MEDattrEntierLire(_elemid,MED_NOM_NEO,&_medintstructelementtype) < 0 ) {
00067 MED_ERR_(_ret,MED_ERR_READ,MED_ERR_ATTRIBUTE,_path);
00068 SSCRUTE(MED_NOM_NEO);ISCRUTE(_medintstructelementtype);
00069 goto ERROR;
00070 }
00071
00072 _ret = _medintstructelementtype;
00073
00074 ERROR:
00075
00076 if (_elemid>0) if (_MEDdatagroupFermer(_elemid) < 0) {
00077 MED_ERR_(_ret,MED_ERR_CLOSE,MED_ERR_DATAGROUP,modelname);
00078 ISCRUTE_id(_elemid);
00079 }
00080
00081 return _ret;
00082 }
00083