#define MESGERR 1
 
#include <string.h>
 
int main (
int argc, 
char **argv) {
 
  int i;
  char *groupname=NULL;
  int ret=-1;
 
  
  if (fid < 0) {
    MESSAGE(
"ERROR : open file in READ ONLY ACCESS mode ...");
 
    goto ERROR;
  }
 
  
 
  
  if (
MEDmeshInfoByName(fid, meshname, &spacedim, &meshdim, &meshtype, meshdescription,
 
                        dtunit, &sortingtype, &nstep, &axistype, axisname, unitname) < 0) {
    goto ERROR;
  }
 
  
                               &geotransformation)) < 0) {
    MESSAGE(
"ERROR : number of nodes ...");
 
    goto ERROR;
  }
 
  
 
  
                               &geotransformation)) < 0) {
    MESSAGE(
"ERROR : number of MED_TRIA3 ...");
 
    goto ERROR;
  }
 
  
                               &geotransformation)) < 0) {
    MESSAGE(
"ERROR : number of MED_QUAD4 ...");
 
    goto ERROR;
  }
 
  
    MESSAGE(
"ERROR : memory allocation ...");
 
    goto ERROR;
  }
 
                              coordinates) < 0) {
    MESSAGE(
"ERROR : nodes coordinates ...");
 
    free(coordinates);
    goto ERROR;
  }
 
  free(coordinates);
 
  
  if ((triaconnectivity = (
med_int *) malloc(
sizeof(
med_int)*ntria3*3)) == NULL) {
 
    MESSAGE(
"ERROR : memory allocation ...");
 
    goto ERROR;
  }
    MESSAGE(
"ERROR : MED_TRIA3 connectivity ...");
 
    free(triaconnectivity);
    goto ERROR;
  }
  free(triaconnectivity);
 
  if ((quadconnectivity = (
med_int *) malloc(
sizeof(
med_int)*nquad4*4)) == NULL) {
 
    MESSAGE(
"ERROR : memory allocation ...");
 
    goto ERROR;
  }
    MESSAGE(
"ERROR : MED_QUAD4 connectivity ...");
 
    free(quadconnectivity);
    goto ERROR;
  }
  free(quadconnectivity);
 
  
    MESSAGE(
"ERROR : read number of family ...");
 
    goto ERROR;
  }
 
  for (i=0; i<nfamily ; i++) {
 
      MESSAGE(
"ERROR : read number of group in a family ...");
 
      goto ERROR;
    }
 
    if (ngroup > 0) {
      if ((groupname = (
char*) malloc(
sizeof(
char)*
MED_LNAME_SIZE*ngroup+1)) == NULL) {
 
        MESSAGE(
"ERROR : memory allocation ...");
 
        goto ERROR;
      }
 
      if (
MEDfamilyInfo(fid, meshname, i+1, familyname, &familynumber, groupname) < 0) {
 
        MESSAGE(
"ERROR : family info ...");
 
        free(groupname);
        goto ERROR;
      }
      free(groupname);
    }
 
  }
 
  
  
          &coordinatechangement, &geotransformation)) < 0) {
    MESSAGE(
"ERROR : check family numbers nodes ...");
 
    goto ERROR;
  }
 
  if ((familynumbers = (
med_int *) malloc(
sizeof(
med_int)*nnodes)) == NULL) {
 
    MESSAGE(
"ERROR : memory allocation ...");
 
    goto ERROR;
  }
 
  if (nfamilynumber > 0) {
    
      MESSAGE(
"ERROR : read family numbers nodes ...");
 
      goto ERROR;
    }
  } else
    for (i=0; i<nnodes; i++) *(familynumbers+i) = 0;
 
  for (i=0; i<nnodes; i++) {
    printf(
IFORMAT, *(familynumbers+i));
    if (i+1 != nnodes)
      printf(" - ");
    else
      printf("\n");
  }
 
  if (familynumbers)
    free(familynumbers);
 
  
 
          &coordinatechangement, &geotransformation)) < 0) {
    MESSAGE(
"ERROR : check family number tria3 ...")
 
    goto ERROR;
  }
 
  if ((familynumbers = (
med_int *) malloc(
sizeof(
med_int)*ntria3)) == NULL) {
 
    MESSAGE(
"ERROR : memory allocation ...");
 
    goto ERROR;
  }
 
  if (nfamilynumber > 0) {
      MESSAGE(
"ERROR : read family numbers tria3 ...");
 
    }
  } else
    for (i=0; i<ntria3; i++) *(familynumbers+i) = 0;
 
  free (familynumbers);
 
            &coordinatechangement, &geotransformation)) < 0) {
    MESSAGE(
"ERROR : check family number quad4 ...");
 
    goto ERROR;
  }
 
  if ((familynumbers = (
med_int *) malloc(
sizeof(
med_int)*nquad4)) == NULL) {
 
    MESSAGE(
"ERROR : memory allocation ...");
 
    goto ERROR;
  }
 
  if (nfamilynumber > 0) {
      MESSAGE(
"ERROR : read family numbers quad4 ...");
 
      goto ERROR;
    }
  } else
    for (i=0; i<nquad4; i++) *(familynumbers+i) = 0;
 
  free (familynumbers);
 
  ret=0;
 ERROR:
 
  
    ret= -1;
  }
 
  return ret;
}
   
