From 046cea8149c35b8d0dca6246c284f1d3c004410d Mon Sep 17 00:00:00 2001 From: ticktock35 Date: Mon, 15 Dec 2008 00:19:00 -0500 Subject: opkg: (leak fixing, day 3) fixed final memory leaks fixed reported from running libopkg_test git-svn-id: http://opkg.googlecode.com/svn/trunk@116 e8e0d7a0-c8d9-11dd-a880-a1081c7ac358 --- (limited to 'libopkg') diff --git a/libopkg/pkg_depends.c b/libopkg/pkg_depends.c index f6e3827..bc2ac27 100644 --- a/libopkg/pkg_depends.c +++ b/libopkg/pkg_depends.c @@ -372,6 +372,7 @@ int version_constraints_satisfied(depend_t * depends, pkg_t * pkg) comparison = pkg_compare_versions(pkg, temp); + free (temp->version); free(temp); if((depends->constraint == EARLIER) && @@ -661,6 +662,8 @@ int buildProvides(hash_table_t * hash, abstract_pkg_t * ab_pkg, pkg_t * pkg) if (!pkg->provides_count) return 0; + if (pkg->provides) + return 0; pkg->provides = (abstract_pkg_t **)malloc(sizeof(abstract_pkg_t *) * (pkg->provides_count + 1)); if (pkg->provides == NULL) { diff --git a/libopkg/pkg_hash.c b/libopkg/pkg_hash.c index f38c6ca..2fb0d1d 100644 --- a/libopkg/pkg_hash.c +++ b/libopkg/pkg_hash.c @@ -140,6 +140,7 @@ int pkg_hash_add_from_file(opkg_conf_t *conf, const char *file_name, } hash_insert_pkg(hash, pkg, is_status_file,conf); } else { + pkg_deinit (pkg); free(pkg); } } -- cgit v0.9.1