summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Runge <mrunge@google.com>2014-10-29 03:49:57 +0100
committerMichael Runge <mrunge@google.com>2014-10-29 03:49:57 +0100
commit042c3cd04ec3ef416019fa382cd5b1a942bd79e1 (patch)
tree8b0544483b3827351f406c5e987e2bf2641d9c68
parentLog mount/unmount errors to UI (diff)
downloadandroid_bootable_recovery-042c3cd04ec3ef416019fa382cd5b1a942bd79e1.tar
android_bootable_recovery-042c3cd04ec3ef416019fa382cd5b1a942bd79e1.tar.gz
android_bootable_recovery-042c3cd04ec3ef416019fa382cd5b1a942bd79e1.tar.bz2
android_bootable_recovery-042c3cd04ec3ef416019fa382cd5b1a942bd79e1.tar.lz
android_bootable_recovery-042c3cd04ec3ef416019fa382cd5b1a942bd79e1.tar.xz
android_bootable_recovery-042c3cd04ec3ef416019fa382cd5b1a942bd79e1.tar.zst
android_bootable_recovery-042c3cd04ec3ef416019fa382cd5b1a942bd79e1.zip
-rw-r--r--minzip/Zip.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/minzip/Zip.c b/minzip/Zip.c
index 5070104d3..70aff00cd 100644
--- a/minzip/Zip.c
+++ b/minzip/Zip.c
@@ -1067,7 +1067,8 @@ bool mzExtractRecursive(const ZipArchive *pArchive,
setfscreatecon(secontext);
}
- int fd = creat(targetFile, UNZIP_FILEMODE);
+ int fd = open(targetFile, O_CREAT|O_WRONLY|O_TRUNC|O_SYNC
+ , UNZIP_FILEMODE);
if (secontext) {
freecon(secontext);
@@ -1082,7 +1083,12 @@ bool mzExtractRecursive(const ZipArchive *pArchive,
}
bool ok = mzExtractZipEntryToFile(pArchive, pEntry, fd);
- close(fd);
+ if (ok) {
+ ok = (fsync(fd) == 0);
+ }
+ if (close(fd) != 0) {
+ ok = false;
+ }
if (!ok) {
LOGE("Error extracting \"%s\"\n", targetFile);
ok = false;