diff options
author | Timo Teräs <timo.teras@iki.fi> | 2023-05-10 16:51:56 +0300 |
---|---|---|
committer | Timo Teräs <timo.teras@iki.fi> | 2023-05-10 16:51:56 +0300 |
commit | 23be7e321009b5c524ebb06746219760d9b40b6a (patch) | |
tree | 4a289b940e16f46fdb090e4e80de54fc81c810fa | |
parent | f360cacea6f112ff1a515eea01e9cfaabd605b89 (diff) | |
download | apk-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.c | 8 |
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, |