MED fichier
medconforme.c
Aller à la documentation de ce fichier.
1 /* This file is part of MED.
2  *
3  * COPYRIGHT (C) 1999 - 2016 EDF R&D, CEA/DEN
4  * MED is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU Lesser General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  *
9  * MED is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public License
15  * along with MED. If not, see <http://www.gnu.org/licenses/>.
16  */
17 
18 
19 #include <med.h>
20 #include <med_config.h>
21 #include <med_utils.h>
22 #include <stdlib.h>
23 
24 
25 
26 int main(int argc, char *argv[]) {
27  med_idt fid;
28  med_int majeur, mineur, release;
29  med_err ret=-1;
30  med_bool hdfok=MED_FALSE;
31  med_bool medok=MED_FALSE;
32 
33  if (argc != 2) {
34  fprintf(stdout,">> Utilisation : medconforme <nom_de_fichier_med> \n");
35  return 0;
36  }
37 
38  /*
39  * Quelle version de la bibliotheque MED est utilisee ?
40  */
41  ret=MEDlibraryNumVersion(&majeur, &mineur, &release);
42  EXIT_IF( ret<0 ,
43  "Erreur d'appel de la routine MEDlibraryNumVersion.", NULL );
44  fprintf(stdout,"- Version de MED-fichier utilisée par medconforme : "IFORMAT"."IFORMAT"."IFORMAT" \n",majeur,mineur,release);
45 
46  /*
47  * Le fichier à lire est-il au bon format de fichier HDF ?
48  */
49 
50  EXIT_IF(MEDfileCompatibility(argv[1],&hdfok,&medok) < 0,
51  "Fichier non conforme.", NULL);
52  if ( hdfok )
53  fprintf(stdout,"- Format HDF du fichier MED [%s] conforme au format HDF utilisé par la bibliothèque \n",argv[1]);
54  else {
55  fprintf(stdout,"- Format HDF du fichier MED [%s] non conforme au format HDF utilisé par la bibliothèque \n",argv[1]);
56  return -1;
57  }
58 
59  /*
60  * Le fichier à lire a-t-il été créé avec une version de la bilbiothèque MED conforme avec celle utilisée ?
61  * (Numéros majeur et mineur identiques).
62  */
63  if ( medok )
64  fprintf(stdout,"- Version MED du fichier [%s] conforme a la bibliothèque MED utilisée \n",argv[1]);
65  else
66  fprintf(stdout,"- Version MED du fichier [%s] non conforme avec celle de la bibliothèque utilisée \n",argv[1]);
67 
68  fid = MEDfileOpen(argv[1],MED_ACC_RDONLY);
69  if (fid < 0)
70  fprintf(stderr,">> ERREUR a l'ouverture du fichier [%s] \n",argv[1]);
71 
72  /*
73  * Une fois le fichier ouvert on peut avoir acces au numero de version complet
74  */
75  ret = MEDfileNumVersionRd(fid, &majeur, &mineur, &release);
76  EXIT_IF(ret < 0,"Lecture du numéro de version",NULL);
77 
78  fprintf(stdout,"- Ce fichier a ete créé avec MED V"IFORMAT"."IFORMAT"."IFORMAT" \n",majeur,mineur,release);
79 
80  ret = MEDfileClose(fid);
81  EXIT_IF(ret < 0,"Fermeture du fichier",argv[1]);
82 
83  return 0;
84 }
herr_t med_err
Definition: med.h:310
int main(int argc, char *argv[])
Definition: medconforme.c:26
MEDC_EXPORT med_idt MEDfileOpen(const char *const filename, const med_access_mode accessmode)
Ouverture d'un fichier MED.
Definition: MEDfileOpen.c:41
#define IFORMAT
Definition: med_utils.h:144
MEDC_EXPORT med_err MEDfileNumVersionRd(const med_idt fid, med_int *const major, med_int *const minor, med_int *const release)
Lecture du numéro de version de la bibliothèque MED utilisée pour créer le fichier.
int med_int
Definition: med.h:316
MEDC_EXPORT med_err MEDfileClose(med_idt fid)
Fermeture d'un fichier MED.
Definition: MEDfileClose.c:30
#define EXIT_IF(expression, message, arg)
Definition: med_utils.h:335
Definition: med.h:240
hid_t med_idt
Definition: med.h:309
MEDC_EXPORT med_err MEDlibraryNumVersion(med_int *const major, med_int *const minor, med_int *const release)
Renvoie les 3 numéros de version de la librairie MED.
med_bool
Definition: med.h:240
MEDC_EXPORT med_err MEDfileCompatibility(const char *const filename, med_bool *const hdfok, med_bool *const medok)
Vérification de la compatibilité d'un fichier avec HDF et MED.