Mercurial > emacs
changeset 93691:427c85059fb8
New file.
author | Eli Zaretskii <eliz@gnu.org> |
---|---|
date | Sat, 05 Apr 2008 14:33:28 +0000 |
parents | c9e7cd4c092d |
children | 1f00fd61c9e6 |
files | nt/inc/sys/stat.h |
diffstat | 1 files changed, 59 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/nt/inc/sys/stat.h Sat Apr 05 14:33:28 2008 +0000 @@ -0,0 +1,59 @@ +/* + * sys/stat.h supplied with MSVCRT uses too narrow data types for + * inode and user/group id, so we replace them with our own. + */ + +#ifndef INC_SYS_STAT_H_ +#define INC_SYS_STAT_H_ + +#ifdef __MINGW32__ +# include <_mingw.h> +#else +# define __MINGW_NOTHROW +#endif + +#include <sys/types.h> +#include <time.h> + +#define S_IFMT 0xF000 + +#define S_IFREG 0x8000 +#define S_IFDIR 0x4000 +#define S_IFBLK 0x3000 +#define S_IFCHR 0x2000 +#define S_IFIFO 0x1000 + +#define S_IREAD 0x0100 +#define S_IWRITE 0x0080 +#define S_IEXEC 0x0040 + +#define S_IRUSR S_IREAD +#define S_IWUSR S_IWRITE +#define S_IXUSR S_IEXEC +#define S_IRWXU (S_IREAD | S_IWRITE | S_IEXEC) + +#define S_ISREG(m) (((m) & S_IFMT) == S_IFREG) +#define S_ISDIR(m) (((m) & S_IFMT) == S_IFDIR) +#define S_ISBLK(m) (((m) & S_IFMT) == S_IFBLK) +#define S_ISCHR(m) (((m) & S_IFMT) == S_IFCHR) +#define S_ISFIFO(m) (((m) & S_IFMT) == S_IFIFO) + +struct stat { + dev_t st_dev; + unsigned __int64 st_ino; /* ino_t in sys/types.h is too narrow */ + unsigned short st_mode; + short st_nlink; + int st_uid; + int st_gid; + dev_t st_rdev; + off_t st_size; + time_t st_atime; + time_t st_mtime; + time_t st_ctime; +}; + +_CRTIMP int __cdecl __MINGW_NOTHROW fstat (int, struct stat*); +_CRTIMP int __cdecl __MINGW_NOTHROW chmod (const char*, int); +_CRTIMP int __cdecl __MINGW_NOTHROW stat (const char*, struct stat*); + +#endif /* INC_SYS_STAT_H_ */