1994-05-27 05:00:24 +00:00
|
|
|
.\" Copyright (c) 1980, 1991, 1993, 1994
|
|
|
|
.\" The Regents of the University of California. All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\" 3. All advertising materials mentioning features or use of this software
|
|
|
|
.\" must display the following acknowledgement:
|
|
|
|
.\" This product includes software developed by the University of
|
|
|
|
.\" California, Berkeley and its contributors.
|
|
|
|
.\" 4. Neither the name of the University nor the names of its contributors
|
|
|
|
.\" may be used to endorse or promote products derived from this software
|
|
|
|
.\" without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
1997-03-11 11:35:56 +00:00
|
|
|
.\" @(#)stat.2 8.4 (Berkeley) 5/1/95
|
|
|
|
.\" $Id: stat.2,v 1.11 1997/02/22 15:04:29 peter Exp $
|
1994-05-27 05:00:24 +00:00
|
|
|
.\"
|
1997-03-11 11:35:56 +00:00
|
|
|
.Dd May 1, 1995
|
1994-05-27 05:00:24 +00:00
|
|
|
.Dt STAT 2
|
|
|
|
.Os BSD 4
|
|
|
|
.Sh NAME
|
|
|
|
.Nm stat ,
|
|
|
|
.Nm lstat ,
|
|
|
|
.Nm fstat
|
|
|
|
.Nd get file status
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Fd #include <sys/types.h>
|
|
|
|
.Fd #include <sys/stat.h>
|
|
|
|
.Ft int
|
|
|
|
.Fn stat "const char *path" "struct stat *sb"
|
|
|
|
.Ft int
|
|
|
|
.Fn lstat "const char *path" "struct stat *sb"
|
|
|
|
.Ft int
|
|
|
|
.Fn fstat "int fd" "struct stat *sb"
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Fn stat
|
|
|
|
function obtains information about the file pointed to by
|
|
|
|
.Fa path .
|
|
|
|
Read, write or execute
|
|
|
|
permission of the named file is not required, but all directories
|
|
|
|
listed in the path name leading to the file must be searchable.
|
|
|
|
.Pp
|
|
|
|
.Fn Lstat
|
|
|
|
is like
|
|
|
|
.Fn stat
|
|
|
|
except in the case where the named file is a symbolic link,
|
|
|
|
in which case
|
|
|
|
.Fn lstat
|
|
|
|
returns information about the link,
|
|
|
|
while
|
|
|
|
.Fn stat
|
|
|
|
returns information about the file the link references.
|
|
|
|
Unlike other filesystem objects,
|
|
|
|
symbolic links do not have an owner, group, access mode, times, etc.
|
|
|
|
Instead, these attributes are taken from the directory that
|
|
|
|
contains the link.
|
|
|
|
The only attributes returned from an
|
|
|
|
.Fn lstat
|
|
|
|
that refer to the symbolic link itself are the file type (S_IFLNK),
|
|
|
|
size, blocks, and link count (always 1).
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fn fstat
|
|
|
|
obtains the same information about an open file
|
|
|
|
known by the file descriptor
|
|
|
|
.Fa fd .
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Fa sb
|
|
|
|
argument is a pointer to a
|
|
|
|
.Fn stat
|
|
|
|
structure
|
|
|
|
as defined by
|
|
|
|
.Aq Pa sys/stat.h
|
|
|
|
(shown below)
|
|
|
|
and into which information is placed concerning the file.
|
|
|
|
.Bd -literal
|
|
|
|
struct stat {
|
1997-01-11 21:45:57 +00:00
|
|
|
dev_t st_dev; /* inode's device */
|
|
|
|
ino_t st_ino; /* inode's number */
|
|
|
|
mode_t st_mode; /* inode protection mode */
|
|
|
|
nlink_t st_nlink; /* number of hard links */
|
|
|
|
uid_t st_uid; /* user ID of the file's owner */
|
|
|
|
gid_t st_gid; /* group ID of the file's group */
|
|
|
|
dev_t st_rdev; /* device type */
|
|
|
|
#ifndef _POSIX_SOURCE
|
1994-05-27 05:00:24 +00:00
|
|
|
struct timespec st_atimespec; /* time of last access */
|
|
|
|
struct timespec st_mtimespec; /* time of last data modification */
|
|
|
|
struct timespec st_ctimespec; /* time of last file status change */
|
1997-01-11 21:45:57 +00:00
|
|
|
#else
|
|
|
|
time_t st_atime; /* time of last access */
|
|
|
|
long st_atimensec; /* nsec of last access */
|
|
|
|
time_t st_mtime; /* time of last data modification */
|
|
|
|
long st_mtimensec; /* nsec of last data modification */
|
|
|
|
time_t st_ctime; /* time of last file status change */
|
|
|
|
long st_ctimensec; /* nsec of last file status change */
|
|
|
|
#endif
|
|
|
|
off_t st_size; /* file size, in bytes */
|
|
|
|
quad_t st_blocks; /* blocks allocated for file */
|
|
|
|
u_long st_blksize; /* optimal blocksize for I/O */
|
|
|
|
u_long st_flags; /* user defined flags for file */
|
|
|
|
u_long st_gen; /* file generation number */
|
1994-05-27 05:00:24 +00:00
|
|
|
};
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
The time-related fields of
|
|
|
|
.Fa struct stat
|
|
|
|
are as follows:
|
|
|
|
.Bl -tag -width XXXst_mtime
|
|
|
|
.It st_atime
|
|
|
|
Time when file data last accessed.
|
|
|
|
Changed by the
|
|
|
|
.Xr mknod 2 ,
|
|
|
|
.Xr utimes 2
|
|
|
|
and
|
|
|
|
.Xr read 2
|
|
|
|
system calls.
|
|
|
|
.It st_mtime
|
|
|
|
Time when file data last modified.
|
|
|
|
Changed by the
|
|
|
|
.Xr mknod 2 ,
|
|
|
|
.Xr utimes 2
|
|
|
|
and
|
|
|
|
.Xr write 2
|
|
|
|
system calls.
|
|
|
|
.It st_ctime
|
|
|
|
Time when file status was last changed (inode data modification).
|
|
|
|
Changed by the
|
|
|
|
.Xr chmod 2 ,
|
|
|
|
.Xr chown 2 ,
|
|
|
|
.Xr link 2 ,
|
|
|
|
.Xr mknod 2 ,
|
|
|
|
.Xr rename 2 ,
|
|
|
|
.Xr unlink 2 ,
|
|
|
|
.Xr utimes 2
|
|
|
|
and
|
|
|
|
.Xr write 2
|
|
|
|
system calls.
|
|
|
|
.El
|
|
|
|
.Pp
|
1997-01-11 21:45:57 +00:00
|
|
|
If
|
|
|
|
.Dv _POSIX_SOURCE
|
|
|
|
is not defined, the time-related fields are defined as:
|
|
|
|
.Bd -literal
|
|
|
|
#ifndef _POSIX_SOURCE
|
|
|
|
#define st_atime st_atimespec.tv_sec
|
|
|
|
#define st_mtime st_mtimespec.tv_sec
|
|
|
|
#define st_ctime st_ctimespec.tv_sec
|
|
|
|
#endif
|
|
|
|
.Ed
|
|
|
|
.Pp
|
1994-05-27 05:00:24 +00:00
|
|
|
The size-related fields of the
|
|
|
|
.Fa struct stat
|
|
|
|
are as follows:
|
|
|
|
.Bl -tag -width XXXst_blksize
|
|
|
|
.It st_blksize
|
|
|
|
The optimal I/O block size for the file.
|
|
|
|
.It st_blocks
|
|
|
|
The actual number of blocks allocated for the file in 512-byte units.
|
|
|
|
As short symbolic links are stored in the inode, this number may
|
|
|
|
be zero.
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
The status information word
|
|
|
|
.Fa st_mode
|
|
|
|
has the following bits:
|
|
|
|
.Bd -literal
|
|
|
|
#define S_IFMT 0170000 /* type of file */
|
|
|
|
#define S_IFIFO 0010000 /* named pipe (fifo) */
|
|
|
|
#define S_IFCHR 0020000 /* character special */
|
|
|
|
#define S_IFDIR 0040000 /* directory */
|
|
|
|
#define S_IFBLK 0060000 /* block special */
|
|
|
|
#define S_IFREG 0100000 /* regular */
|
|
|
|
#define S_IFLNK 0120000 /* symbolic link */
|
|
|
|
#define S_IFSOCK 0140000 /* socket */
|
1997-01-11 21:45:57 +00:00
|
|
|
#define S_IFWHT 0160000 /* whiteout */
|
1994-05-27 05:00:24 +00:00
|
|
|
#define S_ISUID 0004000 /* set user id on execution */
|
|
|
|
#define S_ISGID 0002000 /* set group id on execution */
|
|
|
|
#define S_ISVTX 0001000 /* save swapped text even after use */
|
|
|
|
#define S_IRUSR 0000400 /* read permission, owner */
|
|
|
|
#define S_IWUSR 0000200 /* write permission, owner */
|
|
|
|
#define S_IXUSR 0000100 /* execute/search permission, owner */
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
For a list of access modes, see
|
|
|
|
.Aq Pa sys/stat.h ,
|
|
|
|
.Xr access 2
|
|
|
|
and
|
|
|
|
.Xr chmod 2 .
|
|
|
|
.Sh RETURN VALUES
|
|
|
|
Upon successful completion a value of 0 is returned.
|
|
|
|
Otherwise, a value of -1 is returned and
|
|
|
|
.Va errno
|
|
|
|
is set to indicate the error.
|
|
|
|
.Sh COMPATIBILITY
|
|
|
|
Previous versions of the system used different types for the
|
|
|
|
.Li st_dev ,
|
|
|
|
.Li st_uid ,
|
|
|
|
.Li st_gid ,
|
|
|
|
.Li st_rdev ,
|
|
|
|
.Li st_size ,
|
|
|
|
.Li st_blksize
|
|
|
|
and
|
|
|
|
.Li st_blocks
|
|
|
|
fields.
|
|
|
|
.Sh ERRORS
|
|
|
|
.Fn Stat
|
|
|
|
and
|
|
|
|
.Fn lstat
|
|
|
|
will fail if:
|
|
|
|
.Bl -tag -width ENAMETOOLONGAA
|
|
|
|
.It Bq Er ENOTDIR
|
|
|
|
A component of the path prefix is not a directory.
|
|
|
|
.It Bq Er ENAMETOOLONG
|
|
|
|
A component of a pathname exceeded 255 characters,
|
|
|
|
or an entire path name exceeded 1023 characters.
|
|
|
|
.It Bq Er ENOENT
|
|
|
|
The named file does not exist.
|
|
|
|
.It Bq Er EACCES
|
|
|
|
Search permission is denied for a component of the path prefix.
|
|
|
|
.It Bq Er ELOOP
|
|
|
|
Too many symbolic links were encountered in translating the pathname.
|
|
|
|
.It Bq Er EFAULT
|
|
|
|
.Fa Sb
|
|
|
|
or
|
|
|
|
.Em name
|
|
|
|
points to an invalid address.
|
|
|
|
.It Bq Er EIO
|
|
|
|
An I/O error occurred while reading from or writing to the file system.
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
.Bl -tag -width [EFAULT]
|
|
|
|
.Fn Fstat
|
|
|
|
will fail if:
|
|
|
|
.It Bq Er EBADF
|
|
|
|
.Fa fd
|
|
|
|
is not a valid open file descriptor.
|
|
|
|
.It Bq Er EFAULT
|
|
|
|
.Fa Sb
|
|
|
|
points to an invalid address.
|
|
|
|
.It Bq Er EIO
|
|
|
|
An I/O error occurred while reading from or writing to the file system.
|
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr chmod 2 ,
|
|
|
|
.Xr chown 2 ,
|
1996-09-23 22:24:39 +00:00
|
|
|
.Xr utimes 2 ,
|
1994-05-27 05:00:24 +00:00
|
|
|
.Xr symlink 7
|
|
|
|
.Sh BUGS
|
|
|
|
Applying
|
1996-03-27 20:49:07 +00:00
|
|
|
.Fn fstat
|
1994-05-27 05:00:24 +00:00
|
|
|
to a socket (and thus to a pipe)
|
1996-01-30 16:34:52 +00:00
|
|
|
returns a zeroed buffer,
|
1994-05-27 05:00:24 +00:00
|
|
|
except for the blocksize field,
|
|
|
|
and a unique device and inode number.
|
|
|
|
.Sh STANDARDS
|
|
|
|
The
|
|
|
|
.Fn stat
|
|
|
|
and
|
|
|
|
.Fn fstat
|
1996-12-02 20:03:58 +00:00
|
|
|
function calls are expected to conform to
|
|
|
|
.St -p1003.1-90 .
|
1994-05-27 05:00:24 +00:00
|
|
|
.Sh HISTORY
|
|
|
|
A
|
1996-08-29 21:24:19 +00:00
|
|
|
.Fn stat
|
|
|
|
and a
|
|
|
|
.Fn fstat
|
|
|
|
function call appeared in
|
|
|
|
.At v7 .
|
|
|
|
A
|
1996-08-22 23:31:07 +00:00
|
|
|
.Fn lstat
|
1994-05-27 05:00:24 +00:00
|
|
|
function call appeared in
|
|
|
|
.Bx 4.2 .
|