X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/f0fca04e4e136c4a487a922e8fb09acf46aeafa0..18c71e96f8f9281f570046095433df38c6785fd6:/syscall.c diff --git a/syscall.c b/syscall.c index c655969e..3780bac5 100644 --- a/syscall.c +++ b/syscall.c @@ -24,8 +24,9 @@ extern int dry_run; extern int read_only; +extern int list_only; -#define CHECK_RO if (read_only) {errno = EROFS; return -1;} +#define CHECK_RO if (read_only || list_only) {errno = EROFS; return -1;} int do_unlink(char *fname) { @@ -75,8 +76,17 @@ int do_rmdir(char *pathname) int do_open(char *pathname, int flags, mode_t mode) { - if (dry_run) return -1; - CHECK_RO + if (flags != O_RDONLY) { + if (dry_run) return -1; + CHECK_RO + } +#ifdef O_BINARY + /* for Windows */ + flags |= O_BINARY; +#endif + /* some systems can't handle a double / */ + if (pathname[0] == '/' && pathname[1] == '/') pathname++; + return open(pathname, flags, mode); } @@ -107,6 +117,9 @@ char *do_mktemp(char *template) { if (dry_run) return NULL; if (read_only) {errno = EROFS; return NULL;} + + /* TODO: Replace this with a good builtin mkstemp, perhaps + * from OpenBSD. Some glibc versions are buggy. */ return mktemp(template); } @@ -149,6 +162,17 @@ OFF_T do_lseek(int fd, OFF_T offset, int whence) #endif } +#ifdef USE_MMAP +void *do_mmap(void *start, int len, int prot, int flags, int fd, OFF_T offset) +{ +#if HAVE_OFF64_T + return mmap64(start, len, prot, flags, fd, offset); +#else + return mmap(start, len, prot, flags, fd, offset); +#endif +} +#endif + char *d_name(struct dirent *di) { #if HAVE_BROKEN_READDIR