aboutsummaryrefslogtreecommitdiffstats
path: root/updater/install.c
diff options
context:
space:
mode:
authorMichael Runge <mrunge@google.com>2014-07-21 17:40:02 -0700
committerMichael Runge <mrunge@google.com>2014-07-21 17:40:02 -0700
commita91ecc59b2753a3dcc93b2619559a980074e77bd (patch)
tree0c44c214421c03f2e34ef529f05b419d20a693c8 /updater/install.c
parent945fc68c62692467ddb8b7d714bcf0bf01c783c2 (diff)
downloadbootable_recovery-a91ecc59b2753a3dcc93b2619559a980074e77bd.zip
bootable_recovery-a91ecc59b2753a3dcc93b2619559a980074e77bd.tar.gz
bootable_recovery-a91ecc59b2753a3dcc93b2619559a980074e77bd.tar.bz2
Auto create parent directories for rename support
Sometimes renames will move a file into a directory that does not yet exist. This will create the parent directories, using the same symlink logic, to ensure that there is a valid destination. Change-Id: Iaa005a12ce800c39f4db20f7c25a2a68cb40a52d
Diffstat (limited to 'updater/install.c')
-rw-r--r--updater/install.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/updater/install.c b/updater/install.c
index edc386d..5025881 100644
--- a/updater/install.c
+++ b/updater/install.c
@@ -357,8 +357,10 @@ Value* RenameFn(const char* name, State* state, int argc, Expr* argv[]) {
name);
goto done;
}
-
- if (rename(src_name, dst_name) != 0) {
+ if (make_parents(dst_name) != 0) {
+ ErrorAbort(state, "Creating parent of %s() failed, error %s()",
+ dst_name, strerror(errno));
+ } else if (rename(src_name, dst_name) != 0) {
ErrorAbort(state, "Rename of %s() to %s() failed, error %s()",
src_name, dst_name, strerror(errno));
} else {
@@ -642,7 +644,7 @@ static int make_parents(char* name) {
*p = '\0';
if (make_parents(name) < 0) return -1;
int result = mkdir(name, 0700);
- if (result == 0) printf("symlink(): created [%s]\n", name);
+ if (result == 0) printf("created [%s]\n", name);
*p = '/';
if (result == 0 || errno == EEXIST) {
// successfully created or already existed; we're done