man.bsd.lv manual page server

Manual Page Search Parameters
GETGRENT(3) Library Functions Manual GETGRENT(3)

getgrent, getgrgid, getgrnam, setgrent, endgrent - get group file entry

#include <grp.h>

struct group *getgrent();

struct group *getgrgid(gid) int gid;

struct group *getgrnam(name) char *name;

int setgrent();

int endgrent();

Getgrent, getgrgid and getgrnam each return pointers to an object with the following structure containing the broken-out fields of a line in the group file.

struct	group { /* see getgrent(3) */
	char	*gr_name;
	char	*gr_passwd;
	int	gr_gid;
	char	**gr_mem;
};

The members of this structure are:

The name of the group.
The encrypted password of the group.
The numerical group-ID.
Null-terminated vector of pointers to the individual member names.

Getgrent simply reads the next line while getgrgid and getgrnam search until a matching gid or name is found (or until EOF is encountered). Each routine picks up where the others leave off so successive calls may be used to search the entire file.

A call to setgrent has the effect of rewinding the group file to allow repeated searches. Endgrent may be called to close the group file when processing is complete.

/etc/group

getlogin(3), getpwent(3), group(5)

A null pointer (0) is returned on EOF or error.

All information is contained in a static area so it must be copied if it is to be saved.

UNIX-7