mirror of
https://github.com/moparisthebest/pacman
synced 2025-01-09 21:08:11 -05:00
Use alpm_depcmp in _alpm_pkg_update_requiredby
The old function did too much on its own; let alpm_depcmp do the hard work. This will allow for future versioned provisions if necessary. Signed-off-by: Dan McGee <dan@archlinux.org>
This commit is contained in:
parent
2bcecbd62c
commit
a3994f975b
@ -533,11 +533,11 @@ int _alpm_pkg_splitname(const char *target, char *name, char *version, int witha
|
|||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* scan the local db to fill in requiredby field of package,
|
||||||
|
* used when we want to install or add a package */
|
||||||
void _alpm_pkg_update_requiredby(pmpkg_t *pkg)
|
void _alpm_pkg_update_requiredby(pmpkg_t *pkg)
|
||||||
{
|
{
|
||||||
alpm_list_t *i, *j, *k;
|
alpm_list_t *i, *j;
|
||||||
const char *pkgname = alpm_pkg_get_name(pkg);
|
|
||||||
|
|
||||||
pmdb_t *localdb = alpm_option_get_localdb();
|
pmdb_t *localdb = alpm_option_get_localdb();
|
||||||
for(i = _alpm_db_get_pkgcache(localdb); i; i = i->next) {
|
for(i = _alpm_db_get_pkgcache(localdb); i; i = i->next) {
|
||||||
@ -549,6 +549,8 @@ void _alpm_pkg_update_requiredby(pmpkg_t *pkg)
|
|||||||
|
|
||||||
for(j = alpm_pkg_get_depends(cachepkg); j; j = j->next) {
|
for(j = alpm_pkg_get_depends(cachepkg); j; j = j->next) {
|
||||||
pmdepend_t *dep;
|
pmdepend_t *dep;
|
||||||
|
int satisfies;
|
||||||
|
|
||||||
if(!j->data) {
|
if(!j->data) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -557,33 +559,16 @@ void _alpm_pkg_update_requiredby(pmpkg_t *pkg)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check the actual package itself */
|
satisfies = alpm_depcmp(pkg, dep);
|
||||||
if(strcmp(dep->name, pkgname) == 0) {
|
|
||||||
alpm_list_t *reqs = alpm_pkg_get_requiredby(pkg);
|
|
||||||
|
|
||||||
if(!alpm_list_find_str(reqs, cachepkgname)) {
|
|
||||||
_alpm_log(PM_LOG_DEBUG, _("adding '%s' in requiredby field for '%s'"),
|
|
||||||
cachepkgname, pkg->name);
|
|
||||||
reqs = alpm_list_add(reqs, strdup(cachepkgname));
|
|
||||||
pkg->requiredby = reqs;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* check for provisions as well */
|
|
||||||
for(k = alpm_pkg_get_provides(pkg); k; k = k->next) {
|
|
||||||
const char *provname = k->data;
|
|
||||||
if(strcmp(dep->name, provname) == 0) {
|
|
||||||
alpm_list_t *reqs = alpm_pkg_get_requiredby(pkg);
|
|
||||||
|
|
||||||
if(!alpm_list_find_str(reqs, cachepkgname)) {
|
|
||||||
_alpm_log(PM_LOG_DEBUG, _("adding '%s' in requiredby field for '%s' (provides: %s)"),
|
|
||||||
cachepkgname, pkgname, provname);
|
|
||||||
reqs = alpm_list_add(reqs, strdup(cachepkgname));
|
|
||||||
pkg->requiredby = reqs;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
free(dep);
|
free(dep);
|
||||||
|
if(satisfies) {
|
||||||
|
alpm_list_t *reqs = alpm_pkg_get_requiredby(pkg);
|
||||||
|
_alpm_log(PM_LOG_DEBUG, _("adding '%s' in requiredby field for '%s'"),
|
||||||
|
cachepkgname, pkg->name);
|
||||||
|
reqs = alpm_list_add(reqs, strdup(cachepkgname));
|
||||||
|
pkg->requiredby = reqs;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user