link#
Synopsis#
#include <unistd.h>
int link(const char *path1, const char *path2);
#include <fcntl.h>
int linkat(int fd1, const char *path1, int fd2, const char *path2, int flag);
Status#
Partially implemented
Conformance#
IEEE Std 1003.1-2017
Description#
The link()
function shall create a new link (directory entry) for the existing file, path1.
The path1 argument points to a path name naming an existing file. The path2 argument points to a path name naming
the new directory entry to be created. The link()
function shall atomically create a new link for the existing file
and the link count of the file shall be incremented by one.
If path1 names a directory, link()
shall fail unless the process has appropriate privileges and the implementation
supports using link()
on directories.
If path1 names a symbolic link, it is implementation-defined whether link()
follows the symbolic link, or creates a
new link to the symbolic link itself.
Upon successful completion, link()
shall mark for update the last file status change timestamp of the file. Also, the
last data modification and last file status change timestamps of the directory that contains the new entry shall be
marked for update.
If link()
fails, no link shall be created and the link count of the file shall remain unchanged.
The implementation may require that the calling process has permission to access the existing file.
The linkat()
function shall be equivalent to the link()
function except that symbolic links shall be handled as
specified by the value of flag (see below) and except in the case where either path1 or path2 or both are
relative paths. In this case a relative path path1 is interpreted relative to the directory associated with the
file descriptor fd1 instead of the current working directory and similarly for path2 and the file descriptor fd2.
If the access mode of the open file description associated with the file descriptor is not O_SEARCH,
the function
shall check whether directory searches are permitted using the current permissions of the directory underlying the
file descriptor. If the access mode is O_SEARCH,
the function shall not perform the check.
Values for flag are constructed by a bitwise-inclusive OR of flags from the following list, defined in <fcntl.h>
:
AT_SYMLINK_FOLLOW
If path1 names a symbolic link, a new link for the target of the symbolic link is created.
If linkat()
is passed the special value AT_FDCWD
in the fd1 or fd2 parameter, the current working directory
shall be used for the respective path argument. If both fd1 and fd2 have value AT_FDCWD,
the behavior shall be
identical to a call to link()
, except that symbolic links shall be handled as specified by the value of flag.
If the AT_SYMLINK_FOLLOW
flag is clear in the flag argument and the path1 argument names a symbolic link, a new
link is created for the symbolic link path1 and not its target.
Return value#
Upon successful completion, these functions shall return 0
. Otherwise, these functions shall return -1
and set
errno
to indicate the error.
Errors#
These functions shall fail if:
EACCES
- A component of either path prefix denies search permission, or the requested link requires writing in a directory that denies write permission, or the calling process does not have permission to access the existing file and this is required by the implementation.EEXIST
- The path2 argument resolves to an existing directory entry or refers to a symbolic link.ELOOP
- A loop exists in symbolic links encountered during resolution of the path1 or path2 argument.EMLINK
- The number of links to the file named by path1 would exceedLINK_MAX
.ENAMETOOLONG
- The length of a component of a path name is longer thanNAME_MAX
.ENOENT
- A component of either path prefix does not exist; the file named by path1 does not exist; or path1 or path2 points to an empty string.ENOENT
orENOTDIR
- The path1 argument names an existing non-directory file, and the path2 argument contains at least one non -<slash>
character and ends with one or more trailing<slash>
characters. If path2 without the trailing<slash>
characters would name an existing file, anENOENT
error shall not occur.ENOSPC
- The directory to contain the link cannot be extended.ENOTDIR
- A component of either path prefix names an existing file that is neither a directory nor a symbolic link to a directory, or the path1 argument contains at least one non-<slash>
character and ends with one or more trailing<slash>
characters and the last path name component names an existing file that is neither a directory nor a symbolic link to a directory, or the path1 argument names an existing non-directory file and the path2 argument names a nonexistent file, contains at least one non-<slash>
character, and ends with one or more trailing<slash>
characters.EPERM
- The file named by path1 is a directory and either the calling process does not have appropriate privileges or the implementation prohibits usinglink()
on directories.EROFS
- The requested link requires writing in a directory on a read-only file system.EXDEV
- The link named by path2 and the file named by path1 are on different file systems and the implementation does not support links between file systems.EXDEV
- path1 refers to a namedSTREAM
.
The linkat()
function shall fail if:
EACCES
- The access mode of the open file description associated with fd1 or fd2 is not O_SEARCH and the permissions of the directory underlying fd1 or fd2, respectively, do not permit directory searches.EBADF
- The path1 or path2 argument does not specify an absolute path and the fd1 or fd2 argument, respectively, is neither AT_FDCWD nor a valid file descriptor open for reading or searching.ENOTDIR
- The path1 or path2 argument is not an absolute path and fd1 or fd2, respectively, is a file descriptor associated with a non-directory file.
These functions may fail if:
ELOOP
- More thanSYMLOOP_MAX
symbolic links were encountered during resolution of the path1 or path2 argument.ENAMETOOLONG
- The length of a path name exceedsPATH_MAX
, or path name resolution of a symbolic link produced an intermediate result with a length that exceedsPATH_MAX
.
The linkat()
function may fail if:
EINVAL
- The value of the flag argument is not valid.
Tests#
Untested
Known bugs#
None