OSDN Git Service

Correct project name references in mingwrt source files.
[mingw/mingw-org-wsl.git] / mingwrt / include / sys / stat.h
1 /*
2  * stat.h
3  *
4  * Symbolic constants for opening and creating files, also stat, fstat and
5  * chmod functions.
6  *
7  * $Id$
8  *
9  * Written by Colin Peters <colin@bird.fu.is.saga-u.ac.jp>
10  * Copyright (C) 1997-2001, 2003-2005, 2007, 2016, 2022, MinGW.OSDN Project
11  *
12  *
13  * Permission is hereby granted, free of charge, to any person obtaining a
14  * copy of this software and associated documentation files (the "Software"),
15  * to deal in the Software without restriction, including without limitation
16  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
17  * and/or sell copies of the Software, and to permit persons to whom the
18  * Software is furnished to do so, subject to the following conditions:
19  *
20  * The above copyright notice, this permission notice, and the following
21  * disclaimer shall be included in all copies or substantial portions of
22  * the Software.
23  *
24  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
25  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
26  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
27  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
28  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
29  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OF OR OTHER
30  * DEALINGS IN THE SOFTWARE.
31  *
32  */
33 #ifndef _SYS_STAT_H
34 #pragma GCC system_header
35
36 /* To support selective (partial) inclusion by <wchar.h>...
37  */
38 #ifndef __WCHAR_H_SOURCED__
39 /* ...we defer the definition of the normal multiple inclusion guard macro,
40  * until we know that this is NOT the <wchar.h> selective inclusion case.
41  */
42 #define _SYS_STAT_H
43
44 /* All MinGW headers are required to include <_mingw.h>; however, Microsoft
45  * also stipulate that USERS MUST include <sys/types.h>, BEFORE they include
46  * <sys/stat.h>.  This is not only appallingly bad software engineering, on
47  * Microsoft's part, but it is a potential obstacle to portability of POSIX
48  * source code; (POSIX requires that <sys/stat.h> should be self-contained,
49  * with no requirement for any specific header inclusion order).  Although
50  * it is more inclusive that POSIX requires, we may mitigate the deficiency
51  * inherent in Microsoft's poor software engineering, by simply including
52  * <sys/types.h> here; in so doing, we may also delegate the inclusion of
53  * <_mingw.h>, and the definition of all data types required herein, to...
54  */
55 #include <sys/types.h>
56
57 /* Constants for the st_mode member of struct stat, and its Microsoft
58  * specific variants.
59  */
60 #define _S_IFIFO        0x1000  /* FIFO */
61 #define _S_IFCHR        0x2000  /* Character */
62 #define _S_IFDIR        0x4000  /* Directory */
63 #define _S_IFREG        0x8000  /* Regular */
64
65 #ifdef _MINGW_S_IFBLK_KLUDGE
66 /* For preference, this kludge should NOT be enabled; for rationale,
67  * see: https://sourceforge.net/p/mingw/bugs/1146
68  *
69  * MS-Windows doesn't support testing for block special devices via the
70  * st_mode flags; ideally, client code to be ported to Windows should not
71  * blindly assume that S_IFBLK (or _S_IFBLK) is defined, but should rather
72  * check for it, and compile dependent code conditionally.  Notwithstanding,
73  * this kludge allows the user to force a definition, which we arbitrarily
74  * choose to ensure that S_ISBLK (or _S_ISBLK) always returns FALSE, (i.e.
75  * choose a value such that _S_IFBLK & _S_IFMT can NEVER equal _S_IFBLK).
76  */
77 #define _S_IFBLK        0x3001  /* Block: unsupported on Win32 */
78 #endif
79
80 #define _S_IFMT         0xF000  /* File type mask */
81
82 #define _S_IEXEC        0x0040
83 #define _S_IWRITE       0x0080
84 #define _S_IREAD        0x0100
85
86 #define _S_IRWXU        (_S_IREAD | _S_IWRITE | _S_IEXEC)
87 #define _S_IXUSR        _S_IEXEC
88 #define _S_IWUSR        _S_IWRITE
89 #define _S_IRUSR        _S_IREAD
90
91 #define _S_ISDIR(m)     (((m) & _S_IFMT) == _S_IFDIR)
92 #define _S_ISFIFO(m)    (((m) & _S_IFMT) == _S_IFIFO)
93 #define _S_ISCHR(m)     (((m) & _S_IFMT) == _S_IFCHR)
94 #define _S_ISBLK(m)     (((m) & _S_IFMT) == _S_IFBLK)
95 #define _S_ISREG(m)     (((m) & _S_IFMT) == _S_IFREG)
96
97 #ifndef _NO_OLDNAMES
98
99 #define S_IFIFO         _S_IFIFO
100 #define S_IFCHR         _S_IFCHR
101 #ifdef _S_IFBLK
102 #define S_IFBLK         _S_IFBLK
103 #endif
104 #define S_IFDIR         _S_IFDIR
105 #define S_IFREG         _S_IFREG
106 #define S_IFMT          _S_IFMT
107 #define S_IEXEC         _S_IEXEC
108 #define S_IWRITE        _S_IWRITE
109 #define S_IREAD         _S_IREAD
110 #define S_IRWXU         _S_IRWXU
111 #define S_IXUSR         _S_IXUSR
112 #define S_IWUSR         _S_IWUSR
113 #define S_IRUSR         _S_IRUSR
114
115 #define S_ISDIR(m)      (((m) & S_IFMT) == S_IFDIR)
116 #define S_ISFIFO(m)     (((m) & S_IFMT) == S_IFIFO)
117 #define S_ISCHR(m)      (((m) & S_IFMT) == S_IFCHR)
118 #define S_ISBLK(m)      (((m) & S_IFMT) == S_IFBLK)
119 #define S_ISREG(m)      (((m) & S_IFMT) == S_IFREG)
120
121 #endif  /* !_NO_OLDNAMES */
122
123 #ifndef _S_IFBLK
124 /* When the _S_IFBLK kludge is NOT enabled, (as it ideally should not be),
125  * ensure that any attempt to use its dependent macros is denied...
126  */
127 # pragma GCC poison _S_ISBLK
128
129 # if defined _NO_UNSUPPORTED || defined _NO_OLDNAMES
130   /* ...including that for the standard POSIX macro, when unsupported
131    * features, or Microsoft's old names, are explicitly forbidden...
132    */
133 #  pragma GCC poison S_ISBLK
134
135 # else /* !(_NO_UNSUPPORTED || _NO_OLDNAMES) */
136   /* ...otherwise assume that the kludge is automatically enabled with
137    * respect to S_ISBLK, (because GCC gratuitously misuses it).
138    */
139 #  define S_IFBLK       0x3001  /* Block: unsupported on Win32 */
140
141 # endif /* !(_NO_UNSUPPORTED || _NO_OLDNAMES) */
142 #endif  /* !_S_IFBLK */
143 #endif  /* !__WCHAR_H_SOURCED__ */
144
145 #ifndef RC_INVOKED
146 #ifndef __struct_stat_defined
147 /* The structure manipulated and returned by stat() and fstat(); note that
148  * expansion of the macro provided below will yield variants of struct stat
149  * to conform with Microsoft's usage, (and POSIX usage up to and including
150  * POSIX.1-2001, but NOT the extended specification of POSIX.1-2008).
151  *
152  * NOTE: If called on a directory the values in the time fields are not only
153  * invalid, they will cause localtime et. al. to return NULL. And calling
154  * asctime with a NULL pointer causes an Invalid Page Fault. So watch it!
155  */
156 #define __struct_stat_defined(__st_off_t, __st_time_t)                       \
157 { _dev_t        st_dev;         /* Equivalent to drive number 0=A 1=B ... */ \
158   _ino_t        st_ino;         /* Always zero ? */                          \
159   _mode_t       st_mode;        /* See above constants */                    \
160    short        st_nlink;       /* Number of links. */                       \
161    short        st_uid;         /* User: Maybe significant on NT ? */        \
162    short        st_gid;         /* Group: Ditto */                           \
163   _dev_t        st_rdev;        /* Seems useless (not even filled in) */     \
164   __st_off_t    st_size;        /* File size in bytes */                     \
165   __st_time_t   st_atime;       /* Access time (always 00:00 on FAT) */      \
166   __st_time_t   st_mtime;       /* Modified time */                          \
167   __st_time_t   st_ctime;       /* Creation time */                          \
168 }
169
170 /* Here, we expand the preceding macro to yield the actual definition
171  * of struct stat, under its current Microsoft "uglified" name...
172  */
173 struct _stat __struct_stat_defined( _off_t, time_t );
174
175 #ifndef _NO_OLDNAMES
176 /* ...while this alternative expansion yields its standard POSIX name,
177  * (and its original Microsoft name); apart from its name, this must be
178  * defined identically to struct _stat above.
179  */
180 struct stat __struct_stat_defined( _off_t, time_t );
181 #endif  /* !_NO_OLDNAMES */
182
183 #if defined __MSVCRT__
184 /* This variant of struct stat is required to support the use of the
185  * _stati64() function, which is provided by MSVCRT.DLL, but was not
186  * present in CRTDLL.DLL...
187  */
188 struct _stati64 __struct_stat_defined( __off64_t, time_t );
189
190 #if __MSVCRT_VERSION__ >= __MSVCR61_DLL || _WIN32_WINNT >= _WIN32_WINNT_WIN2K
191 /* ...while this supports the use of the _stat64() function, introduced
192  * by MSVCR61.DLL, and subsequently added to MSVCRT.DLL for releases from
193  * Win2K onwards...
194  */
195 struct __stat64 __struct_stat_defined( __off64_t, __time64_t );
196
197 #if __MSVCRT_VERSION__ >= __MSVCR80_DLL
198 /* ...and these are specific to additional function variants, added to
199  * the non-free MSVCR80.DLL, and its later derivatives, but not present
200  * in MSVCRT.DLL (or CRTDLL.DLL).
201  */
202 struct __stat32 __struct_stat_defined( __off32_t, __time32_t );
203 struct _stat32i64 __struct_stat_defined( __off64_t, __time32_t );
204 struct _stat64i32 __struct_stat_defined( __off32_t, __time64_t );
205
206 #endif  /* __MSVCRT_VERSION__ >= __MSVCR80_DLL */
207 #endif  /* __MSVCRT_VERSION__ >= __MSVCR61_DLL */
208 #endif  /* __MSVCRT__ */
209
210 /* From here on, it is sufficient to leave __struct_stat_defined as
211  * a macro which expands to nothing.
212  */
213 #undef  __struct_stat_defined
214 #define __struct_stat_defined
215
216 #endif /* !__struct_stat_defined */
217
218 _BEGIN_C_DECLS
219
220 #ifdef _SYS_STAT_H
221 /* This set of function prototypes are to be declared only when
222  * <sys/stat.h> is included directly.
223  */
224 _CRTIMP __cdecl __MINGW_NOTHROW  int _umask (int);
225 _CRTIMP __cdecl __MINGW_NOTHROW  int _chmod (const char *, int);
226
227 #if __MSVCRT_VERSION__ < __MSVCR80_DLL
228 /* This pair of functions are present in all versions of MSVCRT.DLL, but
229  * they are NOT present in MSVCR80.DLL, nor in any of its later non-free
230  * variants, all of which rely on inline aliases (defined below).
231  */
232 _CRTIMP __cdecl __MINGW_NOTHROW  int _fstat (int, struct _stat *);
233 _CRTIMP __cdecl __MINGW_NOTHROW  int _stat (const char *, struct _stat *);
234 #endif  /* __MSVCRT_VERSION__ < __MSVCR80_DLL */
235
236 #ifndef _NO_OLDNAMES
237 /* These are the standard POSIX names, (and the original Microsoft names),
238  * for the preceding four functions.
239  */
240 _CRTIMP __cdecl __MINGW_NOTHROW  int umask (int);
241 _CRTIMP __cdecl __MINGW_NOTHROW  int chmod (const char *, int);
242
243 #if __MSVCRT_VERSION__ < __MSVCR80_DLL
244 /* Since the underlying functions, with "uglified" names, are not supported
245  * by MSVCR80.DLL and its later derivitaves, there is also nothing to which
246  * to map these originally named alternatives; declare prototypes only when
247  * using DLL versions which can support them, while falling back to the use
248  * of inline replacements (defined below) in the unsupported cases.
249  */
250 _CRTIMP __cdecl __MINGW_NOTHROW  int fstat (int, struct stat *);
251 _CRTIMP __cdecl __MINGW_NOTHROW  int stat (const char *, struct stat *);
252 #endif  /* __MSVCRT_VERSION__ < __MSVCR80_DLL */
253 #endif  /* !_NO_OLDNAMES */
254
255 #if defined __MSVCRT__
256 #if __MSVCRT_VERSION__ < __MSVCR80_DLL
257 /* This pair of functions were withdrawn from MSVCR80.DLL, and its later
258  * derivatives, but remain in all versions of MSVCRT.DLL
259  */
260 _CRTIMP __cdecl __MINGW_NOTHROW  int _fstati64 (int, struct _stati64 *);
261 _CRTIMP __cdecl __MINGW_NOTHROW  int _stati64 (const char *, struct _stati64 *);
262 #endif  /* __MSVCRT_VERSION__ < __MSVCR80_DLL */
263
264 #if __MSVCRT_VERSION__ >= __MSVCR61_DLL || _WIN32_WINNT >= _WIN32_WINNT_WIN2K
265 /* This pair of functions were introduced in MSVCR61.DLL, and were subsequently
266  * added to MSVCRT.DLL from the release accompanying Win2K onwards...
267  */
268 _CRTIMP __cdecl __MINGW_NOTHROW  int _fstat64 (int, struct __stat64 *);
269 _CRTIMP __cdecl __MINGW_NOTHROW  int _stat64 (const char *, struct __stat64 *);
270
271 #if __MSVCRT_VERSION__ >= __MSVCR80_DLL
272 /* ...whereas this group were introduced in MSVCR80.DLL, and its later
273  * derivatives, but are not present in MSVCRT.DLL
274  */
275 _CRTIMP __cdecl __MINGW_NOTHROW  int _fstat32 (int, struct __stat32 *);
276 _CRTIMP __cdecl __MINGW_NOTHROW  int _stat32 (const char *, struct __stat32 *);
277 _CRTIMP __cdecl __MINGW_NOTHROW  int _fstat32i64 (int, struct _stat32i64 *);
278 _CRTIMP __cdecl __MINGW_NOTHROW  int _fstat64i32 (int, struct _stat64i32 *);
279 _CRTIMP __cdecl __MINGW_NOTHROW  int _stat32i64 (const char *, struct _stat32i64 *);
280 _CRTIMP __cdecl __MINGW_NOTHROW  int _stat64i32 (const char *, struct _stat64i32 *);
281
282 #ifdef _USE_32BIT_TIME_T
283 /* We must provide inline replacements for the four MSVCRT.DLL functions
284  * which have been withdrawn from MSVCR80.DLL, and its later derivatives;
285  * this first set of replacements are compatible with their MSVCRT.DLL
286  * equivalents, but require the user to define _USE_32BIT_TIME_T...
287  */
288 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _fstat (int __v1, struct _stat *__v2)
289   { return _fstat32 (__v1, (struct __stat32 *)(__v2)); }
290
291 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _stat (const char *__v1, struct _stat *__v2)
292   { return _stat32  (__v1, (struct __stat32 *)(__v2)); }
293
294 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _fstati64 (int __v1, struct _stati64 *__v2)
295   { return _fstat32i64 (__v1, (struct _stat32i64 *)(__v2)); }
296
297 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _stati64 (const char *__v1, struct _stati64 *__v2)
298   { return _stat32i64  (__v1, (struct _stat32i64 *)(__v2)); }
299
300 #else   /* !_USE_32BIT_TIME_T */
301 /* ...whereas, the following alternatives emulate the brain-damaged
302  * behaviour of Microsoft's own implementations, which take effect when
303  * the user does not define _USE_32BIT_TIME_T; they break compatibility
304  * with MSVCRT.DLL
305  */
306 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _fstat (int __v1, struct _stat *__v2)
307   { return _fstat64i32 (__v1, (struct _stat64i32 *)(__v2)); }
308
309 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _stat (const char *__v1, struct _stat *__v2)
310   { return _stat64i32  (__v1, (struct _stat64i32 *)(__v2)); }
311
312 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _fstati64 (int __v1, struct _stati64 *__v2)
313   { return _fstat64 (__v1, (struct __stat64 *)(__v2)); }
314
315 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _stati64 (const char *__v1, struct _stati64 *__v2)
316   { return _stat64  (__v1,(struct __stat64*)(__v2)); }
317 #endif  /* !_USE_32BIT_TIME_T */
318
319 #ifndef _NO_OLDNAMES
320 /* Irrespective of the state of _USE_32BIT_TIME_T, we may provide inline
321  * replacements for the stat() and fstat() functions, (which are missing
322  * from MSVCR80.DLL and its later derivatives), simply by aliasing them
323  * to their corresponding replacements with "uglified" names.
324  */
325 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int fstat (int __v1, struct _stat *__v2)
326   { return _fstat (__v1, __v2); }
327
328 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int stat (const char *__v1, struct _stat *__v2)
329   { return _stat (__v1, __v2); }
330
331 #endif  /* !_NO_OLDNAMES */
332 #endif  /* __MSVCRT_VERSION__ >= __MSVCR80_DLL */
333 #endif  /* __MSVCRT_VERSION__ >= __MSVCR61_DLL */
334 #endif  /* __MSVCRT__ */
335 #endif  /* _SYS_STAT_H */
336
337 #if defined __MSVCRT__ && !(defined _SYS_STAT_H && defined _WCHAR_H)
338 /* This final group of function prototypes, specific to MSVCRT.DLL and its
339  * non-free derivatives, are to be declared both when <sys/stat.h> is included
340  * directly, and when it is selectively included by <wchar.h>; however, if both
341  * _SYS_STAT_H and _WCHAR_H are defined, by the time we get to here, then this
342  * must be the direct inclusion case, after having already declared these via
343  * selective inclusion by <wchar.h>, and we should not declare these again;
344  * (in particular, we should not repeat inline function implementations).
345  */
346 #if __MSVCRT_VERSION__ < __MSVCR80_DLL
347 /* As is the case for their regular counterparts, this pair of functions
348  * remain available in MSVCRT.DLL itself, but they are not exported from its
349  * non-free derivatives from MSVCR80.DLL onwards, whence it is expected that
350  * they will be replaced by inline implementations.
351  */
352 _CRTIMP __cdecl __MINGW_NOTHROW  int _wstat(const wchar_t *, struct _stat *);
353 _CRTIMP __cdecl __MINGW_NOTHROW  int _wstati64 (const wchar_t *, struct _stati64 *);
354 #endif  /* __MSVCRT_VERSION__ < __MSVCR80_DLL */
355
356 #if __MSVCRT_VERSION__ >= __MSVCR61_DLL || _WIN32_WINNT >= _WIN32_WINNT_WIN2K
357 /* Similarly, this variant was introduced in MSVCR80.DLL, and was subsequently
358  * added to MSVCRT.DLL with the release of Win2K...
359  */
360 _CRTIMP __cdecl __MINGW_NOTHROW  int _wstat64 (const wchar_t *, struct __stat64 *);
361
362 #if __MSVCRT_VERSION__ >= __MSVCR80_DLL
363 /* ...whereas these variants are exclusive to the non-free MSVCR80.DLL, and
364  * its later derivatives; they are not available in MSVCRT.DLL.
365  */
366 _CRTIMP __cdecl __MINGW_NOTHROW  int _wstat32 (const wchar_t *, struct __stat32 *);
367 _CRTIMP __cdecl __MINGW_NOTHROW  int _wstat32i64 (const wchar_t *, struct _stat32i64 *);
368 _CRTIMP __cdecl __MINGW_NOTHROW  int _wstat64i32 (const wchar_t *, struct _stat64i32 *);
369
370 #ifdef _USE_32BIT_TIME_T
371 /* Once again, we must furnish inline replacements for the functions which
372  * were withdrawn from MSVCR80.DLL and its later derivatives; these are the
373  * implementations which remain compatible with MSVCRT.DLL, but require the
374  * user to define _USE_32BIT_TIME_T...
375  */
376 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _wstat (const wchar_t *__v1, struct _stat *__v2)
377   { return _wstat32 (__v1, (struct __stat32 *)(__v2)); }
378
379 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _wstati64 (const wchar_t *__v1, struct _stati64 *__v2)
380   { return _wstat32i64 (__v1, (struct _stat32i64 *)(__v2)); }
381
382 #else   /* !_USE_32BIT_TIME_T */
383 /* ...whereas these emulate the brain-damaged Microsoft behaviour, for the
384  * case when the user does not define _USE_32BIT_TIME_T, breaking MSVCRT.DLL
385  * compatibility.
386  */
387 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _wstat (const wchar_t *__v1, struct _stat *__v2)
388   { return _wstat64i32 (__v1, (struct _stat64i32 *)(__v2)); }
389
390 __CRT_ALIAS __cdecl __MINGW_NOTHROW  int _wstati64 (const wchar_t *__v1, struct _stati64 *__v2)
391   { return _wstat64 (__v1, (struct __stat64 *)(__v2)); }
392
393 #endif  /* !_USE_32BIT_TIME_T */
394 #endif  /* __MSVCRT_VERSION__ >= 0x0800 */
395 #endif  /* __MSVCRT_VERSION__ >= 0x0601 */
396 #endif  /* __MSVCRT__ && !(_SYS_STAT_H && _WCHAR_H) */
397
398 _END_C_DECLS
399
400 #endif  /* ! RC_INVOKED */
401 #endif  /* !_SYS_STAT__H: $RCSfile$: end of file */