| <html lang="en"> |
| <head> |
| <title>ACCESS - The GNU Fortran Compiler</title> |
| <meta http-equiv="Content-Type" content="text/html"> |
| <meta name="description" content="The GNU Fortran Compiler"> |
| <meta name="generator" content="makeinfo 4.13"> |
| <link title="Top" rel="start" href="index.html#Top"> |
| <link rel="up" href="Intrinsic-Procedures.html#Intrinsic-Procedures" title="Intrinsic Procedures"> |
| <link rel="prev" href="ABS.html#ABS" title="ABS"> |
| <link rel="next" href="ACHAR.html#ACHAR" title="ACHAR"> |
| <link href="http://www.gnu.org/software/texinfo/" rel="generator-home" title="Texinfo Homepage"> |
| <!-- |
| Copyright (C) 1999-2013 Free Software Foundation, Inc. |
| |
| Permission is granted to copy, distribute and/or modify this document |
| under the terms of the GNU Free Documentation License, Version 1.3 or |
| any later version published by the Free Software Foundation; with the |
| Invariant Sections being ``Funding Free Software'', the Front-Cover |
| Texts being (a) (see below), and with the Back-Cover Texts being (b) |
| (see below). A copy of the license is included in the section entitled |
| ``GNU Free Documentation License''. |
| |
| (a) The FSF's Front-Cover Text is: |
| |
| A GNU Manual |
| |
| (b) The FSF's Back-Cover Text is: |
| |
| You have freedom to copy and modify this GNU Manual, like GNU |
| software. Copies published by the Free Software Foundation raise |
| funds for GNU development.--> |
| <meta http-equiv="Content-Style-Type" content="text/css"> |
| <style type="text/css"><!-- |
| pre.display { font-family:inherit } |
| pre.format { font-family:inherit } |
| pre.smalldisplay { font-family:inherit; font-size:smaller } |
| pre.smallformat { font-family:inherit; font-size:smaller } |
| pre.smallexample { font-size:smaller } |
| pre.smalllisp { font-size:smaller } |
| span.sc { font-variant:small-caps } |
| span.roman { font-family:serif; font-weight:normal; } |
| span.sansserif { font-family:sans-serif; font-weight:normal; } |
| --></style> |
| </head> |
| <body> |
| <div class="node"> |
| <a name="ACCESS"></a> |
| <p> |
| Next: <a rel="next" accesskey="n" href="ACHAR.html#ACHAR">ACHAR</a>, |
| Previous: <a rel="previous" accesskey="p" href="ABS.html#ABS">ABS</a>, |
| Up: <a rel="up" accesskey="u" href="Intrinsic-Procedures.html#Intrinsic-Procedures">Intrinsic Procedures</a> |
| <hr> |
| </div> |
| |
| <h3 class="section">8.4 <code>ACCESS</code> — Checks file access modes</h3> |
| |
| <p><a name="index-ACCESS-381"></a><a name="index-file-system_002c-access-mode-382"></a> |
| <dl> |
| <dt><em>Description</em>:<dd><code>ACCESS(NAME, MODE)</code> checks whether the file <var>NAME</var> |
| exists, is readable, writable or executable. Except for the |
| executable check, <code>ACCESS</code> can be replaced by |
| Fortran 95's <code>INQUIRE</code>. |
| |
| <br><dt><em>Standard</em>:<dd>GNU extension |
| |
| <br><dt><em>Class</em>:<dd>Inquiry function |
| |
| <br><dt><em>Syntax</em>:<dd><code>RESULT = ACCESS(NAME, MODE)</code> |
| |
| <br><dt><em>Arguments</em>:<dd> |
| <p><table summary=""><tr align="left"><td valign="top" width="15%"><var>NAME</var> </td><td valign="top" width="70%">Scalar <code>CHARACTER</code> of default kind with the |
| file name. Tailing blank are ignored unless the character <code>achar(0)</code> |
| is present, then all characters up to and excluding <code>achar(0)</code> are |
| used as file name. |
| <br></td></tr><tr align="left"><td valign="top" width="15%"><var>MODE</var> </td><td valign="top" width="70%">Scalar <code>CHARACTER</code> of default kind with the |
| file access mode, may be any concatenation of <code>"r"</code> (readable), |
| <code>"w"</code> (writable) and <code>"x"</code> (executable), or <code>" "</code> to check |
| for existence. |
| <br></td></tr></table> |
| |
| <br><dt><em>Return value</em>:<dd>Returns a scalar <code>INTEGER</code>, which is <code>0</code> if the file is |
| accessible in the given mode; otherwise or if an invalid argument |
| has been given for <code>MODE</code> the value <code>1</code> is returned. |
| |
| <br><dt><em>Example</em>:<dd> |
| <pre class="smallexample"> program access_test |
| implicit none |
| character(len=*), parameter :: file = 'test.dat' |
| character(len=*), parameter :: file2 = 'test.dat '//achar(0) |
| if(access(file,' ') == 0) print *, trim(file),' is exists' |
| if(access(file,'r') == 0) print *, trim(file),' is readable' |
| if(access(file,'w') == 0) print *, trim(file),' is writable' |
| if(access(file,'x') == 0) print *, trim(file),' is executable' |
| if(access(file2,'rwx') == 0) & |
| print *, trim(file2),' is readable, writable and executable' |
| end program access_test |
| </pre> |
| <br><dt><em>Specific names</em>:<br><dt><em>See also</em>:<dd> |
| </dl> |
| |
| </body></html> |
| |