_MEDnEquivalence30.c

Aller à la documentation de ce fichier.
00001 /*  This file is part of MED.
00002  *
00003  *  COPYRIGHT (C) 1999 - 2011  EDF R&D, CEA/DEN
00004  *  MED is free software: you can redistribute it and/or modify
00005  *  it under the terms of the GNU Lesser General Public License as published by
00006  *  the Free Software Foundation, either version 3 of the License, or
00007  *  (at your option) any later version.
00008  *
00009  *  MED is distributed in the hope that it will be useful,
00010  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00011  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00012  *  GNU Lesser General Public License for more details.
00013  *
00014  *  You should have received a copy of the GNU Lesser General Public License
00015  *  along with MED.  If not, see <http://www.gnu.org/licenses/>.
00016  */
00017 
00018 
00019 #include <med.h>
00020 #include <med_config.h>
00021 #include <med_outils.h>
00022 
00023 #include <string.h>
00024 #include <stdlib.h>
00025 
00026 void _MEDnEquivalence30(int dummy, ...) {
00027 
00028   va_list params;
00029   va_start(params,dummy);
00030 
00031   const med_idt      fid       = va_arg(params,const med_idt      );
00032   const char * const meshname  = va_arg(params,const char * const );
00033   med_int *          fret      = va_arg(params,      med_int*     );
00034 
00035 
00036 
00037   char             _path[MED_TAILLE_EQS+MED_NAME_SIZE+1]=MED_EQS;
00038   med_int          _ret=-1,_err=-1;
00039   med_size         _tmpn=0;
00040 
00041   /*
00042    * On inhibe le gestionnaire d'erreur HDF 5
00043    */
00044   _MEDmodeErreurVerrouiller();
00045 
00046 
00047   strcat(_path,meshname);
00048 
00049   /*
00050    *  nombre d'équivalence
00051    */
00052   if ( (_err=_MEDnObjects(fid,_path,&_tmpn)) <0)
00053     if ( _err == (MED_ERR_COUNT + MED_ERR_DATAGROUP) ) {
00054       MED_ERR_(_ret,MED_ERR_COUNT,MED_ERR_DATAGROUP,_path);
00055       goto ERROR;
00056    }
00057 
00058   _ret = (med_int) _tmpn;
00059  ERROR:
00060 
00061   va_end(params);
00062   *fret = _ret;
00063   return;
00064 }

Généré le Mon May 16 17:10:22 2011 pour MED fichier par  doxygen 1.6.1