SETMODE(3) | Library Functions Manual | SETMODE(3) |
getmode
, setmode
— modify mode bits
#include
<unistd.h>
mode_t
getmode
(const
void *set, mode_t
mode);
void *
setmode
(const
char *mode_str);
The
getmode
()
function returns a copy of the file permission bits
mode as altered by the values pointed to by
set. While only the mode bits are altered, other parts
of the file mode may be examined.
The
setmode
()
function takes an absolute (octal) or symbolic value, as described in
chmod(1), as an argument and returns a
pointer to mode values to be supplied to getmode
().
Because some of the symbolic values are relative to the file creation mask,
setmode
() may call
umask(2). If this occurs, the file
creation mask will be restored before setmode
()
returns. If the calling program changes the value of its file creation mask
after calling setmode
(),
setmode
() must be called again if
getmode
() is to modify future file modes
correctly.
If the mode passed to
setmode
()
is invalid, setmode
() returns
NULL
. The caller is responsible for freeing the
pointer that setmode
() returns.
The setmode
() function may fail and set
errno for any of the errors specified for the library
routine malloc(3) or to
ERANGE
if an invalid octal value was specified, or
EINVAL
if an invalid symbolic value was
specified.
The getmode
() and
setmode
() functions first appeared in
4.4BSD.
June 5, 2013 | OpenBSD-current |