From c7ffc96a16c6963fe0a07be7ee75e8f1f7426882 Mon Sep 17 00:00:00 2001 From: Timo Teras Date: Tue, 6 Jan 2009 21:10:00 +0200 Subject: db: rmdir() directories only on package purge --- src/database.c | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/database.c b/src/database.c index 3901ad2..42da186 100644 --- a/src/database.c +++ b/src/database.c @@ -113,7 +113,6 @@ static void apk_db_dir_put(struct apk_database *db, struct apk_db_dir *dir) return; db->installed.stats.dirs--; - rmdir(dir->dirname); if (dir->parent != NULL) apk_db_dir_put(db, dir->parent); @@ -190,7 +189,7 @@ static void apk_db_diri_set(struct apk_db_dir_instance *diri, mode_t mode, diri->gid = gid; } -static void apk_db_diri_create(struct apk_db_dir_instance *diri) +static void apk_db_diri_mkdir(struct apk_db_dir_instance *diri) { if (diri->dir->refs == 1) { mkdir(diri->dir->dirname, diri->mode); @@ -198,6 +197,13 @@ static void apk_db_diri_create(struct apk_db_dir_instance *diri) } } +static void apk_db_diri_rmdir(struct apk_db_dir_instance *diri) +{ + if (diri->dir->refs == 1) { + rmdir(diri->dir->dirname); + } +} + static void apk_db_diri_free(struct apk_database *db, struct apk_db_dir_instance *diri) { @@ -889,7 +895,7 @@ static int apk_db_install_archive_entry(void *_ctx, ctx->file_diri_node = NULL; apk_db_diri_set(diri, ae->mode & 0777, ae->uid, ae->gid); - apk_db_diri_create(diri); + apk_db_diri_mkdir(diri); } return r; @@ -914,6 +920,7 @@ static void apk_db_purge_pkg(struct apk_database *db, db->installed.stats.files--; } + apk_db_diri_rmdir(diri); apk_db_dir_put(db, diri->dir); __hlist_del(dc, &pkg->owned_dirs.first); } -- cgit v1.2.3-60-g2f50