1 /************************************************************************* 2 * COPYRIGHT (C) 1999 - 2003 EDF R&D 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 /****************************************************************************** 21 * - Nom du fichier : test21.c 22 * 23 * - Description : ecriture de valeurs scalaires numeriques dans un fichier MED 24 * 25 *****************************************************************************/ 26 27 #include <med.h> 28 #include <med_utils.h> 29 #include <stdio.h> 30 31 int main () 32 { 33 med_err ret; 34 med_idt fid; 35 char nom_scalaire1[MED_TAILLE_NOM+1] = "VariableEntiere"; 36 char description1[MED_TAILLE_DESC+1] = "Une premiere description"; 37 char nom_scalaire2[MED_TAILLE_NOM+1] = "VariableFlottante"; 38 char description2[MED_TAILLE_DESC+1] = "Une seconde description"; 39 med_int vali1 = 56; 40 med_int vali2 = -789; 41 med_float valr1 = 67.98; 42 43 /* Creation du fichier test21.med */ 44 if ((fid = MEDouvrir("test21.med",MED_CREATION)) < 0) { 45 MESSAGE("Erreur a la creation du fichier test21.med"); 46 return -1; 47 } 48 49 /* Creation d'un variable scalaire entiere */ 50 if (MEDscalaireCr(fid,nom_scalaire1,MED_INT,description1) < 0) { 51 MESSAGE("Erreur a la creation d'une variable scalaire entière"); 52 return -1; 53 } 54 printf("Creation d'une variable scalaire entiere \n"); 55 56 /* Ecriture d'un valeur sans pas de temps et sans numero d'ordre*/ 57 if (MEDscalaireEntierEcr(fid,nom_scalaire1,vali1,MED_NOPDT,"",0.0,MED_NONOR) < 0) { 58 MESSAGE("Erreur a l'ecriture d'une valeur entiere"); 59 return -1; 60 } 61 printf("Ecriture d'une valeur entiere sans pas de temps \n"); 62 63 /* Ecriture d'une valeur entiere avec 1 pas de temps et sans numero d'ordre */ 64 if (MEDscalaireEntierEcr(fid,nom_scalaire1,vali2,1,"ms",5.5,MED_NONOR) < 0) { 65 MESSAGE("Erreur a l'ecriture d'une valeur entiere"); 66 return -1; 67 } 68 printf("Ecriture d'une valeur entiere avec pas de temps \n"); 69 70 /* Creation d'un variable scalaire flottante */ 71 if (MEDscalaireCr(fid,nom_scalaire2,MED_FLOAT64,description2) < 0) { 72 MESSAGE("Erreur a la creation d'une variable scalaire flottante"); 73 return -1; 74 } 75 printf("Creation d'une variable scalaire flottante \n"); 76 77 /* Ecriture d'une valeur reelle avec 1 pas de temps et 1 numero d'ordre */ 78 if (MEDscalaireFlottantEcr(fid,nom_scalaire2,valr1,1,"ms",5.5,2) < 0) { 79 MESSAGE("Erreur a l'ecriture d'une valeur flottante"); 80 return -1; 81 } 82 printf("Ecriture d'une valeur reelle avec pas de temps et numero d'ordre \n"); 83 84 /* Fermeture du fichier */ 85 if (MEDfermer(fid) < 0) { 86 MESSAGE("Erreur a la fermeture du fichier"); 87 return -1; 88 } 89 90 return 0; 91 }