MEDC_EXPORT med_int MEDmeshnEntity(const med_idt fid, const char *const meshname, const med_int numdt, const med_int numit, const med_entity_type entitype, const med_geometry_type geotype, const med_data_type datatype, const med_connectivity_mode cmode, med_bool *const changement, med_bool *const transformation)
Cette routine permet de lire le nombre d'entités dans un maillage pour une étape de calcul donnée.
MEDC_EXPORT med_idt MEDfileOpen(const char *const filename, const med_access_mode accessmode)
Ouverture d'un fichier MED.
MEDC_EXPORT med_int MEDnFamilyGroup(const med_idt fid, const char *const meshname, const int famit)
Cette routine permet de lire le nombre de groupe dans une famille.
MEDC_EXPORT med_err MEDmeshElementConnectivityRd(const med_idt fid, const char *const meshname, const med_int numdt, const med_int numit, const med_entity_type entitype, const med_geometry_type geotype, const med_connectivity_mode cmode, const med_switch_mode switchmode, med_int *const connectivity)
Cette routine permet de lire dans un maillage le tableau des connectivités pour un type géométrique d...
MEDC_EXPORT med_err MEDmeshNodeCoordinateRd(const med_idt fid, const char *const meshname, const med_int numdt, const med_int numit, const med_switch_mode switchmode, med_float *const coordinates)
Cette routine permet de lire dans un maillage le tableau des coordonnées des noeuds,...
MEDC_EXPORT med_err MEDfileClose(med_idt fid)
Fermeture d'un fichier MED.
MEDC_EXPORT med_int MEDnFamily(const med_idt fid, const char *const meshname)
Cette routine permet de lire le nombre de famille dans un maillage.
MEDC_EXPORT med_err MEDmeshInfoByName(const med_idt fid, const char *const meshname, med_int *const spacedim, med_int *const meshdim, med_mesh_type *const meshtype, char *const description, char *const dtunit, med_sorting_type *const sortingtype, med_int *const nstep, med_axis_type *const axistype, char *const axisname, char *const axisunit)
Cette routine permet de lire les informations relatives à un maillage en précisant son nom.
MEDC_EXPORT med_err MEDfamilyInfo(const med_idt fid, const char *const meshname, const int famit, char *const familyname, med_int *const familynumber, char *const groupname)
Cette routine permet de lire les informations relatives à une famille d'un maillage.
MEDC_EXPORT med_err MEDmeshEntityFamilyNumberRd(const med_idt fid, const char *const meshname, const med_int numdt, const med_int numit, const med_entity_type entitype, const med_geometry_type geotype, med_int *const number)
Cette routine permet la lecture des numéros de famille d'un type d'entité d'un maillage.
int main(int argc, char **argv)