#include <sys/types.h>
|
#include <sys/stat.h>
|
#include <wchar.h>
|
int
wstat (const wchar_t *path, struct stat *sb); |
The sb argument is a pointer to a stat structure as defined by
#include <sys/stat.h> and into which information is placed concerning the file.
The fields of struct stat related to the file system are as follows:
The st_dev and st_ino fields together identify the file uniquely within the system. The time-related fields of struct stat are as follows:
If _POSIX_SOURCE is not defined, the time-related fields are defined as: #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 The size-related fields of the struct stat are as follows:
The access-related fields of struct stat are as follows:
The status information word st_mode has the following bits: #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 */ #define S_IFWHT 0160000 /* whiteout */ #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 */ For a list of access modes, see |
#include <sys/stat.h,> The following macros are available to test whether a
st_mode
value passed in the
m
argument corresponds to a file of the specified type:
The macros evaluate to a non-zero value if the test is true or to the value 0 if the test is false. |
/** * Detailed description: Sample usage of wstat system call * Preconditions: Example.txt file should be present in working directory **/ #include <fcntl.h> #include <unistd.h> #include <sys/types.h> #include <sys/stat.h> #include <wchar.h> int main() { struct stat buf; if(wstat(L"Example.txt" , &buf) < 0 ) { printf("Failed to wstat Example.txt \n"); return -1; } printf("wstat system call succeded \n"); return 0; }
Output
wstat system call succeded
[EACCES] | |
Search permission is denied for a component of the path prefix. | |
[EFAULT] | |
The sb or path argument points to an invalid address. | |
[EIO] |
An I/O error occurred while reading from or writing to the file system. |
[ENAMETOOLONG] | |
A component of a pathname exceeded 255 characters, or an entire path name exceeded 1023 characters. | |
[ENOENT] | |
The named file does not exist. | |
[ENOTDIR] | |
A component of the path prefix is not a directory. | |
© 2008 Nokia Corporation. All rights reserved. This documentation can be used in the connection with this Product to help and support the user. |