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 : test2.c
 21  *
 22  * - Description : exemples de creation de maillages MED.
 23  *
 24  *****************************************************************************/
 25 
 26 #include <med.h>
 27 #define MESGERR
 28 #include <med_utils.h>
 29 
 30 #ifdef DEF_LECT_ECR
 31 #define MODE_ACCES MED_LECTURE_ECRITURE
 32 #elif DEF_LECT_AJOUT
 33 #define MODE_ACCES MED_LECTURE_AJOUT
 34 #else
 35 #define MODE_ACCES MED_CREATION
 36 #endif
 37 
 38 int main (int argc, char **argv)
 39 
 40 {
 41   med_err ret=0;
 42   med_idt fid;
 43   char des[MED_TAILLE_DESC+1]="";
 44 
 45   /* Verification de la conformite du format med du fichier test1.med */
 46   ret = MEDformatConforme("test1.med");
 47   if (ret < 0) {
 48     MESSAGE("Format HDF non conforme ou fichier inexistant");
 49     return -1;
 50   }
 51 
 52   /* Ouverture en mode de lecture du fichier "test1.med" */
 53   fid = MEDouvrir("test1.med",MED_LECTURE);
 54   if (fid < 0) {
 55       MESSAGE("Erreur a l'ouverture du fichier test1.med en mode MED_LECTURE");
 56       return -1;
 57   }
 58 
 59   /* Affiche de l'en-tete du fichier */
 60   ret = MEDfichEntete(fid,MED_FICH_DES, des);
 61   if (ret == 0)
 62     printf("En-tete du fichier test1.med : %s\n",des);
 63   else {
 64     MESSAGE("Erreur a la lecture de l'en-tete du fichier test1.med");
 65     ret = -1;
 66   }
 67 
 68   /* Fermeture du fichier test1.med */
 69   ret = MEDfermer(fid);
 70   if (ret < 0) {
 71     MESSAGE("Erreur a la fermeture du fichier test1.med");
 72     return -1;
 73   }
 74 
 75   /* Ouverture en mode creation du fichier test2.med */
 76   fid = MEDouvrir("test2.med",MODE_ACCES);
 77   if (fid < 0) {
 78     MESSAGE("Erreur a la creation du fichier test2.med");
 79     return -1;
 80   }
 81 
 82   /* Creation du maillage "maa1" de type MED_NON_STRUCTURE
 83      et de dimension 3 */
 84   if (MEDmaaCr(fid,"maa1",3,MED_NON_STRUCTURE,
 85                       "un premier maillage") < 0) {
 86     MESSAGE("Erreur a la creation du maillage maa1");
 87     ret = -1;
 88   }
 89 
 90   /* Ecriture du nom universel pour "maa1" */
 91   if (MEDunvCr(fid,"maa1") < 0) {
 92     MESSAGE("Erreur a la creation du nom universel de maa1");
 93     ret = -1;
 94   }
 95 
 96   /* Creation du maillage "maa2" de type MED_NON_STRUCTURE
 97      et de dimension 2 */
 98   if (MEDmaaCr(fid,"maa2",2,MED_NON_STRUCTURE,
 99                       "un second maillage") < 0) {
100     MESSAGE("Erreur a la creation du maillage maa2");
101     ret = -1;
102   }
103 
104   /* Ecriture de la dimension de l'espace : Maillage de 
105      dimension 2 dans un espace de dimension 3 */
106   if (MEDdimEspaceCr(fid,"maa2",3) < 0) {
107     MESSAGE("Erreur a l'ecriture de la dimension de l'espace");
108     ret = -1;
109   }
110 
111   /* Creation du maillage "maa3" de type MED_STRUCTURE
112      et de dimension 1 */
113   if (MEDmaaCr(fid,"maa3",1,MED_STRUCTURE,
114                       "un troisieme maillage") < 0) {
115     MESSAGE("Erreur a la creation du maillage maa3");
116     ret = -1;
117   }
118 
119   /* Fermeture du fichier */
120   if ((ret = MEDfermer(fid))  < 0) {
121     MESSAGE("Erreur a la fermeture du fichier");
122     return -1;
123   }
124 
125   return ret;
126 }
127 
128 
129 
130