unlink(S-osr5)
unlink --
remove directory entry
Syntax
cc ... -lc
int unlink (path)
char *path;
Description
The unlink function removes the link named by the
pathname pointed to by path and decrements the link
count of the file referenced by the link.
When the file's link count becomes zero and no process has the
file open, the space occupied by the file is freed and the file
is no longer accessible.  If one or more processes have the file
open when the last link is removed, the link is removed before
unlink returns, but the removal of the file contents is
postponed until all references to the file have been closed.
Upon successful completion, unlink marks for update the
``st_ctime'' and ``st_mtime'' fields of the parent
directory.  Also, if the file's link count is not zero, the
``st_ctime''
and
``st_mtime''
fields of the file are marked for update.
If all of the following conditions are true, a file is not unlinked:
- 
The parent directory has the sticky bit set
 
- 
The file is not writable by the user
 
- 
The user does not own the parent directory
 
- 
The user does not own the file
 
- 
The user is not root
When all links to a file have been removed and no process has the
file open, the space occupied by the file is freed and the file
ceases to exist.  If one or more processes have the file open
when the last link is removed, the removal is postponed until all
references to the file have been closed.
Return value
Upon successful completion, a value of 0 is returned.
Otherwise, a value of -1 is returned and
errno is set to indicate the error.
Diagnostics
The unlink function will fail and not unlink the file if:
 [EACCES]
- 
Search permission is denied for a component of the
path prefix, or write permission is denied on the directory
containing the link to be removed.
 [EBUSY]
- 
The entry to be unlinked is the mount point for a mounted file system.
 [EINTR]
- 
A signal was caught during the unlink system call.
 [EMULTIHOP]
- 
Components of path require hopping to multiple
remote machines.
 [ENAMETOOLONG]
- 
The length of the path string exceeds
PATH_MAX or a pathname component is longer than
NAME_MAX while _POSIX_NO_TRUNC is in effect.
 [ENOENT]
- 
The named file does not exist, or the path argument
points to an empty string.
 [ENOLINK]
- 
path points to a remote machine and the link
to that machine is no longer active.
 [ENOTDIR]
- 
A component of the path prefix is not a directory.
 [EPERM]
- 
The named file is a directory and the effective user
ID of the process is not super user.
 [EROFS]
- 
The directory entry to be unlinked is part of a
read-only file system.
 [ETXTBSY]
- 
The entry to be unlinked is the last link to
a pure procedure (shared text) file
that is being executed.
Warning
unlink and
link(S-osr5)
do exactly as instructed, using
only the error checking as described.
For example, a call to unlink a directory will succeed even if the
directory still contains files.
See also
close(S-osr5),
link(S-osr5),
open(S-osr5),
rm(C),
stat(S-osr5)
Standards conformance
unlink is conformant with:
X/Open Portability Guide, Issue 3, 1989
;
Intel386 Binary Compatibility Specification, Edition 2 (iBCSe2)
;
IEEE POSIX Std 1003.1-1990 System Application Program Interface (API) [C Language] (ISO/IEC 9945-1)
;
and
NIST FIPS 151-1
.
© 2005 The SCO Group, Inc.  All rights reserved.
SCO OpenServer Release 6.0.0 -- 02 June 2005