From 236ef35e1ce9eccfa47d37718b763decb7077136 Mon Sep 17 00:00:00 2001 From: Dave Reisner Date: Fri, 10 Dec 2010 23:13:30 -0500 Subject: fix memory leak in print_pkg lists are allocated when they're requested, and not resident in memory when alpm is initialized. grab a pointer to them so they can be freed after each loop. --- expac.c | 35 ++++++++++++++++++++++++----------- 1 file changed, 24 insertions(+), 11 deletions(-) diff --git a/expac.c b/expac.c index 503af54..4a17d3b 100644 --- a/expac.c +++ b/expac.c @@ -346,6 +346,7 @@ static int print_time(time_t timestamp) { } static int print_pkg(pmpkg_t *pkg, const char *format) { + alpm_list_t *list = NULL; const char *f; char fmt[32]; int len, out = 0; @@ -413,45 +414,57 @@ static int print_pkg(pmpkg_t *pkg, const char *format) { /* lists */ case 'N': /* requiredby */ - out += print_list(alpm_pkg_compute_requiredby(pkg), NULL, shortdeps); + list = alpm_pkg_compute_requiredby(pkg); + out += print_list(list, NULL, shortdeps); break; case 'L': /* licenses */ - out += print_list(alpm_pkg_get_licenses(pkg), NULL, shortdeps); + list = alpm_pkg_get_licenses(pkg); + out += print_list(list, NULL, shortdeps); break; case 'G': /* groups */ - out += print_list(alpm_pkg_get_groups(pkg), NULL, shortdeps); + list = alpm_pkg_get_groups(pkg); + out += print_list(list, NULL, shortdeps); break; case 'E': /* depends (shortdeps) */ - out += print_list(alpm_pkg_get_depends(pkg), (extractfn)alpm_dep_get_name, shortdeps); + list = alpm_pkg_get_depends(pkg); + out += print_list(list, (extractfn)alpm_dep_get_name, shortdeps); break; case 'D': /* depends */ - out += print_list(alpm_pkg_get_depends(pkg), (extractfn)alpm_dep_compute_string, shortdeps); + list = alpm_pkg_get_depends(pkg); + out += print_list(list, (extractfn)alpm_dep_compute_string, shortdeps); break; case 'O': /* optdepends */ - out += print_list(alpm_pkg_get_optdepends(pkg), NULL, shortdeps); + list = alpm_pkg_get_optdepends(pkg); + out += print_list(list, NULL, shortdeps); break; case 'C': /* conflicts */ - out += print_list(alpm_pkg_get_conflicts(pkg), NULL, shortdeps); + list = alpm_pkg_get_conflicts(pkg); + out += print_list(list, NULL, shortdeps); break; case 'S': /* provides (shortdeps) */ shortdeps = true; case 'P': /* provides */ - out += print_list(alpm_pkg_get_provides(pkg), NULL, shortdeps); + list = alpm_pkg_get_provides(pkg); + out += print_list(list, NULL, shortdeps); break; case 'R': /* replaces */ - out += print_list(alpm_pkg_get_replaces(pkg), NULL, shortdeps); + list = alpm_pkg_get_replaces(pkg); + out += print_list(list, NULL, shortdeps); break; case 'F': /* files */ - out += print_list(alpm_pkg_get_files(pkg), NULL, shortdeps); + list = alpm_pkg_get_files(pkg); + out += print_list(list, NULL, shortdeps); break; case 'B': /* backup */ - out += print_list(alpm_pkg_get_backup(pkg), NULL, shortdeps); + list = alpm_pkg_get_backup(pkg); + out += print_list(list, NULL, shortdeps); break; case '%': putchar('%'); out++; break; } + FREELIST(list); } else if (*f == '\\') { char buf[3]; /* its not safe to do this in a single sprintf */ buf[0] = *f; -- cgit v1.2.3-70-g09d2