c/2.3.6/test3.c
#include <med.h>
#define MESGERR 1
#include "med_utils.h"
#include <string.h>
#ifdef DEF_LECT_ECR
#define MODE_ACCES MED_LECTURE_ECRITURE
#elif DEF_LECT_AJOUT
#define MODE_ACCES MED_LECTURE_AJOUT
#else
#define MODE_ACCES MED_CREATION
#endif
int main (int argc, char **argv)
{
med_err ret = 0;
med_idt fid;
med_int nmaa,i,mdim,edim;
char maa[MED_TAILLE_NOM+1];
char nomu[MED_TAILLE_LNOM+1];
char desc[MED_TAILLE_DESC+1];
med_maillage type;
med_err inomu;
fid = MEDouvrir("test2.med",MED_LECTURE);
if (fid < 0) {
MESSAGE("Erreur a l'ouverture du fichier test2.med");
return -1;
}
nmaa = MEDnMaa(fid);
if (nmaa < 0) {
MESSAGE("Erreur a la lecture du nombre de maillage");
ret = -1;
}
if (ret == 0)
printf("- Nombre de maillage dans test2.med = "IFORMAT"\n",nmaa);
if (ret == 0)
for (i=0;i<nmaa;i++) {
if (MEDmaaInfo(fid,i+1,maa,&mdim,&type,desc) < 0) {
MESSAGE("Erreur a la lecture des informations du maillage :"); SSCRUTE(maa);
ret = -1;
}
edim = MEDdimEspaceLire(fid,maa);
inomu = MEDunvLire(fid,maa,nomu);
if (inomu < 0)
printf("maillage "IFORMAT" de nom %s, de dimension "IFORMAT" \n",i+1,maa,mdim);
else
printf("maillage "IFORMAT" de nom %s, de dimension "IFORMAT" et de nom univ. %s\n",i+1,maa,mdim,nomu);
if (edim > 0)
printf("La dimension de l'espace est "IFORMAT" \n",edim);
else
printf("La dimension de l'espace est "IFORMAT" \n",mdim);
if (type == MED_STRUCTURE)
printf("Il s'agit d'un maillage structure \n");
else
printf("Il s'agit d'un maillage non structure \n");
printf("Description associee au maillage : %s \n\n",desc);
}
ret = MEDfermer(fid);
if (ret < 0) {
MESSAGE("Erreur a la fermeture du fichier test2.med");
return -1;
}
return ret;
}