/*
  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;
}