NAME
readlink - read value of a symbolic link
SYNOPSIS
#include <unistd.h>
I ssize_t readlink(const char * path , char * buf , size_t bufsiz );
DESCRIPTION
R readlink ()
places the contents of the symbolic link
path
in the buffer
R buf ,
which has size
R bufsiz .
R readlink ()
does not append a null byte to
R buf .
It will truncate the contents (to a length of
bufsiz
characters), in case the buffer is too small to hold all of the contents.
RETURN VALUE
The call returns the count of characters placed in the buffer
if it succeeds, or a -1 if an error occurs, placing the error
code in
R errno .
ERRORS
EACCES
Search permission is denied for a component of the path prefix.
(See also
path_resolution(7).)
EFAULT
buf
extends outside the process's allocated address space.
EINVAL
bufsiz
is not positive.
EINVAL
The named file is not a symbolic link.
EIO
An I/O error occurred while reading from the file system.
ELOOP
Too many symbolic links were encountered in translating the pathname.
ENAMETOOLONG
A pathname, or a component of a pathname, was too long.
ENOENT
The named file does not exist.
ENOMEM
Insufficient kernel memory was available.
ENOTDIR
A component of the path prefix is not a directory.
CONFORMING TO
4.4BSD (the
R readlink ()
function call appeared in 4.2BSD),
POSIX.1-2001.
NOTES
In versions of glibc up to and including glibc 2.4, the return type of
R readlink ()
was declared as
R int .
Nowadays, the return type is declared as
R ssize_t ,
as (newly) required in POSIX.1-2001.
SEE ALSO