1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167
|
<TITLE>access</TITLE>
<body bgcolor="#ffffcc">
<hr>
<pre>
<h3>ACCESS(2) Linux Programmer's Manual ACCESS(2)
</h3>
<h3>NAME
</h3> access - check user's permissions for a file
<h3>SYNOPSIS
</h3> #include <unistd.h>
int access(const char *pathname, int mode);
<h3>DESCRIPTION
</h3> access checks whether the process would be allowed to
read, write or test for existence of the file (or other
file system object) whose name is pathname.
mode is a mask consisting of one or more of R_OK, W_OK,
X_OK and F_OK.
R_OK, W_OK and X_OK request testing for reading, writing
and executing the file, respectively. F_OK requests
checking whether merely testing for the existence of the
file would be allowed (this depends on the permissions of
the directories in the path to the file, as given in path-
name.)
The check is done with the process's real uid and gid,
rather than with the effective ids as is done when actu-
ally attempting an operation. This is to allow set-UID
programs to easily determine the invoking user's author-
ity.
Only access bits are checked, not the file type or con-
tents. Therefore, if a directory is found to be
"writable," it probably means that files can be created in
the directory, and not that the directory can be written
as a file. Similarly, a DOS file may be found to be "exe-
cutable," but the execve(2) call will still fail.
<h3>RETURN VALUE
</h3> On success, zero is returned. On error, -1 is returned,
and errno is set appropriately.
<h3>ERRORS
</h3> EACCES The requested access would be denied, either to
the file itself or one of the directories in path-
name.
EFAULT pathname points outside your accessible address
space.
EINVAL mode was incorrectly specified.
ENAMETOOLONG
pathname is too long.
ENOENT A directory component in pathname would have been
<h3>Linux 1.1.46 21 August 1994 1
</h3>
<h3>ACCESS(2) Linux Programmer's Manual ACCESS(2)
</h3>
accessible but does not exist or was a dangling
symbolic link.
ENOTDIR A component used as a directory in pathname is
not, in fact, a directory.
ENOMEM Insufficient kernel memory was available.
ELOOP pathname contains a reference to a circular sym-
bolic link, i.e., a symbolic link containing a
reference to itself.
<h3>CONFORMING TO
</h3> SVID, AT&T, POSIX, X/OPEN, BSD 4.3
</pre>
<hr>
<h3>SEE ALSO
</h3><p>
<a href=stat.htm>stat</a>,
<a href=open.htm>open</a>,
<a href=chmod.htm>chmod</a>,
<a href=chown.htm>chown</a>,
<a href=setuid.htm>setuid</a>,
<pre>
<h3>Linux 1.1.46 21 August 1994 2
</h3>
</pre>
<P>
<hr>
<p>
<center>
<table border=2 width=80%>
<tr align=center>
<td width=25%>
<a href=../cref.html>Top</a>
</td><td width=25%>
<a href=../master_index.html>Master Index</a>
</td><td width=25%>
<a href=../SYNTAX/keywords.html>Keywords</a>
</td><td width=25%>
<a href=../FUNCTIONS/funcref.htm>Functions</a>
</td>
</tr>
</table>
</center>
<p>
<hr>
This manual page was brought to you by <i>mjl_man V-2.0</i>
|