diff --git a/include/xbps_api_impl.h b/include/xbps_api_impl.h index ade3d49c..dd3910d8 100644 --- a/include/xbps_api_impl.h +++ b/include/xbps_api_impl.h @@ -198,7 +198,7 @@ bool HIDDEN xbps_transaction_shlibs(struct xbps_handle *, xbps_array_t, xbps_arr */ int HIDDEN xbps_transaction_init(struct xbps_handle *); -int HIDDEN xbps_transaction_store(struct xbps_handle *, xbps_array_t, xbps_dictionary_t, pkg_state_t); +int HIDDEN xbps_transaction_store(struct xbps_handle *, xbps_array_t, xbps_dictionary_t); /** * @private diff --git a/lib/repo_pkgdeps.c b/lib/repo_pkgdeps.c index 19320697..a03770f1 100644 --- a/lib/repo_pkgdeps.c +++ b/lib/repo_pkgdeps.c @@ -330,7 +330,7 @@ find_repo_deps(struct xbps_handle *xhp, * Package is on repo, add it into the transaction dictionary. */ xbps_dictionary_set_cstring_nocopy(curpkgd, "transaction", reason); - rv = xbps_transaction_store(xhp, unsorted, curpkgd, state); + rv = xbps_transaction_store(xhp, unsorted, curpkgd); if (rv != 0) { xbps_dbg_printf(xhp, "xbps_transaction_store failed for `%s': %s\n", reqpkg, strerror(rv)); break; @@ -359,7 +359,7 @@ find_repo_deps(struct xbps_handle *xhp, * Package is on repo, add it into the transaction dictionary. */ xbps_dictionary_set_cstring_nocopy(curpkgd, "transaction", reason); - rv = xbps_transaction_store(xhp, unsorted, curpkgd, state); + rv = xbps_transaction_store(xhp, unsorted, curpkgd); if (rv != 0) { xbps_dbg_printf(xhp, "xbps_transaction_store failed for `%s': %s\n", reqpkg, strerror(rv)); break; diff --git a/lib/transaction_ops.c b/lib/transaction_ops.c index f6ca0ac6..7b5deebb 100644 --- a/lib/transaction_ops.c +++ b/lib/transaction_ops.c @@ -197,7 +197,7 @@ trans_find_pkg(struct xbps_handle *xhp, const char *pkg, bool reinstall) free(pkgname); return EINVAL; } - if ((rv = xbps_transaction_store(xhp, pkgs, pkg_repod, state)) != 0) { + if ((rv = xbps_transaction_store(xhp, pkgs, pkg_repod)) != 0) { free(pkgname); return rv; } @@ -310,7 +310,8 @@ xbps_transaction_remove_pkg(struct xbps_handle *xhp, obj = xbps_array_get(orphans, count); xbps_dictionary_get_cstring_nocopy(obj, "pkgver", &pkgver); xbps_dictionary_set_cstring_nocopy(obj, "transaction", "remove"); - xbps_array_add(pkgs, obj); + if ((rv = xbps_transaction_store(xhp, pkgs, obj)) != 0) + return EINVAL; xbps_dbg_printf(xhp, "%s: added into transaction (remove).\n", pkgver); } reqby = xbps_pkgdb_get_pkg_revdeps(xhp, pkgname); @@ -331,7 +332,8 @@ rmpkg: */ xbps_dictionary_get_cstring_nocopy(pkgd, "pkgver", &pkgver); xbps_dictionary_set_cstring_nocopy(pkgd, "transaction", "remove"); - xbps_array_add(pkgs, pkgd); + if ((rv = xbps_transaction_store(xhp, pkgs, pkgd)) != 0) + return EINVAL; xbps_dbg_printf(xhp, "%s: added into transaction (remove).\n", pkgver); reqby = xbps_pkgdb_get_pkg_revdeps(xhp, pkgver); /* diff --git a/lib/transaction_store.c b/lib/transaction_store.c index 237523bd..684c3d7c 100644 --- a/lib/transaction_store.c +++ b/lib/transaction_store.c @@ -32,22 +32,15 @@ int HIDDEN xbps_transaction_store(struct xbps_handle *xhp, xbps_array_t pkgs, - xbps_dictionary_t pkgd, pkg_state_t pstate) + xbps_dictionary_t pkgd) { xbps_array_t replaces; const char *pkgver; char *pkgname, *self_replaced; - int rv; xbps_dictionary_get_cstring_nocopy(pkgd, "pkgver", &pkgver); if (xbps_find_pkg_in_array(pkgs, pkgver, NULL)) return 0; - /* - * Overwrite package state in dictionary with same state than the - * package currently uses, otherwise not-installed. - */ - if ((rv = xbps_set_pkg_state_dictionary(pkgd, pstate)) != 0) - return rv; /* * Add required objects into package dep's dictionary. */ diff --git a/tests/xbps/libxbps/shell/remove_test.sh b/tests/xbps/libxbps/shell/remove_test.sh index 62ba3f4d..6b91dc1d 100644 --- a/tests/xbps/libxbps/shell/remove_test.sh +++ b/tests/xbps/libxbps/shell/remove_test.sh @@ -136,9 +136,32 @@ remove_readonly_files_body() { atf_check_equal $rv 0 } +atf_test_case remove_dups + +remove_dups_head() { + atf_set "descr" "Tests for package removal: remove pkg multiple times" +} + +remove_dups_body() { + mkdir some_repo + mkdir -p pkg_A/usr/bin + + cd some_repo + xbps-create -A noarch -n A-1.0_1 -s "A pkg" ../pkg_A + atf_check_equal $? 0 + xbps-rindex -a *.xbps + atf_check_equal $? 0 + cd .. + xbps-install -r root -C null.conf --repository=$PWD/some_repo -yv A + atf_check_equal $? 0 + out=$(xbps-remove -r root -yvn A A A|wc -l) + atf_check_equal $out 1 +} + atf_init_test_cases() { atf_add_test_case keep_base_symlinks atf_add_test_case remove_readonly_files atf_add_test_case remove_symlinks atf_add_test_case remove_symlinks_from_root + atf_add_test_case remove_dups }