c/test8.c
#include <med.h>
#define MESGERR 1
#include "med_utils.h"
#include <string.h>
#ifdef DEF_LECT_ECR
#define MODE_ACCES MED_ACC_RDWR
#elif DEF_LECT_AJOUT
#define MODE_ACCES MED_ACC_RDEXT
#else
#define MODE_ACCES MED_ACC_CREAT
#endif
int main (int argc, char **argv)
{
med_idt fid = 0;
char maa[MED_NAME_SIZE+1] ="maa1";
med_int mdim = 2;
char nomfam[MED_NAME_SIZE+1]="";
med_int numfam;
med_int ngro;
char gro[MED_LNAME_SIZE+1]="";
int i;
int nfame = 3;
int nfamn = 2;
char nomcoo[2*MED_SNAME_SIZE+1] = "x y ";
char unicoo[2*MED_SNAME_SIZE+1] = "cm cm ";
if ((fid = MEDfileOpen("test8.med",MODE_ACCES)) < 0) {
MESSAGE("Erreur a la creation du fichier test8.med");
return -1;
}
if (MEDmeshCr( fid, maa, mdim, mdim, MED_UNSTRUCTURED_MESH,
"un maillage pour test8","s", MED_SORT_DTIT,
MED_CARTESIAN, nomcoo, unicoo) < 0) {
MESSAGE("Erreur a la creation du maillage : "); SSCRUTE(maa);
return -1;
}
strcpy(nomfam,"FAMILLE_0");
numfam = 0;
if (MEDfamilyCr(fid,maa,nomfam,numfam,0,"") < 0) {
MESSAGE("Erreur a la creation de la famille 0");
return -1;
}
nfame = 3;
for (i=0;i<nfame;i++) {
numfam = -(i+1);
sprintf(nomfam,"%s"IFORMAT,"FAMILLE_ELEMENT_",-numfam);
strcpy(gro,"groupe1");
ngro = 1;
printf("%s - "IFORMAT" - "IFORMAT" \n",nomfam,numfam,
ngro);
if (MEDfamilyCr(fid,maa,nomfam,numfam,ngro,gro) < 0) {
MESSAGE("Erreur a la creation de la famille :");
SSCRUTE(nomfam); ISCRUTE(numfam);
return -1;
}
}
nfamn = 2;
for (i=0;i<nfamn;i++) {
numfam = i+1;
sprintf(nomfam,"%s"IFORMAT,"FAMILLE_NOEUD_",numfam);
strcpy(gro,"groupe1");
ngro = 1;
if (MEDfamilyCr(fid,maa,nomfam,numfam,ngro,gro) < 0) {
MESSAGE("Erreur a la creation de la famille :");
SSCRUTE(nomfam); ISCRUTE(numfam);
return -1;
}
}
if (MEDfileClose(fid) < 0) {
MESSAGE("Erreur a la fermeture du fichier :");
return -1;
}
return 0;
}