diff options
author | Denys Vlasenko | 2009-07-25 11:52:32 +0200 |
---|---|---|
committer | Denys Vlasenko | 2009-07-25 11:52:32 +0200 |
commit | d1090c91ccbd75b30f30a70dbbb2e0f7b129f083 (patch) | |
tree | 7f43c06e94d7f1db5fdbc86e914f8ff98557c2fd /archival | |
parent | f3b56b428f5c903ef4622d7e04925d9056f751e9 (diff) | |
download | busybox-d1090c91ccbd75b30f30a70dbbb2e0f7b129f083.zip busybox-d1090c91ccbd75b30f30a70dbbb2e0f7b129f083.tar.gz |
dpkg: delete postrm script after it's run, not before. closes bug 449
function old new delta
purge_package 220 252 +32
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'archival')
-rw-r--r-- | archival/dpkg.c | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/archival/dpkg.c b/archival/dpkg.c index 577b77f..abeb162 100644 --- a/archival/dpkg.c +++ b/archival/dpkg.c @@ -1354,8 +1354,8 @@ static void remove_package(const unsigned package_num, int noisy) free_array(exclude_files); free_array(remove_files); - /* Create a list of files in /var/lib/dpkg/info/<package>.* to keep */ - exclude_files = xzalloc(sizeof(char*) * 3); + /* Create a list of files in /var/lib/dpkg/info/<package>.* to keep */ + exclude_files = xzalloc(sizeof(exclude_files[0]) * 3); exclude_files[0] = xstrdup(conffile_name); exclude_files[1] = xasprintf("/var/lib/dpkg/info/%s.%s", package_name, "postrm"); @@ -1393,20 +1393,25 @@ static void purge_package(const unsigned package_num) sprintf(list_name, "/var/lib/dpkg/info/%s.%s", package_name, "list"); remove_files = create_list(list_name); - exclude_files = xzalloc(sizeof(char*)); - /* Some directories cant be removed straight away, so do multiple passes */ - while (remove_file_array(remove_files, exclude_files)) /* repeat */; + while (remove_file_array(remove_files, NULL)) + continue; free_array(remove_files); /* Create a list of all /var/lib/dpkg/info/<package> files */ remove_files = all_control_list(package_name); + + /* Delete all of them except the postrm script */ + exclude_files = xzalloc(sizeof(exclude_files[0]) * 2); + exclude_files[0] = xasprintf("/var/lib/dpkg/info/%s.%s", package_name, "postrm"); remove_file_array(remove_files, exclude_files); - free_array(remove_files); - free(exclude_files); + free_array(exclude_files); - /* Run postrm script */ + /* Run and remove postrm script */ run_package_script_or_die(package_name, "postrm"); + remove_file_array(remove_files, NULL); + + free_array(remove_files); /* Change package status */ set_status(status_num, "not-installed", 3); |