From 40a264478e65c652f863b3e43b0fc8aa10f0bd19 Mon Sep 17 00:00:00 2001 From: Dan McGee Date: Wed, 28 Sep 2011 01:53:43 -0500 Subject: Track unresolvable transaction packages Rather than free them right away, keep the list on the transaction as we already do with add and remove lists. This is necessary because we may be manipulating pointers the frontend needs to refer to packages, and we are breaking our contract as stated in the alpm_add_pkg() documentation of only freeing packages at the end of a transaction. This fixes an issue found when refactoring the package list display code. Signed-off-by: Dan McGee --- lib/libalpm/trans.c | 3 +++ 1 file changed, 3 insertions(+) (limited to 'lib/libalpm/trans.c') diff --git a/lib/libalpm/trans.c b/lib/libalpm/trans.c index a5fa95b9..fbc5feec 100644 --- a/lib/libalpm/trans.c +++ b/lib/libalpm/trans.c @@ -236,6 +236,9 @@ void _alpm_trans_free(alpm_trans_t *trans) return; } + alpm_list_free_inner(trans->unresolvable, + (alpm_list_fn_free)_alpm_pkg_free_trans); + alpm_list_free(trans->unresolvable); alpm_list_free_inner(trans->add, (alpm_list_fn_free)_alpm_pkg_free_trans); alpm_list_free(trans->add); alpm_list_free_inner(trans->remove, (alpm_list_fn_free)_alpm_pkg_free); -- cgit v1.2.3-24-g4f1b