Museum

Home

Lab Overview

Retrotechnology Articles

⇒ Online Manual

Media Vault

Software Library

Restoration Projects

Artifacts Sought

Related Articles

setgroups(2)

getgrent(3C)

grp(5)

types(5)

initgroups(3C)                                               initgroups(3C)

NAME
     initgroups - initialize the supplementary group access list

SYNOPSIS
     #include <grp.h>
     #include <sys/types.h>

     int initgroups(const char *name, gidt basegid);

DESCRIPTION
     initgroups() reads the group file, using getgrent(), to get the group
     membership for the user specified by name and then initializes the
     supplementary group access list of the calling process using
     setgroups(). The basegid group id is also included in the supplemen-
     tary group access list. This is typically the real group id from the
     password file.

     While scanning the group file, if the number of groups, including the
     basegid entry, exceeds NGROUPSMAX, subsequent group entries are
     ignored.

     initgroups() will fail and not change the supplementary group access
     list if:

     EPERM     The effective user id is not superuser.

RESULT
     Upon successful completion, a value of 0 is returned. Otherwise, a
     value of -1 is returned and errno is set to indicate the error.

SEE ALSO
     setgroups(2), getgrent(3C), grp(5), types(5).























Page 1                       Reliant UNIX 5.44                Printed 11/98

Typewritten Software • bear@typewritten.org • Edmonds, WA 98026