1 /*************************************************************************
  2 * COPYRIGHT (C) 1999 - 2007  EDF R&D, CEA/DEN
  3 * THIS LIBRARY IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
  4 * IT UNDER THE TERMS OF THE GNU LESSER GENERAL PUBLIC LICENSE 
  5 * AS PUBLISHED BY THE FREE SOFTWARE FOUNDATION; 
  6 * EITHER VERSION 2.1 OF THE LICENSE, OR (AT YOUR OPTION) ANY LATER VERSION.
  7 *  
  8 * THIS LIBRARY IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
  9 * WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
 10 * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
 11 * LESSER GENERAL PUBLIC LICENSE FOR MORE DETAILS.
 12 *
 13 * YOU SHOULD HAVE RECEIVED A COPY OF THE GNU LESSER GENERAL PUBLIC LICENSE
 14 * ALONG WITH THIS LIBRARY; IF NOT, WRITE TO THE FREE SOFTWARE FOUNDATION,
 15 * INC., 59 TEMPLE PLACE, SUITE 330, BOSTON, MA 02111-1307 USA
 16 *
 17 *************************************************************************/
 18 
 19 /******************************************************************************
 20  * - Nom du fichier : test14.c
 21  *
 22  * - Description : ecriture des noeuds d'un maillage MED
 23  *                 a l'aide des routines de niveau 2
 24  *                 equivalent a test4.c
 25  *
 26  *****************************************************************************/
 27 
 28 #include <med.h>
 29 #define MESGERR
 30 #include <med_utils.h>
 31 
 32 #ifdef DEF_LECT_ECR
 33 #define MODE_ACCES MED_LECTURE_ECRITURE
 34 #elif DEF_LECT_AJOUT
 35 #define MODE_ACCES MED_LECTURE_AJOUT
 36 #else
 37 #define MODE_ACCES MED_CREATION
 38 #endif
 39 
 40 int main (int argc, char **argv)
 41 
 42 
 43 {
 44   med_idt fid;
 45   /* la dimension du maillage */
 46   med_int mdim = 2;
 47   /* nom du maillage de longueur maxi MED_TAILLE_NOM */
 48   char maa[MED_TAILLE_NOM+1] = "maa1";
 49   /* le nombre de noeuds */
 50   med_int nnoe = 4;
 51   /* table des coordonnees  
 52      profil : (dimension * nombre de noeuds) */
 53   med_float coo[8] = {0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 1.0, 1.0};
 54   /* tables des noms et des unites des coordonnees 
 55      profil : (dimension*MED_TAILLE_PNOM+1) */
 56   /*                                  12345678901234561234567890123456 */
 57   char nomcoo[2*MED_TAILLE_PNOM+1] = "x               y               ";
 58   char unicoo[2*MED_TAILLE_PNOM+1] = "cm              cm              ";
 59   /* tables des noms, numeros, numeros de familles des noeuds
 60      autant d'elements que de noeuds - les noms ont pout longueur
 61      MED_TAILLE_PNOM */
 62   /*                                  1234567890123456123456789012345612345678901234561234567890123456 */
 63   char nomnoe[4*MED_TAILLE_PNOM+1] = "nom1            nom2            nom3            nom4";
 64   med_int numnoe[4] = {1,2,3,4};
 65   med_int nufano[4] = {0,1,2,2};;
 66 
 67   /* Creation du fichier test14.med */
 68   if ((fid = MEDouvrir("test14.med",MODE_ACCES)) < 0) {
 69     MESSAGE("Erreur a la creation du fichier test14.med");
 70     return -1;
 71   }
 72 
 73   /* Creation du maillage */
 74   if (MEDmaaCr(fid,maa,mdim,MED_NON_STRUCTURE,"Un maillage pour test14") < 0) {
 75     MESSAGE("Erreur a la creation du maillage");
 76     SSCRUTE(maa)
 77     return -1;
 78   }
 79 
 80   /* Ecriture des noeuds d'un maillage MED : 
 81      - Des cooordonnees en mode MED_FULL_INTERLACE : (X1,Y1,X2,Y2,X3,Y3,...) 
 82      dans un repere cartesien 
 83      - Des noms (optionnel dans un fichier MED) 
 84      - Des numeros (optionnel dans un fichier MED) 
 85      - Des numeros de familles des noeuds */
 86   if (MEDnoeudsEcr(fid,maa,mdim,coo,MED_FULL_INTERLACE,MED_CART,
 87                    nomcoo,unicoo,nomnoe,MED_VRAI,numnoe,MED_VRAI,
 88                    nufano,nnoe) < 0) {
 89     MESSAGE("Erreur a l'ecriture des noeuds du maillage");
 90     return -1;
 91   }
 92 
 93   /* Fermeture du fichier */
 94   if (MEDfermer(fid) < 0) {
 95     MESSAGE("Erreur a la fermeture du fichier");
 96     return -1;
 97   }
 98 
 99   return 0;
100 }
101 
102 
103 
104