/*
Copyright ICARE
Contributeur : SIX Bruno, Juin 2006
Bruno.Six@univ-lille1.fr
Ce logiciel est régi par la licence CeCILL soumise au droit français et
respectant les principes de diffusion des logiciels libres. Vous pouvez
utiliser, modifier et/ou redistribuer ce programme sous les conditions de la
licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA sur le site
"http://www.cecill.info".
En contrepartie de l'accessibilité au code source et des droits de copie, de
modification et de redistribution accordés par cette licence, il n'est offert
aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons, seule une
responsabilité restreinte pèse sur l'auteur du programme, le titulaire des
droits patrimoniaux et les concédants successifs.
A cet égard, l'attention de l'utilisateur est attirée sur les risques associés
au chargement, à l'utilisation, à la modification et/ou au développement et à
la reproduction du logiciel par l'utilisateur étant donné sa spécificité de
logiciel libre, qui peut le rendre complexe à manipuler et qui le réserve donc
à des développeurs et des professionnels avertis possédant des connaissances
informatiques approfondies. Les utilisateurs sont donc invités à charger et
tester l'adéquation du logiciel à leurs besoins dans des conditions permettant
d'assurer la sécurité de leurs systèmes et ou de leurs données et, plus
généralement, à l'utiliser et l'exploiter dans les mêmes conditions de
sécurité.
Le fait que vous puissiez accéder à cet en-tête signifie que vous avez pris
connaissance de la licence CeCILL, et que vous en avez accepté les termes.
*/
/**
* \file hdf_get_obj_att.c
* \brief Récupération des attributs d'un objet HDF
*
* Cette fonction retourne une structure décrivant les attribut d'un objet HDF.
* Voir hdfatt.h pour la définition de cette structure.
*
* Elle retourne 0 en cas de succès, 1 en cas d'erreur HDF et 2 pour toute
* autre erreur
* ----------------------------------------------------------------------------
*
* Spécification: int hdf_get_obj_att(int32 obj_id, int32 nbatt,
* struct hdfatt **att);
*
* ----------------------------------------------------------------------------
*
* \author SIX Bruno, CGTD ICARE
* \author CRI USTL, Domaine Universitaire Scientifique
* \version 1.0.0
* \date 2006-06-09
*
* ----------------------------------------------------------------------------
*
* Modifications, révisions:
*
* ----------------------------------------------------------------------------
*
*/
#include
int hdf_get_obj_att(
/** Identificateur HDF de l'objet */ int32 obj_id,
/** Nombre d'attributs de l'objet */ int32 nbatt,
/** Pointeur sur la table des attributs à renseigner */ struct hdfatt **att )
{
int32 iatt; /* Indice de l'attribut courant */
int8 *attdat; /* Zone mémoire pour la récupération des valeurs de l'attribut courant */
/* Allocation de la table d'attributs pour cet objet */
if ((*att = (struct hdfatt *)malloc(nbatt*sizeof(struct hdfatt))) == NULL) goto ERR_STD;
/* DEBUT DE BOUCLE SUR LES ATTRIBUTS A EXTRAIRE */
for (iatt = 0; iatt < nbatt; iatt++) {
/* Récupération des informations sur l'attribut courant */
if (SDattrinfo(obj_id, iatt, (*att + iatt)->name, &((*att + iatt)->typ),
&((*att + iatt)->dim)) < 0) goto ERR_HDF;
/* Alloc. de la zone mémoire pour l'extraction des valeurs de l'attribut */
if ((attdat = (int8 *)malloc((1+(*att + iatt)->dim)*DFKNTsize((*att + iatt)->typ)))
== NULL) goto ERR_STD;
attdat[(*att + iatt)->dim] = 0;
/* Extraction des valeur de cet attribut */
if (SDreadattr(obj_id, iatt, attdat) < 0) goto ERR_HDF;
(*att + iatt)->data = (VOIDP)attdat;
}
/* Fin normale de la fonction */
return 0;
ERR_HDF: /* Fin de la fonction sur une erreur HDF locale */
HEprint(stderr, 0);
return 1;
ERR_STD: /* Fin de la fonction sur une autre erreur locale */
perror("ERROR");
return 2;
}