ACL_SET(3) Library Functions Manual ACL_SET(3)

acl_set_fd, acl_set_fd_np, acl_set_file, acl_set_link_npset an ACL for a file

Standard C Library (libc, -lc)

#include <sys/types.h>
#include <sys/acl.h>

int
acl_set_fd(int fd, acl_t acl);

int
acl_set_fd_np(int fd, acl_t acl, acl_type_t type);

int
acl_set_file(const char *path_p, acl_type_t type, acl_t acl);

int
acl_set_link_np(const char *path_p, acl_type_t type, acl_t acl);

The (), (), (), and acl_set_link_np() each associate an ACL with an object referred to by fd or path_p. The acl_set_fd_np() and acl_set_link_np() functions are not POSIX.1e calls. The acl_set_fd() function allows only the setting of ACLs of type ACL_TYPE_EXTENDED where as acl_set_fd_np() allows the setting of ACLs of any type.

Upon successful completion, the value 0 is returned; otherwise the value -1 is returned and the global variable errno is set to indicate the error.

If any of the following conditions occur, these functions shall return -1 and set errno to the corresponding value:

[]
Search permission is denied for a component of the path prefix, or the object exists and the process does not have appropriate access rights.
[]
The fd argument is not a valid file descriptor.
[]
Argument acl does not point to a valid ACL for this object, or the ACL type specified in type is invalid for this object, or both.
[]
A component of a pathname exceeded 255 characters, or an entire path name exceeded 1023 characters.
[]
The named object does not exist, or the path_p argument points to an empty string.
[]
Insufficient memory available to fulfill request.
[]
The directory or file system that would contain the new ACL cannot be extended, or the file system is out of file allocation resources.
[]
The file system does not support ACL retrieval.
[]
This function requires modification of a file system which is currently read-only.

acl(3), acl_delete(3), acl_get(3), acl_valid(3), posix1e(3)

POSIX.1e is described in IEEE POSIX.1e draft 17.

Michael Smith
Robert N M Watson

December 29, 2002 macOS 15.0