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 : test18.c
21 *
22 * - Description : routines de test de la conformite d'un fichier 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_idt fid;
42 med_int majeur, mineur, release;
43
44 /* Creation du fichier test18.med */
45 if ((fid = MEDouvrir("test18.med",MODE_ACCES)) < 0) {
46 MESSAGE("Erreur a la creation du fichier test18.med");
47 return -1;
48 }
49 fprintf(stdout,"- Creation du fichier test18.med \n");
50
51 if (MEDfermer(fid) < 0) {
52 MESSAGE("Erreur a la fermeture du fichier");
53 return -1;
54 }
55 fprintf(stdout,"- Fermeture du fichier \n");
56
57 /*
58 * Quelle version de la bibliotheque MED est utilisee ?
59 */
60 MEDversionDonner(&majeur, &mineur, &release);
61 fprintf(stdout,"- Version de MED utilisee pour lire le fichier : %d.%d.%d \n",majeur,mineur,release);
62 /*
63 * Le fichier à lire est-il au bon format de fichier HDF ?
64 */
65 if (! MEDformatConforme("test18.med"))
66 fprintf(stdout,"- Format HDF du fichier MED conforme au format HDF utilise par la bibliotheque \n");
67 else
68 fprintf(stdout,"- Format HDF du fichier MED non conforme au format HDF utilise par la bibliotheque \n");
69
70 /*
71 * Le fichier a lire a-t-il été créé avec une version de la bibliothèque MED conforme avec celle utilise ?
72 * (Numéros majeur et mineur identiques).
73 */
74 if (! MEDversionConforme("test18.med"))
75 fprintf(stdout,"- Version MED du fichier conforme a la bibliotheque MED utilisee \n");
76 else
77 fprintf(stdout,"- Version MED du fichier non conforme a la bibliotheque MED utilisee \n");
78
79 if ((fid = MEDouvrir("test18.med",MED_LECTURE)) < 0) {
80 MESSAGE("Erreur a l'ouverture du fichier test18.med");
81 return -1;
82 }
83 fprintf(stdout,"- Ouverture du fichier en lecture \n");
84
85 /*
86 * Une fois le fichier ouvert on peut avoir acces au numero de version complet
87 */
88 if (MEDversionLire(fid, &majeur, &mineur, &release) < 0) {
89 MESSAGE("Erreur a la lecture du numero de version de la bibliothèque ");
90 return -1;
91 }
92 fprintf(stdout,"- Ce fichier a ete cree avec MED %d.%d.%d \n",majeur,mineur,release);
93
94 if (MEDfermer(fid) < 0) {
95 MESSAGE("Erreur a la fermeture du fichier");
96 return -1;
97 }
98 fprintf(stdout,"- Fermeture du fichier \n");
99
100 return 0;
101 }