To examine the attributes of files, use the functions stat , fstat and lstat . They return the attribute information in a struct stat object. All three functions are declared in the header file `sys/stat.h'.
stat function returns information about the attributes of the file named by filename in the structure pointed at by buf.
If filename is the name of a symbolic link, the attributes you get describe the file that the link points to. If the link points to a nonexistent file name, then stat fails, reporting a nonexistent file.
The return value is 0 if the operation is successful, and -1 on failure. In addition to the usual file name syntax errors (see File Name Errors, the following errno error conditions are defined for this function:
ENOENT
fstat function is like stat , except that it takes an open file descriptor as an argument instead of a file name. See Low-Level I/O.
Like stat , fstat returns 0 on success and -1 on failure. The following errno error conditions are defined for fstat :
EBADF
lstat function is like stat , except that it does not follow symbolic links. If filename is the name of a symbolic link, lstat returns information about the link itself; otherwise, lstat works like stat . See Symbolic Links.