]> SALOME platform Git repositories - modules/med.git/blob - src/MEDWrapper/V2_1/Core/MEDlFichDes.cxx
Salome HOME
Mantis issue 0021668: [CEA 564] MED2.1 to MED2.3
[modules/med.git] / src / MEDWrapper / V2_1 / Core / MEDlFichDes.cxx
1 /*************************************************************************
2 * COPYRIGHT (C) 1999 - 2002  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 #include "med.hxx"
20 #include "med_outils.hxx"
21 #include <string.h>
22
23 namespace med_2_1{
24
25 med_int
26 MEDlFichDes(med_idt fid)
27 {
28   med_idt attr, root;
29   med_err ret=0;
30   char des[MED_TAILLE_DESC+1];
31   med_int longueur=0;
32   char nom[MED_TAILLE_NOM+1];
33   char chemin[MED_TAILLE_MAA+1];
34
35   /*
36    * On inhibe le gestionnaire d'erreur HDF
37    */
38   _MEDmodeErreurVerrouiller();
39
40   /*
41    * On ouvre le Data Group racine
42    */
43   strncpy(chemin,MED_MAA,MED_TAILLE_MAA-1);
44   chemin[MED_TAILLE_MAA-1] = '\0';
45   if ((root = _MEDdatagroupOuvrir(fid,chemin)) < 0)
46     return -1;
47
48   /*
49    * On regarde si l'attribut existe
50    * Si non => erreur
51    * Si oui => on retourne sa longueur
52    */
53   strcpy(nom,MED_NOM_DESCRIPTEUR);
54  
55   if ((attr = _MEDattrOuvrir(root,nom)) < 0) {
56     _MEDdatagroupFermer(root);
57     longueur=0;
58     return 0;
59   }
60  
61   if ((ret = _MEDattrFermer(attr)) < 0) {
62     _MEDdatagroupFermer(root);
63     return -1;
64   }
65   
66   if ((ret = _MEDattrStringLire(root,nom,MED_TAILLE_DESC,des)) < 0) {
67     _MEDdatagroupFermer(root);
68     return -1;
69   }
70   
71   longueur = (med_int)strlen(des);
72
73   /*
74    * fermetures 
75    */
76   if ((ret = _MEDdatagroupFermer(root)) < 0)
77     return -1;
78
79   return longueur;
80 }
81
82 }