From 6363f5c76f236303c13e714d451ccd2b1208ebca Mon Sep 17 00:00:00 2001 From: Laurent Bercot Date: Tue, 25 Aug 2015 23:12:11 +0000 Subject: Add touch, filecopy_unsafe, filecopy_suffix --- src/libstddjb/filecopy_suffix.c | 25 +++++++++++++++++++++++++ src/libstddjb/filecopy_unsafe.c | 32 ++++++++++++++++++++++++++++++++ src/libstddjb/hiercopy_tmp.c | 28 +--------------------------- src/libstddjb/touch.c | 11 +++++++++++ 4 files changed, 69 insertions(+), 27 deletions(-) create mode 100644 src/libstddjb/filecopy_suffix.c create mode 100644 src/libstddjb/filecopy_unsafe.c create mode 100644 src/libstddjb/touch.c (limited to 'src/libstddjb') diff --git a/src/libstddjb/filecopy_suffix.c b/src/libstddjb/filecopy_suffix.c new file mode 100644 index 0000000..70673ea --- /dev/null +++ b/src/libstddjb/filecopy_suffix.c @@ -0,0 +1,25 @@ +/* ISC license. */ + +#include +#include +#include +#include +#include + +int filecopy_suffix (char const *src, char const *dst, unsigned int mode, char const *suffix) +{ + unsigned int dstlen = str_len(dst) ; + unsigned int suffixlen = str_len(suffix) ; + char tmp[dstlen + suffixlen + 1] ; + byte_copy(tmp, dstlen, dst) ; + byte_copy(tmp + dstlen, suffixlen + 1, suffix) ; + if (!filecopy_unsafe(src, tmp, mode)) return 0 ; + if (rename(tmp, dst) < 0) + { + register int e = errno ; + unlink(tmp) ; + errno = e ; + return 0 ; + } + return 1 ; +} diff --git a/src/libstddjb/filecopy_unsafe.c b/src/libstddjb/filecopy_unsafe.c new file mode 100644 index 0000000..b60c783 --- /dev/null +++ b/src/libstddjb/filecopy_unsafe.c @@ -0,0 +1,32 @@ +/* ISC license. */ + +#include +#include +#include + +int filecopy_unsafe (char const *src, char const *dst, unsigned int mode) +{ + int d ; + int s = open2(src, O_RDONLY) ; + if (s < 0) return 0 ; + d = open3(dst, O_WRONLY | O_CREAT | O_TRUNC, mode) ; + if (d < 0) + { + register int e = errno ; + fd_close(s) ; + errno = e ; + return 0 ; + } + if (fd_cat(s, d) < 0) + { + register int e = errno ; + fd_close(d) ; + fd_close(s) ; + errno = e ; + return 0 ; + } + fd_close(d) ; + fd_close(s) ; + return 1 ; +} + diff --git a/src/libstddjb/hiercopy_tmp.c b/src/libstddjb/hiercopy_tmp.c index ce2282f..bcff2b2 100644 --- a/src/libstddjb/hiercopy_tmp.c +++ b/src/libstddjb/hiercopy_tmp.c @@ -11,32 +11,6 @@ #include #include -static int filecopy (char const *src, char const *dst, mode_t mode) -{ - int d ; - int s = open_readb(src) ; - if (s < 0) return 0 ; - d = open3(dst, O_WRONLY | O_CREAT | O_TRUNC, mode) ; - if (d < 0) - { - fd_close(s) ; - return 0 ; - } - if (fd_cat(s, d) < 0) goto err ; - fd_close(s) ; - fd_close(d) ; - return 1 ; - -err: - { - register int e = errno ; - fd_close(s) ; - fd_close(d) ; - errno = e ; - } - return 0 ; -} - static int dircopy (char const *src, char const *dst, mode_t mode, stralloc *tmp) { unsigned int tmpbase = tmp->len ; @@ -108,7 +82,7 @@ int hiercopy_tmp (char const *src, char const *dst, stralloc *tmp) if (lstat(src, &st) < 0) return 0 ; if (S_ISREG(st.st_mode)) { - if (!filecopy(src, dst, st.st_mode)) return 0 ; + if (!filecopy_unsafe(src, dst, st.st_mode)) return 0 ; } else if (S_ISDIR(st.st_mode)) { diff --git a/src/libstddjb/touch.c b/src/libstddjb/touch.c new file mode 100644 index 0000000..45a8d2c --- /dev/null +++ b/src/libstddjb/touch.c @@ -0,0 +1,11 @@ +/* ISC license. */ + +#include + +int touch (char const *file) +{ + register int fd = open_create(file) ; + if (fd < 0) return 0 ; + fd_close(fd) ; + return 1 ; +} -- cgit v1.2.3