428
|
1 /*
|
|
2 Copyright (C) 1995 Free Software Foundation, Inc.
|
777
|
3 Copyright (C) 2000, 2001, 2002 Ben Wing.
|
428
|
4
|
|
5 This file is part of XEmacs.
|
|
6
|
|
7 XEmacs is free software; you can redistribute it and/or modify it
|
|
8 under the terms of the GNU General Public License as published by the
|
|
9 Free Software Foundation; either version 2, or (at your option) any
|
|
10 later version.
|
|
11
|
|
12 XEmacs is distributed in the hope that it will be useful, but WITHOUT
|
|
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
15 for more details.
|
|
16
|
|
17 You should have received a copy of the GNU General Public License
|
|
18 along with XEmacs; see the file COPYING. If not, write to
|
|
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
20 Boston, MA 02111-1307, USA. */
|
|
21
|
|
22 /* Synched up with: Not really in FSF. */
|
|
23
|
440
|
24 #ifndef INCLUDED_sysfile_h_
|
|
25 #define INCLUDED_sysfile_h_
|
|
26
|
771
|
27 /* The anonymous voice of the past says:
|
|
28 Must come before sysfile.h
|
|
29
|
|
30 So instead we just put it here. --ben */
|
|
31 #ifdef HAVE_LIBGEN_H
|
|
32 #include <libgen.h>
|
|
33 #endif
|
|
34
|
428
|
35 #include <errno.h>
|
|
36
|
442
|
37 #ifndef WIN32_NATIVE
|
573
|
38 # include <sys/errno.h> /* <errno.h> does not always imply this */
|
428
|
39 #endif
|
|
40
|
|
41 #ifdef HAVE_UNISTD_H
|
558
|
42 # include <unistd.h>
|
428
|
43 #endif
|
|
44
|
|
45 #ifndef INCLUDED_FCNTL
|
|
46 # define INCLUDED_FCNTL
|
|
47 # include <fcntl.h>
|
|
48 #endif /* INCLUDED_FCNTL */
|
|
49
|
558
|
50 /* The anonymous voice of the past says:
|
428
|
51 In some systems loading it twice is suicidal. */
|
558
|
52 #ifndef INCLUDED_SYS_TYPES
|
|
53 # define INCLUDED_SYS_TYPES
|
|
54 # include <sys/types.h> /* some typedefs are used in sys/file.h */
|
|
55 #endif /* INCLUDED_SYS_TYPES */
|
442
|
56
|
|
57 #ifndef WIN32_NATIVE
|
558
|
58 # include <sys/file.h>
|
442
|
59 #endif
|
|
60
|
1467
|
61 /* Some systems (SCO 3.2v5) do #define stat ... in this header. So it
|
|
62 _must_ be included before any use of struct stat. Most emacs files
|
|
63 should include sysfile.h. The unex*.c include <sys/stat.h> directly. */
|
428
|
64 #include <sys/stat.h>
|
442
|
65
|
1315
|
66 #ifdef WIN32_ANY
|
558
|
67 # include <io.h>
|
|
68 #endif
|
|
69
|
|
70 #ifdef WIN32_NATIVE
|
|
71 # include <direct.h>
|
|
72 #else
|
442
|
73 /* Some configuration files' definitions for the LOAD_AVE_CVT macro
|
|
74 (like sparc.h's) use macros like FSCALE, defined here. */
|
558
|
75 # ifdef HAVE_GTK
|
462
|
76 /* I hate GTK */
|
558
|
77 # undef MIN
|
|
78 # undef MAX
|
|
79 # endif /* HAVE_GTK */
|
|
80 # include <sys/param.h>
|
609
|
81 /* As per Martin's recommendation, we do not include this. There was
|
|
82 a comment stating that stuff from here was needed on NeXT, Cygwin,
|
|
83 and sunplay.c. However, Cygwin includes this automatically from
|
|
84 fcntl.h, and Martin says that a "conforming" system should never
|
|
85 need this. We will put it back if necessary on systems requiring it. */
|
|
86 /* # include <sys/fcntl.h> */
|
777
|
87 #endif /* WIN32_NATIVE */
|
428
|
88
|
|
89 #ifndef STDERR_FILENO
|
|
90 #define STDIN_FILENO 0
|
|
91 #define STDOUT_FILENO 1
|
|
92 #define STDERR_FILENO 2
|
|
93 #endif
|
|
94
|
|
95 #ifndef O_RDONLY
|
|
96 #define O_RDONLY 0
|
|
97 #endif
|
|
98
|
|
99 #ifndef O_WRONLY
|
|
100 #define O_WRONLY 1
|
|
101 #endif
|
|
102
|
|
103 #ifndef O_RDWR
|
|
104 #define O_RDWR 2
|
|
105 #endif
|
|
106
|
|
107 /* file opening defaults */
|
|
108 #ifndef OPEN_BINARY
|
|
109 #ifdef O_BINARY
|
|
110 #define OPEN_BINARY O_BINARY
|
|
111 #else
|
|
112 #define OPEN_BINARY (0)
|
|
113 #endif
|
|
114 #endif
|
|
115
|
|
116 #ifndef OPEN_TEXT
|
|
117 #ifdef O_TEXT
|
|
118 #define OPEN_TEXT O_TEXT
|
|
119 #else
|
|
120 #define OPEN_TEXT (0)
|
|
121 #endif
|
|
122 #endif
|
|
123
|
|
124 #ifndef CREAT_MODE
|
442
|
125 #ifdef WIN32_NATIVE
|
428
|
126 #define CREAT_MODE (S_IREAD | S_IWRITE)
|
|
127 #else
|
|
128 #define CREAT_MODE (0666)
|
|
129 #endif
|
|
130 #endif
|
|
131
|
|
132 #ifndef READ_TEXT
|
|
133 #ifdef O_TEXT
|
|
134 #define READ_TEXT "rt"
|
|
135 #else
|
|
136 #define READ_TEXT "r"
|
|
137 #endif
|
|
138 #endif
|
|
139
|
|
140 #ifndef READ_BINARY
|
|
141 #ifdef O_BINARY
|
|
142 #define READ_BINARY "rb"
|
|
143 #else
|
|
144 #define READ_BINARY "r"
|
|
145 #endif
|
|
146 #endif
|
|
147
|
442
|
148 #ifndef READ_PLUS_TEXT
|
|
149 #ifdef O_TEXT
|
|
150 #define READ_PLUS_TEXT "r+t"
|
|
151 #else
|
|
152 #define READ_PLUS_TEXT "r+"
|
|
153 #endif
|
|
154 #endif
|
|
155
|
|
156 #ifndef READ_PLUS_BINARY
|
|
157 #ifdef O_BINARY
|
|
158 #define READ_PLUS_BINARY "r+b"
|
|
159 #else
|
|
160 #define READ_PLUS_BINARY "r+"
|
|
161 #endif
|
|
162 #endif
|
|
163
|
|
164 #ifndef WRITE_TEXT
|
|
165 #ifdef O_TEXT
|
|
166 #define WRITE_TEXT "wt"
|
|
167 #else
|
|
168 #define WRITE_TEXT "w"
|
|
169 #endif
|
|
170 #endif
|
|
171
|
428
|
172 #ifndef WRITE_BINARY
|
|
173 #ifdef O_BINARY
|
|
174 #define WRITE_BINARY "wb"
|
|
175 #else
|
|
176 #define WRITE_BINARY "w"
|
|
177 #endif
|
|
178 #endif
|
|
179
|
771
|
180 #ifndef APPEND_TEXT
|
|
181 #ifdef O_TEXT
|
|
182 #define APPEND_TEXT "at"
|
|
183 #else
|
|
184 #define APPEND_TEXT "a"
|
|
185 #endif
|
|
186 #endif
|
|
187
|
|
188 #ifndef APPEND_BINARY
|
|
189 #ifdef O_BINARY
|
|
190 #define APPEND_BINARY "ab"
|
|
191 #else
|
|
192 #define APPEND_BINARY "a"
|
|
193 #endif
|
|
194 #endif
|
|
195
|
428
|
196 #ifndef O_NONBLOCK
|
|
197 #ifdef O_NDELAY
|
|
198 #define O_NONBLOCK O_NDELAY
|
|
199 #else
|
|
200 #define O_NONBLOCK 04000
|
|
201 #endif
|
|
202 #endif
|
|
203
|
|
204 #if !S_IRUSR
|
|
205 # if S_IREAD
|
|
206 # define S_IRUSR S_IREAD
|
|
207 # else
|
|
208 # define S_IRUSR 00400
|
|
209 # endif
|
|
210 #endif
|
|
211
|
|
212 #if !S_IWUSR
|
|
213 # if S_IWRITE
|
|
214 # define S_IWUSR S_IWRITE
|
|
215 # else
|
|
216 # define S_IWUSR 00200
|
|
217 # endif
|
|
218 #endif
|
|
219
|
|
220 #if !S_IXUSR
|
|
221 # if S_IEXEC
|
|
222 # define S_IXUSR S_IEXEC
|
|
223 # else
|
|
224 # define S_IXUSR 00100
|
|
225 # endif
|
|
226 #endif
|
|
227
|
|
228 #ifdef STAT_MACROS_BROKEN
|
|
229 #undef S_ISBLK
|
|
230 #undef S_ISCHR
|
|
231 #undef S_ISDIR
|
|
232 #undef S_ISFIFO
|
|
233 #undef S_ISLNK
|
|
234 #undef S_ISMPB
|
|
235 #undef S_ISMPC
|
|
236 #undef S_ISNWK
|
|
237 #undef S_ISREG
|
|
238 #undef S_ISSOCK
|
|
239 #endif /* STAT_MACROS_BROKEN. */
|
|
240
|
|
241 #if !defined(S_ISBLK) && defined(S_IFBLK)
|
|
242 #define S_ISBLK(m) (((m) & S_IFMT) == S_IFBLK)
|
|
243 #endif
|
|
244 #if !defined(S_ISCHR) && defined(S_IFCHR)
|
|
245 #define S_ISCHR(m) (((m) & S_IFMT) == S_IFCHR)
|
|
246 #endif
|
|
247 #if !defined(S_ISDIR) && defined(S_IFDIR)
|
|
248 #define S_ISDIR(m) (((m) & S_IFMT) == S_IFDIR)
|
|
249 #endif
|
|
250 #if !defined(S_ISREG) && defined(S_IFREG)
|
|
251 #define S_ISREG(m) (((m) & S_IFMT) == S_IFREG)
|
|
252 #endif
|
|
253 #if !defined(S_ISFIFO) && defined(S_IFIFO)
|
|
254 #define S_ISFIFO(m) (((m) & S_IFMT) == S_IFIFO)
|
|
255 #endif
|
|
256 #if !defined(S_ISLNK) && defined(S_IFLNK)
|
|
257 #define S_ISLNK(m) (((m) & S_IFMT) == S_IFLNK)
|
|
258 #endif
|
|
259 #if !defined(S_ISSOCK) && defined(S_IFSOCK)
|
|
260 #define S_ISSOCK(m) (((m) & S_IFMT) == S_IFSOCK)
|
|
261 #endif
|
|
262 #if !defined(S_ISMPB) && defined(S_IFMPB) /* V7 */
|
|
263 #define S_ISMPB(m) (((m) & S_IFMT) == S_IFMPB)
|
|
264 #define S_ISMPC(m) (((m) & S_IFMT) == S_IFMPC)
|
|
265 #endif
|
|
266 #if !defined(S_ISNWK) && defined(S_IFNWK) /* HP/UX */
|
|
267 #define S_ISNWK(m) (((m) & S_IFMT) == S_IFNWK)
|
|
268 #endif
|
|
269
|
442
|
270 /* Client .c files should simply use `PATH_MAX'. */
|
|
271 #ifndef PATH_MAX
|
558
|
272 # if defined (_MAX_PATH)
|
|
273 /* MS Win -- and preferable to _POSIX_PATH_MAX, which is also defined */
|
|
274 # define PATH_MAX _MAX_PATH
|
|
275 # elif defined (_POSIX_PATH_MAX)
|
442
|
276 # define PATH_MAX _POSIX_PATH_MAX
|
|
277 # elif defined (MAXPATHLEN)
|
|
278 # define PATH_MAX MAXPATHLEN
|
|
279 # else
|
|
280 # define PATH_MAX 1024
|
|
281 # endif
|
|
282 #endif
|
|
283
|
|
284 /* The following definitions are needed under Windows, at least */
|
|
285 #ifndef X_OK
|
|
286 # define X_OK 1
|
|
287 #endif
|
428
|
288
|
442
|
289 #ifndef R_OK
|
|
290 # define R_OK 4
|
|
291 #endif
|
|
292
|
771
|
293 #ifndef D_OK
|
|
294 # define D_OK 8
|
|
295 #endif
|
|
296
|
442
|
297 #ifndef W_OK
|
|
298 # define W_OK 2
|
|
299 #endif
|
|
300
|
|
301 #ifndef F_OK
|
|
302 # define F_OK 0
|
428
|
303 #endif
|
|
304
|
|
305 #ifndef FD_CLOEXEC
|
|
306 # define FD_CLOEXEC 1
|
|
307 #endif
|
|
308
|
771
|
309 #ifdef emacs
|
|
310
|
428
|
311 /* Emacs needs to use its own definitions of certain system calls on
|
|
312 some systems (like SunOS 4.1 and USG systems, where the read system
|
|
313 call is interruptible but Emacs expects it not to be; and under
|
|
314 MULE, where all filenames need to be converted to external format).
|
|
315
|
771
|
316 We used to play preprocessor games, but in the long run that just leads
|
|
317 you to ruin. So we explicitly put in the new calls, even if the source
|
|
318 gets marginally less pretty.
|
428
|
319
|
771
|
320 Current files where we don't use retry_ or qxe_ versions:
|
428
|
321
|
771
|
322 -- all sound files except ntplay.c (includes esd.c libsst.[ch] libst.h
|
|
323 linuxplay.c sgiplay.c sunplay.c
|
|
324 hpplay.c nas.c)
|
|
325 -- all unex* files
|
|
326 -- hftctl.c
|
|
327 -- lib-src files
|
|
328 */
|
428
|
329
|
771
|
330 ssize_t retry_read (int, void *, size_t);
|
|
331 ssize_t retry_write (int, const void *, size_t);
|
|
332 int retry_open (const Extbyte *path, int oflag, ...);
|
867
|
333 int qxe_open (const Ibyte *path, int oflag, ...);
|
|
334 int qxe_interruptible_open (const Ibyte *path, int oflag, int mode);
|
771
|
335 int retry_close (int);
|
|
336 Bytecount read_allowing_quit (int fildes, void *buf, Bytecount size);
|
|
337 Bytecount write_allowing_quit (int fildes, const void *buf,
|
|
338 Bytecount size);
|
428
|
339
|
|
340 /* Now the stdio versions ... */
|
|
341
|
771
|
342 size_t retry_fread (void *, size_t, size_t, FILE *);
|
|
343 size_t retry_fwrite (const void *, size_t, size_t, FILE *);
|
|
344 FILE *retry_fopen (const Extbyte *path, const Char_ASCII *mode);
|
867
|
345 FILE *qxe_fopen (const Ibyte *path, const Char_ASCII *mode);
|
771
|
346 int retry_fclose (FILE *);
|
428
|
347
|
|
348 /* encapsulations: file-information calls */
|
|
349
|
867
|
350 int qxe_access (const Ibyte *path, int mode);
|
|
351 int qxe_eaccess (const Ibyte *path, int mode);
|
|
352 int qxe_lstat (const Ibyte *path, struct stat *buf);
|
|
353 int qxe_readlink (const Ibyte *path, Ibyte *buf, size_t bufsiz);
|
771
|
354 int qxe_fstat (int fd, struct stat *buf);
|
867
|
355 int qxe_stat (const Ibyte *path, struct stat *buf);
|
|
356 Ibyte *qxe_realpath (const Ibyte *path, Ibyte resolved_path []);
|
428
|
357
|
|
358 /* encapsulations: file-manipulation calls */
|
|
359
|
867
|
360 int qxe_chmod (const Ibyte *path, mode_t mode);
|
771
|
361
|
|
362 #if defined (HAVE_LINK)
|
867
|
363 int qxe_link (const Ibyte *existing, const Ibyte *new);
|
771
|
364 #endif /* defined (HAVE_LINK) */
|
|
365
|
867
|
366 int qxe_rename (const Ibyte *old, const Ibyte *new);
|
771
|
367
|
|
368 #if defined (HAVE_SYMLINK)
|
867
|
369 int qxe_symlink (const Ibyte *name1, const Ibyte *name2);
|
771
|
370 #endif /* defined (HAVE_SYMLINK) */
|
|
371
|
867
|
372 int qxe_unlink (const Ibyte *path);
|
771
|
373
|
1467
|
374 /* definition in filemode.c
|
|
375 must be declared here to ensure that struct stat is properly formed
|
|
376 on systems like SCO 3.2v5 */
|
|
377 void filemodestring (struct stat *, char *);
|
|
378
|
771
|
379 #endif /* emacs */
|
|
380
|
|
381
|
|
382 #ifndef HAVE_H_ERRNO
|
|
383 extern int h_errno;
|
428
|
384 #endif
|
|
385
|
771
|
386 #ifndef HAVE_DUP2
|
|
387 int dup2 (int oldd, int newd);
|
428
|
388 #endif
|
|
389
|
771
|
390 #ifndef HAVE_STRERROR
|
|
391 /* X11R6 defines strerror as a macro */
|
|
392 # ifdef strerror
|
|
393 # undef strerror
|
|
394 # endif
|
|
395 const char *strerror (int);
|
428
|
396 #endif
|
|
397
|
771
|
398
|
|
399
|
|
400 /*
|
|
401 DEFAULT_DIRECTORY_SEP is the default value of Vdirectory_sep_char.
|
|
402 DIRECTORY_SEP is the currently preferred separator between elements
|
|
403 of a path, when paths are canonicalized.
|
|
404 DEVICE_SEP is the separator between devices and paths (might not
|
|
405 be defined).
|
|
406 SEPCHAR is the separator between paths in a path search string
|
|
407 (e.g. the PATH environment variable).
|
|
408 IS_DIRECTORY_SEP() returns true if the character is any directory
|
|
409 separator (there might be more than one allowed on a system.).
|
|
410 IS_DEVICE_SEP() returns true if the character is a device separator.
|
|
411 IS_ANY_SEP() returns true if the character is a directory or device
|
|
412 separator.
|
|
413 */
|
|
414
|
|
415 #ifdef emacs
|
428
|
416
|
771
|
417 /* We used to put some of this stuff in the s+m files for the various
|
|
418 types of MS Windows, but that's disingenuous. The various definitions
|
|
419 above were specifically created for MS Windows, and the "if not, then
|
|
420 let's define the defaults" stuff (formerly in lisp.h) specifically knows
|
|
421 about what is going to get redefined and how, and code all over the
|
|
422 place that works with filenames has to conditionalize on WIN32_NATIVE
|
|
423 anyway. It's much clearer if we put all related definitions in one
|
|
424 place. (In fact, I discovered a number of bugs in the process.)
|
|
425
|
|
426 S+M files should be used for simple on-off or multiple-choice settings,
|
|
427 or possibly string settings. Anything that gets to the level of
|
|
428 programming should be elsewhere, and anything that ends up having
|
|
429 lots of complicated interactions scattered around in many files should
|
|
430 be consolidated. */
|
|
431
|
|
432 #ifdef WIN32_NATIVE
|
|
433
|
|
434 #define SEPCHAR ';'
|
|
435 #define DEFAULT_DIRECTORY_SEP '\\'
|
428
|
436
|
867
|
437 DECLARE_INLINE_HEADER (Ibyte sysfile_get_directory_sep (void))
|
771
|
438 {
|
|
439 if (!CHARP (Vdirectory_sep_char)
|
|
440 || (XCHAR (Vdirectory_sep_char) != '/'
|
|
441 && XCHAR (Vdirectory_sep_char) != '\\'))
|
|
442 {
|
|
443 warn_when_safe
|
|
444 (Qfile_name, Qerror,
|
|
445 "`directory-sep-char' set to invalid %s: resetting to %c.",
|
|
446 DEFAULT_DIRECTORY_SEP);
|
|
447 Vdirectory_sep_char = make_char (DEFAULT_DIRECTORY_SEP);
|
|
448 }
|
|
449
|
|
450 return XCHAR (Vdirectory_sep_char);
|
|
451 }
|
|
452 #define DIRECTORY_SEP sysfile_get_directory_sep()
|
|
453
|
|
454 #else /* not WIN32_NATIVE */
|
|
455
|
|
456 #define SEPCHAR ':'
|
|
457 #define DEFAULT_DIRECTORY_SEP '/'
|
|
458 #define DIRECTORY_SEP '/'
|
|
459
|
|
460 #endif /* WIN32_NATIVE */
|
|
461
|
428
|
462
|
1315
|
463 #ifdef WIN32_ANY
|
771
|
464
|
|
465 #define DEVICE_SEP ':'
|
|
466
|
|
467 #define IS_DEVICE_SEP(c) ((c) == DEVICE_SEP)
|
|
468
|
867
|
469 DECLARE_INLINE_HEADER (int IS_DIRECTORY_SEP (Ichar c))
|
771
|
470 {
|
|
471 return (c == '/' || c == '\\');
|
|
472 }
|
|
473
|
867
|
474 DECLARE_INLINE_HEADER (int IS_ANY_SEP (Ichar c))
|
771
|
475 {
|
|
476 return (c == '/' || c == '\\' || c == ':');
|
|
477 }
|
|
478
|
1315
|
479 #else /* not WIN32_ANY */
|
771
|
480
|
|
481 #define IS_DEVICE_SEP(c) 0
|
|
482 #define IS_DIRECTORY_SEP(c) ((c) == DIRECTORY_SEP)
|
|
483 #define IS_ANY_SEP(c) IS_DIRECTORY_SEP (c)
|
|
484
|
1315
|
485 #endif /* WIN32_ANY */
|
771
|
486
|
|
487 #endif /* emacs */
|
|
488
|
440
|
489 #endif /* INCLUDED_sysfile_h_ */
|