1 /*  This file is part of MED.
2  *
3  *  COPYRIGHT (C) 1999 - 2019  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 <string.h>
22 #include <stdlib.h>
23 #include <med_outils.h>
24 
25 /**\ingroup MEDfield
26   \brief \MEDfieldnComponentBrief
27   \param fid \fid
28   \param ind \ind
29   \retval med_int \ncomponent
30   \details \MEDfieldnComponentDetails
31  */
32 
33 med_int
MEDfieldnComponent(const med_idt fid,const int ind)34 MEDfieldnComponent(const med_idt fid,
35 		   const int ind)
36 {
37   med_err _ret       = -1;
38   char    _fieldname[MED_NAME_SIZE+1]="";
39   int     _num       = ind-1;
40   char    _path        [MED_FIELD_GRP_SIZE+MED_NAME_SIZE+1]=MED_FIELD_GRP;
41   /*
42    * On inhibe le gestionnaire d'erreur HDF
43    */
44   _MEDmodeErreurVerrouiller();
45 
46 
47   /*
48    * On recupere le nom du champ
49    */
50   if ( _MEDobjectGetName(fid, _path ,_num, _fieldname) < 0 ) {
51     MED_ERR_(_ret,MED_ERR_ACCESS,MED_ERR_DATAGROUP,_path);ISCRUTE_int(_num);
52     goto ERROR;
53   }
54 
55   if ( (_ret=MEDfieldnComponentByName( fid, _fieldname )) < 0) {
56     MED_ERR_(_ret,MED_ERR_CALL,MED_ERR_API,MED_ERR_FIELD_MSG);
57     SSCRUTE(_fieldname);SSCRUTE(_path);SSCRUTE("MEDfieldnComponentbyName");
58     goto ERROR;
59   }
60 
61  ERROR:
62   return _ret;
63 }
64 
65