From 1dbbd2fe3474858668b4b1242a386649ad349061 Mon Sep 17 00:00:00 2001 From: Glenn L McGrath Date: Wed, 5 Dec 2001 04:10:14 +0000 Subject: Fail gracefully if package depends on a virtual package. --- archival/dpkg.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'archival') diff --git a/archival/dpkg.c b/archival/dpkg.c index 9a3bff9..9a95eb4 100644 --- a/archival/dpkg.c +++ b/archival/dpkg.c @@ -989,10 +989,14 @@ int check_deps(deb_file_t **deb_file, int deb_start, int dep_max_count) for (j = 0; j < package_hashtable[deb_file[i]->package]->num_of_edges; j++) { const edge_t *package_edge = package_node->edge[j]; - const unsigned int package_num = search_package_hashtable(package_edge->name, - package_edge->version, package_edge->operator); + unsigned int package_num; + package_num = search_package_hashtable(package_edge->name, package_edge->version, package_edge->operator); + if (package_hashtable[package_num] == NULL) { + error_msg_and_die("Dependency checking failed for package %s\nNOTE: This may be due to busybox dpkg's inability to handle the Provides field, you may avoid dependency checking using the -F option ", name_hashtable[package_edge->name]); + } status_num = search_status_hashtable(name_hashtable[package_hashtable[package_num]->name]); + state_status = get_status(status_num, 3); state_want = get_status(status_num, 1); switch (package_edge->type) { -- cgit v1.1