mirror of
https://github.com/moparisthebest/pacman
synced 2025-01-09 04:57:59 -05:00
New error type: PM_ERR_PKG_IGNORED
This patch fixes FS#12059. Now sync_addtarget can return with PM_ERR_PKG_IGNORED, which indicates that although the requested package was found it is in ignorepkg, so alpm could not add it to the transaction. So the front-end can decide what to do. Signed-off-by: Nagy Gabor <ngaba@bibl.u-szeged.hu> Signed-off-by: Dan McGee <dan@archlinux.org>
This commit is contained in:
parent
93ca155b48
commit
77efd51216
@ -493,6 +493,7 @@ enum _pmerrno_t {
|
|||||||
PM_ERR_TRANS_DOWNLOADING,
|
PM_ERR_TRANS_DOWNLOADING,
|
||||||
/* Packages */
|
/* Packages */
|
||||||
PM_ERR_PKG_NOT_FOUND,
|
PM_ERR_PKG_NOT_FOUND,
|
||||||
|
PM_ERR_PKG_IGNORED,
|
||||||
PM_ERR_PKG_INVALID,
|
PM_ERR_PKG_INVALID,
|
||||||
PM_ERR_PKG_OPEN,
|
PM_ERR_PKG_OPEN,
|
||||||
PM_ERR_PKG_LOAD,
|
PM_ERR_PKG_LOAD,
|
||||||
|
@ -520,6 +520,7 @@ pmpkg_t *_alpm_resolvedep(pmdepend_t *dep, alpm_list_t *dbs,
|
|||||||
alpm_list_t *excluding, int prompt)
|
alpm_list_t *excluding, int prompt)
|
||||||
{
|
{
|
||||||
alpm_list_t *i, *j;
|
alpm_list_t *i, *j;
|
||||||
|
int ignored = 0;
|
||||||
/* 1. literals */
|
/* 1. literals */
|
||||||
for(i = dbs; i; i = i->next) {
|
for(i = dbs; i; i = i->next) {
|
||||||
pmpkg_t *pkg = _alpm_db_get_pkgfromcache(i->data, dep->name);
|
pmpkg_t *pkg = _alpm_db_get_pkgfromcache(i->data, dep->name);
|
||||||
@ -531,6 +532,7 @@ pmpkg_t *_alpm_resolvedep(pmdepend_t *dep, alpm_list_t *dbs,
|
|||||||
NULL, NULL, &install);
|
NULL, NULL, &install);
|
||||||
}
|
}
|
||||||
if(!install) {
|
if(!install) {
|
||||||
|
ignored = 1;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -550,6 +552,7 @@ pmpkg_t *_alpm_resolvedep(pmdepend_t *dep, alpm_list_t *dbs,
|
|||||||
pkg, NULL, NULL, &install);
|
pkg, NULL, NULL, &install);
|
||||||
}
|
}
|
||||||
if(!install) {
|
if(!install) {
|
||||||
|
ignored = 1;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -559,6 +562,11 @@ pmpkg_t *_alpm_resolvedep(pmdepend_t *dep, alpm_list_t *dbs,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(ignored) { /* resolvedeps will override these */
|
||||||
|
pm_errno = PM_ERR_PKG_IGNORED;
|
||||||
|
} else {
|
||||||
|
pm_errno = PM_ERR_PKG_NOT_FOUND;
|
||||||
|
}
|
||||||
return(NULL);
|
return(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -640,7 +648,7 @@ int _alpm_resolvedeps(pmdb_t *local, alpm_list_t *dbs_sync, pmpkg_t *pkg,
|
|||||||
alpm_list_free_inner(deps, (alpm_list_fn_free)_alpm_depmiss_free);
|
alpm_list_free_inner(deps, (alpm_list_fn_free)_alpm_depmiss_free);
|
||||||
alpm_list_free(deps);
|
alpm_list_free(deps);
|
||||||
return(-1);
|
return(-1);
|
||||||
} else {
|
} else {
|
||||||
_alpm_log(PM_LOG_DEBUG, "pulling dependency %s (needed by %s)\n",
|
_alpm_log(PM_LOG_DEBUG, "pulling dependency %s (needed by %s)\n",
|
||||||
alpm_pkg_get_name(spkg), alpm_pkg_get_name(tpkg));
|
alpm_pkg_get_name(spkg), alpm_pkg_get_name(tpkg));
|
||||||
*packages = alpm_list_add(*packages, spkg);
|
*packages = alpm_list_add(*packages, spkg);
|
||||||
|
@ -106,6 +106,8 @@ const char SYMEXPORT *alpm_strerror(int err)
|
|||||||
/* Packages */
|
/* Packages */
|
||||||
case PM_ERR_PKG_NOT_FOUND:
|
case PM_ERR_PKG_NOT_FOUND:
|
||||||
return _("could not find or read package");
|
return _("could not find or read package");
|
||||||
|
case PM_ERR_PKG_IGNORED:
|
||||||
|
return _("operation cancelled due to ignorepkg");
|
||||||
case PM_ERR_PKG_INVALID:
|
case PM_ERR_PKG_INVALID:
|
||||||
return _("invalid or corrupted package");
|
return _("invalid or corrupted package");
|
||||||
case PM_ERR_PKG_OPEN:
|
case PM_ERR_PKG_OPEN:
|
||||||
|
@ -297,7 +297,8 @@ int _alpm_sync_addtarget(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sy
|
|||||||
FREE(targline);
|
FREE(targline);
|
||||||
|
|
||||||
if(spkg == NULL) {
|
if(spkg == NULL) {
|
||||||
RET_ERR(PM_ERR_PKG_NOT_FOUND, -1);
|
/* pm_errno is set by _alpm_resolvedep */
|
||||||
|
return(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(_alpm_sync_find(trans->packages, alpm_pkg_get_name(spkg))) {
|
if(_alpm_sync_find(trans->packages, alpm_pkg_get_name(spkg))) {
|
||||||
|
@ -574,11 +574,12 @@ static int sync_trans(alpm_list_t *targets)
|
|||||||
char *targ = alpm_list_getdata(i);
|
char *targ = alpm_list_getdata(i);
|
||||||
if(alpm_trans_addtarget(targ) == -1) {
|
if(alpm_trans_addtarget(targ) == -1) {
|
||||||
pmgrp_t *grp = NULL;
|
pmgrp_t *grp = NULL;
|
||||||
int found=0;
|
int found = 0;
|
||||||
alpm_list_t *j;
|
alpm_list_t *j;
|
||||||
|
|
||||||
if(pm_errno == PM_ERR_TRANS_DUP_TARGET) {
|
if(pm_errno == PM_ERR_TRANS_DUP_TARGET || pm_errno == PM_ERR_PKG_IGNORED) {
|
||||||
/* just ignore duplicate targets */
|
/* just skip duplicate or ignored targets */
|
||||||
|
pm_printf(PM_LOG_WARNING, _("skipping target: %s\n"), targ);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if(pm_errno != PM_ERR_PKG_NOT_FOUND) {
|
if(pm_errno != PM_ERR_PKG_NOT_FOUND) {
|
||||||
|
Loading…
Reference in New Issue
Block a user