diff options
author | JP Abgrall <jpa@google.com> | 2014-03-08 01:34:24 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2014-03-08 01:34:24 +0000 |
commit | 443904746301e4d519e51075487ea4c8b9a860e3 (patch) | |
tree | 3d5c3a181fe744a3db4bd1fe94d0fba1cd99358e | |
parent | b2c34ece647c212baa30c474394c498a2d6dd61f (diff) | |
parent | 55b6c843a6166fbbf57aa4afba8b2c2b3e87cfea (diff) | |
download | system_core-443904746301e4d519e51075487ea4c8b9a860e3.zip system_core-443904746301e4d519e51075487ea4c8b9a860e3.tar.gz system_core-443904746301e4d519e51075487ea4c8b9a860e3.tar.bz2 |
Merge "adb: Don't unlink special files on sync failure."
-rw-r--r-- | adb/file_sync_service.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/adb/file_sync_service.c b/adb/file_sync_service.c index 25bfdc9..1d80d26 100644 --- a/adb/file_sync_service.c +++ b/adb/file_sync_service.c @@ -172,7 +172,7 @@ static int fail_errno(int s) } static int handle_send_file(int s, char *path, uid_t uid, - gid_t gid, mode_t mode, char *buffer) + gid_t gid, mode_t mode, char *buffer, bool do_unlink) { syncmsg msg; unsigned int timestamp = 0; @@ -236,7 +236,7 @@ static int handle_send_file(int s, char *path, uid_t uid, if(writex(fd, buffer, len)) { int saved_errno = errno; adb_close(fd); - adb_unlink(path); + if (do_unlink) adb_unlink(path); fd = -1; errno = saved_errno; if(fail_errno(s)) return -1; @@ -261,7 +261,7 @@ static int handle_send_file(int s, char *path, uid_t uid, fail: if(fd >= 0) adb_close(fd); - adb_unlink(path); + if (do_unlink) adb_unlink(path); return -1; } @@ -323,6 +323,7 @@ static int do_send(int s, char *path, char *buffer) char *tmp; unsigned int mode; int is_link, ret; + bool do_unlink; tmp = strrchr(path,','); if(tmp) { @@ -339,10 +340,12 @@ static int do_send(int s, char *path, char *buffer) if(!tmp || errno) { mode = 0644; is_link = 0; + do_unlink = true; } else { struct stat st; /* Don't delete files before copying if they are not "regular" */ - if(lstat(path, &st) || S_ISREG(st.st_mode) || S_ISLNK(st.st_mode)) { + do_unlink = lstat(path, &st) || S_ISREG(st.st_mode) || S_ISLNK(st.st_mode); + if (do_unlink) { adb_unlink(path); } } @@ -369,7 +372,7 @@ static int do_send(int s, char *path, char *buffer) if (is_on_system(path)) { fs_config(tmp, 0, &uid, &gid, &mode, &cap); } - ret = handle_send_file(s, path, uid, gid, mode, buffer); + ret = handle_send_file(s, path, uid, gid, mode, buffer, do_unlink); } return ret; |