summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTimo Teräs <timo.teras@iki.fi>2023-05-10 16:51:56 +0300
committerTimo Teräs <timo.teras@iki.fi>2023-05-10 16:51:56 +0300
commit23be7e321009b5c524ebb06746219760d9b40b6a (patch)
tree4a289b940e16f46fdb090e4e80de54fc81c810fa
parentf360cacea6f112ff1a515eea01e9cfaabd605b89 (diff)
downloadapk-tools-23be7e321009b5c524ebb06746219760d9b40b6a.tar.gz
apk-tools-23be7e321009b5c524ebb06746219760d9b40b6a.tar.bz2
apk-tools-23be7e321009b5c524ebb06746219760d9b40b6a.tar.xz
apk-tools-23be7e321009b5c524ebb06746219760d9b40b6a.zip
del: fix up previous commit
fixes commit "del: fix --rdepends" to not delete provided names if not using --rdepends
-rw-r--r--src/app_del.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/app_del.c b/src/app_del.c
index 5304c30..c077987 100644
--- a/src/app_del.c
+++ b/src/app_del.c
@@ -114,13 +114,15 @@ static void delete_pkg(struct apk_package *pkg0, struct apk_dependency *dep0,
struct apk_dependency *d;
apk_deps_del(&ctx->world, pkg0->name);
- foreach_array_item(d, pkg0->provides)
- apk_deps_del(&ctx->world, d->name);
- if (ctx->recursive_delete)
+ if (ctx->recursive_delete) {
+ foreach_array_item(d, pkg0->provides)
+ apk_deps_del(&ctx->world, d->name);
+
apk_pkg_foreach_reverse_dependency(
pkg0, ctx->genid | APK_FOREACH_INSTALLED | APK_DEP_SATISFIES,
delete_pkg, pctx);
+ }
}
static int delete_name(struct apk_database *db, const char *match,