ADC Home > Reference Library > Reference > Mac OS X > Mac OS X Man Pages

 

This document is a Mac OS X manual page. Manual pages are a command-line technology for providing documentation. You can view these manual pages locally using the man(1) command. These manual pages come from many different sources, and thus, have a variety of writing styles.

This manual page is associated with the Mac OS X developer tools. The software or headers described may not be present on your Mac OS X installation until you install the developer tools package. This package is available on your Mac OS X installation DVD, and the latest versions can be downloaded from developer.apple.com.

For more information about the manual page format, see the manual page for manpages(5).



SETREGID(2)                 BSD System Calls Manual                SETREGID(2)

NAME
     setregid -- set real and effective group ID

LIBRARY
     Standard C Library (libc, -lc)

SYNOPSIS
     #include <unistd.h>

     int
     setregid(gid_t rgid, gid_t egid);

DESCRIPTION
     The real and effective group ID's of the current process are set to the arguments.  Unprivileged users
     may change the real group ID to the effective group ID and vice-versa; only the super-user may make
     other changes.

     Supplying a value of -1 for either the real or effective group ID forces the system to substitute the
     current ID in place of the -1 parameter.

     The setregid() function was intended to allow swapping the real and effective group IDs in set-group-ID
     programs to temporarily relinquish the set-group-ID value.  This function did not work correctly; its
     purpose is now better served by the use of the setegid() function (see setuid(2)).

     When setting the real and effective group IDs to the same value, the standard setgid() function is pre-ferred. preferred.
     ferred.

RETURN VALUES
     The setregid() function returns the value 0 if successful; otherwise the value -1 is returned and the
     global variable errno is set to indicate the error.

ERRORS
     [EPERM]            The current process is not the super-user and a change other than changing the
                        effective group-id to the real group-id was specified.

SEE ALSO
     getgid(2), issetugid(2), setegid(2), setgid(2), setuid(2)

HISTORY
     The setregid() system call appeared in 4.2BSD.

BSD                             April 16, 1994                             BSD

Did this document help you?
Yes: Tell us what works for you.
It’s good, but: Report typos, inaccuracies, and so forth.
It wasn’t helpful: Tell us what would have helped.