#include <grp.h> int getgrent_r(struct group *gbuf, char *buf,
size_t buflen, struct group **gbufp); int fgetgrent_r(FILE *fp, struct group *gbuf, char *buf,
size_t buflen, struct group **gbufp);
Exigences de macros de test de fonctionnalités pour la glibc (voir feature_test_macros(7)) :
getgrent_r() :
_GNU_SOURCE
fgetgrent_r() :
_SVID_SOURCE
La structure group est définie dans <grp.h> de la manière suivante :
struct group { char *gr_name; /* Nom du groupe */ char *gr_passwd; /* Mot de passe du groupe */ gid_t gr_gid; /* Identifiant du groupe */ char **gr_mem; /* Membres du groupe */ };
Les fonctions non réentrantes renvoient un pointeur sur une zone statique, zone qui contient d'autres pointeurs vers le nom, le mot de passe et les membres du groupe. Les fonctions réentrantes décrites ici renvoient tout ceci dans des tampons fournis par l'appelant. Il y a tout d'abord le tampon gbuf qui contient une structure group. Puis le tampon buf de taille buflen qui contient les chaînes supplémentaires. Le résultat de ces fonctions, la structure group lue dans le flux, est enregistré dans le tampon *gbuf fourni, et un pointeur vers cette structure group est renvoyé dans *gbufp.
struct group *getgrent_r(struct group *grp, char *buf, int buflen);
ou mieux,
int getgrent_r(struct group *grp, char *buf, int buflen, FILE **gr_fp);
#define _GNU_SOURCE #include <grp.h> #include <stdio.h> #include <stdlib.h> #define BUFLEN 4096 int main(void) { struct group grp, *grpp; char buf[BUFLEN]; int i; setgrent(); while (1) { i = getgrent_r(&grp, buf, BUFLEN, &grpp); if (i) break; printf("%s (%d):", grpp->gr_name, grpp->gr_gid); for (i = 0; ; i++) { if (grpp->gr_mem[i] == NULL) break; printf(" %s", grpp->gr_mem[i]); } printf("\n"); } endgrent(); exit(EXIT_SUCCESS); }
Ce document est une traduction réalisée par Alain Portal <aportal AT univ-montp2 DOT fr> le 8 juillet 2005 et révisée le 17 juillet 2008.
L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 3 getgrent_r ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.
Dernière mise à jour : 17 juillet 2008