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 
20 #include <med.h>
21 #include <med_config.h>
22 #include <med_outils.h>
23 #include <string.h>
24 
_MEDobjectGetRank(const med_idt gid,const char * const linkname,med_size * const rank)25 med_err _MEDobjectGetRank(const med_idt        gid,
26 			  const char * const   linkname,
27 			  med_size *    const  rank )
28 {
29   med_err        _ret=-1;
30   H5L_info_t      _linkinfo;
31 
32   if ( H5Lget_info( gid, linkname,  &_linkinfo, H5P_DEFAULT ) >= 0 ) {
33     if ( _linkinfo.type == H5L_TYPE_HARD ) {
34       if ( _linkinfo.corder_valid) {
35 	*rank = (med_size) _linkinfo.corder;
36       } else {
37 	MED_ERR_(_ret,MED_ERR_ACCESS,MED_ERR_DATAGROUP,linkname);
38 	ISCRUTE_int(_linkinfo.corder_valid);
39       goto ERROR;
40 
41       }
42     }else{
43       MED_ERR_(_ret,MED_ERR_INVALID,MED_ERR_DATATYPE,MED_ERR_DATAGROUP_MSG);
44       SSCRUTE(linkname);
45       goto ERROR;
46     }
47   } else  {
48     MED_ERR_(_ret,MED_ERR_ACCESS,MED_ERR_DATAGROUP,linkname);
49     goto ERROR;
50   }
51 
52   _ret = 0;
53  ERROR:
54 
55   return _ret;
56 }
57