summaryrefslogtreecommitdiff
path: root/src/libposixplz
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2024-05-03 21:01:48 +0000
committerLaurent Bercot <ska@appnovation.com>2024-05-03 21:01:48 +0000
commitc684d2df8c04554f79ada0c9bf5aa2e8c01aa82b (patch)
tree96bfdcfd6bed655dd991fc2e8d130a044ac7d1e4 /src/libposixplz
parent02926ee3447b1ea0d04b53b8fcb08d8b1a4deec5 (diff)
downloadskalibs-c684d2df8c04554f79ada0c9bf5aa2e8c01aa82b.tar.xz
Add mkptemp3
Signed-off-by: Laurent Bercot <ska@appnovation.com>
Diffstat (limited to 'src/libposixplz')
-rw-r--r--src/libposixplz/mkptemp2.c18
-rw-r--r--src/libposixplz/mkptemp3.c25
2 files changed, 26 insertions, 17 deletions
diff --git a/src/libposixplz/mkptemp2.c b/src/libposixplz/mkptemp2.c
index 4e4f64a..b4f5df5 100644
--- a/src/libposixplz/mkptemp2.c
+++ b/src/libposixplz/mkptemp2.c
@@ -1,24 +1,8 @@
/* ISC license. */
-#include <sys/stat.h>
-
-#include <skalibs/fcntl.h>
-#include <skalibs/djbunix.h>
#include <skalibs/posixplz.h>
-static int f (char const *fn, mode_t mode, void *data)
-{
- unsigned int flags = *(unsigned int *)data ;
- mode_t m = umask(0) ;
- int r = mkfifo(fn, mode) ;
- umask(m) ;
- if (r == -1) return -1 ;
- r = flags & O_NONBLOCK ? flags & O_CLOEXEC ? openc_read(fn) : open_read(fn) : flags & O_CLOEXEC ? openc_readb(fn) : open_readb(fn) ;
- if (r == -1) unlink_void(fn) ;
- return r ;
-}
-
int mkptemp2 (char *s, unsigned int flags)
{
- return mkfiletemp(s, &f, 0600, &flags) ;
+ return mkptemp3(s, 0600, flags) ;
}
diff --git a/src/libposixplz/mkptemp3.c b/src/libposixplz/mkptemp3.c
new file mode 100644
index 0000000..4b75b4d
--- /dev/null
+++ b/src/libposixplz/mkptemp3.c
@@ -0,0 +1,25 @@
+/* ISC license. */
+
+#include <sys/stat.h>
+
+#include <skalibs/fcntl.h>
+#include <skalibs/djbunix.h>
+#include <skalibs/posixplz.h>
+
+static int f (char const *fn, mode_t mode, void *data)
+{
+ unsigned int flags = *(unsigned int *)data ;
+ int r = mkfifo(fn, mode) ;
+ if (r == -1) return -1 ;
+ r = flags & O_NONBLOCK ? flags & O_CLOEXEC ? openc_read(fn) : open_read(fn) : flags & O_CLOEXEC ? openc_readb(fn) : open_readb(fn) ;
+ if (r == -1) unlink_void(fn) ;
+ return r ;
+}
+
+int mkptemp3 (char *s, mode_t mode, unsigned int flags)
+{
+ mode_t m = umask(0) ;
+ int r = mkfiletemp(s, &f, mode, &flags) ;
+ umask(m) ;
+ return r ;
+}