Salome HOME
Merge from V6_main_20120808 08Aug12
[modules/med.git] / src / MEDWrapper / V2_1 / Core / MEDchampInfo.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
22 #include <cstring>
23
24 namespace med_2_1{
25
26 med_err 
27 MEDchampInfo(med_idt fid,int indice,char *champ,
28              med_type_champ *type,char *comp,char *unit, 
29              med_int ncomp)
30 {
31   med_err ret=0;
32   med_idt gid;
33   char chemin[MED_TAILLE_CHA+MED_TAILLE_LNOM+1]; //SRN: Changed to MED_TAILLE_LNOM to avoid a crash 
34                                                  //     in case if a field name longer than MED_TAILLE_NOM
35   int num;
36
37   /*
38    * On inhibe le gestionnaire d'erreur HDF 5
39    */
40   _MEDmodeErreurVerrouiller();
41
42   /*
43    * On recupere le nom du champ
44    */
45   num = indice - 1;
46   strcpy(chemin,MED_CHA);
47   if ((ret = _MEDobjetIdentifier(fid,chemin,num,champ)) < 0)
48     return -1;
49
50   if(strlen(champ) > MED_TAILLE_NOM) return -1;
51
52   /* 
53    * Si le Data Group cha n'existe pas => erreur
54    */
55   strcat(chemin,champ);
56   if ((gid = _MEDdatagroupOuvrir(fid,chemin)) < 0)
57     return -1;
58
59
60   /*
61    * La liste des attributs
62    */
63
64   // MPV 05.10.2006
65   // BUG IPAL 13482: on 64bit Mandriva OS sizeof(med_int)=8, but sizeof(med_type_champ)=4
66   med_int aType;
67   //  if ((ret = _MEDattrEntierLire(gid,MED_NOM_TYP,(med_int*) type)) < 0)
68   if ((ret = _MEDattrEntierLire(gid,MED_NOM_TYP,&aType)) < 0)
69     return -1;
70   *type = (med_type_champ)aType;
71   
72   if ((ret = _MEDattrStringLire(gid,MED_NOM_NOM,ncomp*MED_TAILLE_PNOM,
73                                 comp)) < 0)
74     return -1;
75   if ((ret = _MEDattrStringLire(gid,MED_NOM_UNI,ncomp*MED_TAILLE_PNOM,
76                                 unit)) < 0)
77     return -1;
78
79   /*
80    * On ferme tout
81    */
82   if ((ret = _MEDdatagroupFermer(gid)) < 0)
83     return -1; 
84
85   return 0;
86 }
87
88 }