READLINK(2) BSD Programmer's Manual READLINK(2)
readlink - read value of a symbolic link
#include <unistd.h>
int
readlink(const char *path, char *buf, size_t bufsiz);
readlink() places the contents of the symbolic link path in the buffer
buf, which has size bufsiz. readlink does not append a NUL character to
buf.
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 the glo-
bal variable errno.
readlink() will fail if:
[ENOTDIR] A component of the path prefix is not a directory.
[ENAMETOOLONG]
A component of a pathname exceeded {NAME_MAX} characters,
or an entire path name exceeded {PATH_MAX} characters.
[ENOENT] The named file does not exist.
[EACCES] Search permission is denied for a component of the path
prefix.
[ELOOP] Too many symbolic links were encountered in translating the
pathname.
[EINVAL] The named file is not a symbolic link.
[EIO] An I/O error occurred while reading from the file system.
[EFAULT] buf extends outside the process's allocated address space.
lstat(2), stat(2), symlink(2), symlink(7)
The readlink() function call appeared in 4.2BSD.
MirOS BSD #10-current June 4, 1993 1
Generated on 2012-02-20 02:47:02 by $MirOS: src/scripts/roff2htm,v 1.70 2011/12/03 18:21:12 tg Exp $
These manual pages and other documentation are copyrighted by their respective writers;
their source is available at our CVSweb,
AnonCVS, and other mirrors. The rest is Copyright © 2002‒2011 The MirOS Project, Germany.
This product includes material
provided by Thorsten Glaser.
This manual page’s HTML representation is supposed to be valid XHTML/1.1; if not, please send a bug report – diffs preferred.