X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/bf6dcd17133e4e29e09420e3252a4184be3b04b6..9f27cd8ca6ccbf1ab4cd8b0b66445535e2573d59:/util.c?ds=sidebyside diff --git a/util.c b/util.c index 5c55ce41..5129c35b 100644 --- a/util.c +++ b/util.c @@ -253,20 +253,20 @@ int copy_file(char *source, char *dest, mode_t mode) ifd = do_open(source, O_RDONLY, 0); if (ifd == -1) { rprintf(FERROR,"open %s: %s\n", - source,strerror(errno)); + full_fname(source), strerror(errno)); return -1; } if (robust_unlink(dest) && errno != ENOENT) { rprintf(FERROR,"unlink %s: %s\n", - dest,strerror(errno)); + full_fname(dest), strerror(errno)); return -1; } ofd = do_open(dest, O_WRONLY | O_CREAT | O_TRUNC | O_EXCL, mode); if (ofd == -1) { rprintf(FERROR,"open %s: %s\n", - dest,strerror(errno)); + full_fname(dest), strerror(errno)); close(ifd); return -1; } @@ -274,19 +274,27 @@ int copy_file(char *source, char *dest, mode_t mode) while ((len = safe_read(ifd, buf, sizeof buf)) > 0) { if (full_write(ofd, buf, len) < 0) { rprintf(FERROR,"write %s: %s\n", - dest,strerror(errno)); + full_fname(dest), strerror(errno)); close(ifd); close(ofd); return -1; } } - close(ifd); - close(ofd); + if (close(ifd) < 0) { + rprintf(FINFO, "close failed on %s: %s\n", + full_fname(source), strerror(errno)); + } + + if (close(ofd) < 0) { + rprintf(FERROR, "close failed on %s: %s\n", + full_fname(dest), strerror(errno)); + return -1; + } if (len < 0) { rprintf(FERROR,"read %s: %s\n", - source,strerror(errno)); + full_fname(source), strerror(errno)); return -1; } @@ -476,8 +484,7 @@ static int exclude_server_path(char *arg) if (server_exclude_list.head) { for (s = arg; (s = strchr(s, '/')) != NULL; ) { *s = '\0'; - if (check_exclude(&server_exclude_list, arg, 1, - "server pattern")) { + if (check_exclude(&server_exclude_list, arg, 1) < 0) { /* We must leave arg truncated! */ return 1; } @@ -786,9 +793,11 @@ char *alloc_sanitize_path(const char *path, const char *rootdir) char *buf; int rlen, plen = strlen(path); - if (*path == '/' && rootdir) + if (*path == '/' && rootdir) { rlen = strlen(rootdir); - else + if (rlen == 1) + path++; + } else rlen = 0; if (!(buf = new_array(char, rlen + plen + 1))) out_of_memory("alloc_sanitize_path"); @@ -796,11 +805,14 @@ char *alloc_sanitize_path(const char *path, const char *rootdir) memcpy(buf, rootdir, rlen); memcpy(buf + rlen, path, plen + 1); - if (rlen) + if (rlen > 1) rlen++; sanitize_path(buf + rlen, NULL); - if (rlen && buf[rlen] == '.' && buf[rlen+1] == '\0') - buf[rlen-1] = '\0'; + if (rlen && buf[rlen] == '.' && buf[rlen+1] == '\0') { + if (rlen > 1) + rlen--; + buf[rlen] = '\0'; + } return buf; }