mirror of
https://github.com/moparisthebest/pacman
synced 2025-01-10 13:28:12 -05:00
Add a new reason field to pmconflict_t struct
Sometimes "foo conflicts with bar" information is not enough, see this thread: http://bbs.archlinux.org/viewtopic.php?id=77647. That's why I added a new reason field to our pmconflict_t struct that stores the packager- defined conflict that induced the fact that package1 conflicts with package2. I modified the front-end (in callback.c, sync.c, upgrade.c) to print this new information as well. Signed-off-by: Nagy Gabor <ngaba@bibl.u-szeged.hu>
This commit is contained in:
parent
902dfe5900
commit
12b55958d8
@ -442,6 +442,7 @@ alpm_list_t *alpm_checkconflicts(alpm_list_t *pkglist);
|
|||||||
|
|
||||||
const char *alpm_conflict_get_package1(pmconflict_t *conflict);
|
const char *alpm_conflict_get_package1(pmconflict_t *conflict);
|
||||||
const char *alpm_conflict_get_package2(pmconflict_t *conflict);
|
const char *alpm_conflict_get_package2(pmconflict_t *conflict);
|
||||||
|
const char *alpm_conflict_get_reason(pmconflict_t *conflict);
|
||||||
|
|
||||||
pmdepmod_t alpm_dep_get_mod(const pmdepend_t *dep);
|
pmdepmod_t alpm_dep_get_mod(const pmdepend_t *dep);
|
||||||
const char *alpm_dep_get_name(const pmdepend_t *dep);
|
const char *alpm_dep_get_name(const pmdepend_t *dep);
|
||||||
|
@ -41,7 +41,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "deps.h"
|
#include "deps.h"
|
||||||
|
|
||||||
pmconflict_t *_alpm_conflict_new(const char *package1, const char *package2)
|
pmconflict_t *_alpm_conflict_new(const char *package1, const char *package2, const char *reason)
|
||||||
{
|
{
|
||||||
pmconflict_t *conflict;
|
pmconflict_t *conflict;
|
||||||
|
|
||||||
@ -51,6 +51,7 @@ pmconflict_t *_alpm_conflict_new(const char *package1, const char *package2)
|
|||||||
|
|
||||||
STRDUP(conflict->package1, package1, RET_ERR(PM_ERR_MEMORY, NULL));
|
STRDUP(conflict->package1, package1, RET_ERR(PM_ERR_MEMORY, NULL));
|
||||||
STRDUP(conflict->package2, package2, RET_ERR(PM_ERR_MEMORY, NULL));
|
STRDUP(conflict->package2, package2, RET_ERR(PM_ERR_MEMORY, NULL));
|
||||||
|
STRDUP(conflict->reason, reason, RET_ERR(PM_ERR_MEMORY, NULL));
|
||||||
|
|
||||||
return(conflict);
|
return(conflict);
|
||||||
}
|
}
|
||||||
@ -59,6 +60,7 @@ void _alpm_conflict_free(pmconflict_t *conflict)
|
|||||||
{
|
{
|
||||||
FREE(conflict->package2);
|
FREE(conflict->package2);
|
||||||
FREE(conflict->package1);
|
FREE(conflict->package1);
|
||||||
|
FREE(conflict->reason);
|
||||||
FREE(conflict);
|
FREE(conflict);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -69,6 +71,7 @@ pmconflict_t *_alpm_conflict_dup(const pmconflict_t *conflict)
|
|||||||
|
|
||||||
STRDUP(newconflict->package1, conflict->package1, RET_ERR(PM_ERR_MEMORY, NULL));
|
STRDUP(newconflict->package1, conflict->package1, RET_ERR(PM_ERR_MEMORY, NULL));
|
||||||
STRDUP(newconflict->package2, conflict->package2, RET_ERR(PM_ERR_MEMORY, NULL));
|
STRDUP(newconflict->package2, conflict->package2, RET_ERR(PM_ERR_MEMORY, NULL));
|
||||||
|
STRDUP(newconflict->reason, conflict->reason, RET_ERR(PM_ERR_MEMORY, NULL));
|
||||||
|
|
||||||
return(newconflict);
|
return(newconflict);
|
||||||
}
|
}
|
||||||
@ -122,9 +125,9 @@ static int does_conflict(pmpkg_t *pkg1, const char *conflict, pmpkg_t *pkg2)
|
|||||||
* @param pkg2 package causing conflict
|
* @param pkg2 package causing conflict
|
||||||
*/
|
*/
|
||||||
static void add_conflict(alpm_list_t **baddeps, const char *pkg1,
|
static void add_conflict(alpm_list_t **baddeps, const char *pkg1,
|
||||||
const char *pkg2)
|
const char *pkg2, const char *reason)
|
||||||
{
|
{
|
||||||
pmconflict_t *conflict = _alpm_conflict_new(pkg1, pkg2);
|
pmconflict_t *conflict = _alpm_conflict_new(pkg1, pkg2, reason);
|
||||||
if(conflict && !_alpm_conflict_isin(conflict, *baddeps)) {
|
if(conflict && !_alpm_conflict_isin(conflict, *baddeps)) {
|
||||||
*baddeps = alpm_list_add(*baddeps, conflict);
|
*baddeps = alpm_list_add(*baddeps, conflict);
|
||||||
} else {
|
} else {
|
||||||
@ -168,9 +171,9 @@ static void check_conflict(alpm_list_t *list1, alpm_list_t *list2,
|
|||||||
|
|
||||||
if(does_conflict(pkg1, conflict, pkg2)) {
|
if(does_conflict(pkg1, conflict, pkg2)) {
|
||||||
if(order >= 0) {
|
if(order >= 0) {
|
||||||
add_conflict(baddeps, pkg1name, pkg2name);
|
add_conflict(baddeps, pkg1name, pkg2name, conflict);
|
||||||
} else {
|
} else {
|
||||||
add_conflict(baddeps, pkg2name, pkg1name);
|
add_conflict(baddeps, pkg2name, pkg1name, conflict);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -578,6 +581,17 @@ const char SYMEXPORT *alpm_conflict_get_package2(pmconflict_t *conflict)
|
|||||||
return conflict->package2;
|
return conflict->package2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char SYMEXPORT *alpm_conflict_get_reason(pmconflict_t *conflict)
|
||||||
|
{
|
||||||
|
ALPM_LOG_FUNC;
|
||||||
|
|
||||||
|
/* Sanity checks */
|
||||||
|
ASSERT(handle != NULL, return(NULL));
|
||||||
|
ASSERT(conflict != NULL, return(NULL));
|
||||||
|
|
||||||
|
return conflict->reason;
|
||||||
|
}
|
||||||
|
|
||||||
const char SYMEXPORT *alpm_fileconflict_get_target(pmfileconflict_t *conflict)
|
const char SYMEXPORT *alpm_fileconflict_get_target(pmfileconflict_t *conflict)
|
||||||
{
|
{
|
||||||
ALPM_LOG_FUNC;
|
ALPM_LOG_FUNC;
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
struct __pmconflict_t {
|
struct __pmconflict_t {
|
||||||
char *package1;
|
char *package1;
|
||||||
char *package2;
|
char *package2;
|
||||||
|
char *reason;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct __pmfileconflict_t {
|
struct __pmfileconflict_t {
|
||||||
@ -36,7 +37,7 @@ struct __pmfileconflict_t {
|
|||||||
char *ctarget;
|
char *ctarget;
|
||||||
};
|
};
|
||||||
|
|
||||||
pmconflict_t *_alpm_conflict_new(const char *package1, const char *package2);
|
pmconflict_t *_alpm_conflict_new(const char *package1, const char *package2, const char *reason);
|
||||||
pmconflict_t *_alpm_conflict_dup(const pmconflict_t *conflict);
|
pmconflict_t *_alpm_conflict_dup(const pmconflict_t *conflict);
|
||||||
void _alpm_conflict_free(pmconflict_t *conflict);
|
void _alpm_conflict_free(pmconflict_t *conflict);
|
||||||
int _alpm_conflict_isin(pmconflict_t *needle, alpm_list_t *haystack);
|
int _alpm_conflict_isin(pmconflict_t *needle, alpm_list_t *haystack);
|
||||||
|
@ -504,7 +504,7 @@ int _alpm_sync_prepare(pmtrans_t *trans, pmdb_t *db_local, alpm_list_t *dbs_sync
|
|||||||
pmpkg_t *local = _alpm_db_get_pkgfromcache(db_local, conflict->package2);
|
pmpkg_t *local = _alpm_db_get_pkgfromcache(db_local, conflict->package2);
|
||||||
int doremove = 0;
|
int doremove = 0;
|
||||||
QUESTION(trans, PM_TRANS_CONV_CONFLICT_PKG, conflict->package1,
|
QUESTION(trans, PM_TRANS_CONV_CONFLICT_PKG, conflict->package1,
|
||||||
conflict->package2, NULL, &doremove);
|
conflict->package2, conflict->reason, &doremove);
|
||||||
if(doremove) {
|
if(doremove) {
|
||||||
/* append to the removes list */
|
/* append to the removes list */
|
||||||
_alpm_log(PM_LOG_DEBUG, "electing '%s' for removal\n", conflict->package2);
|
_alpm_log(PM_LOG_DEBUG, "electing '%s' for removal\n", conflict->package2);
|
||||||
|
@ -259,10 +259,20 @@ void cb_trans_conv(pmtransconv_t event, void *data1, void *data2,
|
|||||||
alpm_pkg_get_name(data2));
|
alpm_pkg_get_name(data2));
|
||||||
break;
|
break;
|
||||||
case PM_TRANS_CONV_CONFLICT_PKG:
|
case PM_TRANS_CONV_CONFLICT_PKG:
|
||||||
*response = yesno(_(":: %s conflicts with %s. Remove %s?"),
|
/* data parameters: target package, local package, conflict (strings) */
|
||||||
|
/* print conflict only if it contains new information */
|
||||||
|
if(!strcmp(data1, data3) || !strcmp(data2, data3)) {
|
||||||
|
*response = yesno(_(":: %s and %s are in conflict. Remove %s?"),
|
||||||
(char *)data1,
|
(char *)data1,
|
||||||
(char *)data2,
|
(char *)data2,
|
||||||
(char *)data2);
|
(char *)data2);
|
||||||
|
} else {
|
||||||
|
*response = yesno(_(":: %s and %s are in conflict (%s). Remove %s?"),
|
||||||
|
(char *)data1,
|
||||||
|
(char *)data2,
|
||||||
|
(char *)data3,
|
||||||
|
(char *)data2);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case PM_TRANS_CONV_REMOVE_PKGS:
|
case PM_TRANS_CONV_REMOVE_PKGS:
|
||||||
{
|
{
|
||||||
|
@ -665,8 +665,15 @@ static int sync_trans(alpm_list_t *targets)
|
|||||||
case PM_ERR_CONFLICTING_DEPS:
|
case PM_ERR_CONFLICTING_DEPS:
|
||||||
for(i = data; i; i = alpm_list_next(i)) {
|
for(i = data; i; i = alpm_list_next(i)) {
|
||||||
pmconflict_t *conflict = alpm_list_getdata(i);
|
pmconflict_t *conflict = alpm_list_getdata(i);
|
||||||
printf(_(":: %s: conflicts with %s\n"),
|
const char *package1 = alpm_conflict_get_package1(conflict);
|
||||||
alpm_conflict_get_package1(conflict), alpm_conflict_get_package2(conflict));
|
const char *package2 = alpm_conflict_get_package2(conflict);
|
||||||
|
const char *reason = alpm_conflict_get_reason(conflict);
|
||||||
|
/* only print reason if it contains new information */
|
||||||
|
if(!strcmp(package1, reason) || !strcmp(package2, reason)) {
|
||||||
|
printf(_(":: %s and %s are in conflict\n"), package1, package2);
|
||||||
|
} else {
|
||||||
|
printf(_(":: %s and %s are in conflict (%s)\n"), package1, package2, reason);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -110,8 +110,15 @@ int pacman_upgrade(alpm_list_t *targets)
|
|||||||
case PM_ERR_CONFLICTING_DEPS:
|
case PM_ERR_CONFLICTING_DEPS:
|
||||||
for(i = data; i; i = alpm_list_next(i)) {
|
for(i = data; i; i = alpm_list_next(i)) {
|
||||||
pmconflict_t *conflict = alpm_list_getdata(i);
|
pmconflict_t *conflict = alpm_list_getdata(i);
|
||||||
printf(_(":: %s: conflicts with %s\n"),
|
const char *package1 = alpm_conflict_get_package1(conflict);
|
||||||
alpm_conflict_get_package1(conflict), alpm_conflict_get_package2(conflict));
|
const char *package2 = alpm_conflict_get_package2(conflict);
|
||||||
|
const char *reason = alpm_conflict_get_reason(conflict);
|
||||||
|
/* only print reason if it contains new information */
|
||||||
|
if(!strcmp(package1, reason) || !strcmp(package2, reason)) {
|
||||||
|
printf(_(":: %s and %s are in conflict\n"), package1, package2);
|
||||||
|
} else {
|
||||||
|
printf(_(":: %s and %s are in conflict (%s)\n"), package1, package2, reason);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case PM_ERR_FILE_CONFLICTS:
|
case PM_ERR_FILE_CONFLICTS:
|
||||||
|
Loading…
Reference in New Issue
Block a user