openat: simplify use of at-func.c
[gnulib.git] / lib / mkfifoat.c
1 /* Create a named fifo relative to an open directory.
2    Copyright (C) 2009 Free Software Foundation, Inc.
3
4    This program is free software: you can redistribute it and/or modify
5    it under the terms of the GNU General Public License as published by
6    the Free Software Foundation; either version 3 of the License, or
7    (at your option) any later version.
8
9    This program is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12    GNU General Public License for more details.
13
14    You should have received a copy of the GNU General Public License
15    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
16
17 /* written by Eric Blake */
18
19 #include <config.h>
20
21 #include <sys/stat.h>
22
23 #ifndef HAVE_MKFIFO
24 # define HAVE_MKFIFO 0
25 #endif
26 #ifndef HAVE_MKNOD
27 # define HAVE_MKNOD 0
28 #endif
29
30 /* For now, all known systems either have both mkfifo and mknod, or
31    neither.  If this is not true, we can implement the portable
32    aspects of one using the other (POSIX only requires mknod to create
33    fifos; all other uses of mknod are for root users and outside the
34    realm of POSIX).  */
35 #if HAVE_MKNOD != HAVE_MKFIFO
36 # error Please report this message and your system to bug-gnulib@gnu.org.
37 #endif
38
39 #if !HAVE_MKFIFO
40 /* Mingw lacks mkfifo and mknod, so this wrapper is trivial.  */
41
42 # include <errno.h>
43
44 int
45 mkfifoat (int fd _UNUSED_PARAMETER_, char const *path _UNUSED_PARAMETER_,
46           mode_t mode _UNUSED_PARAMETER_)
47 {
48   errno = ENOSYS;
49   return -1;
50 }
51
52 int
53 mknodat (int fd _UNUSED_PARAMETER_, char const *path _UNUSED_PARAMETER_,
54          mode_t mode _UNUSED_PARAMETER_, dev_t dev _UNUSED_PARAMETER_)
55 {
56   errno = ENOSYS;
57   return -1;
58 }
59
60 #else /* HAVE_MKFIFO */
61
62 /* Create a named fifo FILE relative to directory FD, with access
63    permissions in MODE.  If possible, do it without changing the
64    working directory.  Otherwise, resort to using save_cwd/fchdir,
65    then mkfifo/restore_cwd.  If either the save_cwd or the restore_cwd
66    fails, then give a diagnostic and exit nonzero.  */
67
68 # define AT_FUNC_NAME mkfifoat
69 # define AT_FUNC_F1 mkfifo
70 # define AT_FUNC_POST_FILE_PARAM_DECLS , mode_t mode
71 # define AT_FUNC_POST_FILE_ARGS        , mode
72 # include "at-func.c"
73 # undef AT_FUNC_NAME
74 # undef AT_FUNC_F1
75 # undef AT_FUNC_POST_FILE_PARAM_DECLS
76 # undef AT_FUNC_POST_FILE_ARGS
77
78 /* Create a file system node FILE relative to directory FD, with
79    access permissions and file type in MODE, and device type in DEV.
80    Usually, non-root applications can only create named fifos, with
81    DEV set to 0.  If possible, create the node without changing the
82    working directory.  Otherwise, resort to using save_cwd/fchdir,
83    then mknod/restore_cwd.  If either the save_cwd or the restore_cwd
84    fails, then give a diagnostic and exit nonzero.  */
85
86 # define AT_FUNC_NAME mknodat
87 # define AT_FUNC_F1 mknod
88 # define AT_FUNC_POST_FILE_PARAM_DECLS , mode_t mode, dev_t dev
89 # define AT_FUNC_POST_FILE_ARGS        , mode, dev
90 # include "at-func.c"
91 # undef AT_FUNC_NAME
92 # undef AT_FUNC_F1
93 # undef AT_FUNC_POST_FILE_PARAM_DECLS
94 # undef AT_FUNC_POST_FILE_ARGS
95
96 #endif /* HAVE_MKFIFO */