solver: add more dbg_printfs
parent
edb45ae464
commit
f3cf824948
81
src/solver.c
81
src/solver.c
|
@ -511,8 +511,10 @@ static int compare_providers(struct apk_solver_state *ss,
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
/* Prefer existing package */
|
/* Prefer existing package */
|
||||||
if (pkgA == NULL || pkgB == NULL)
|
if (pkgA == NULL || pkgB == NULL) {
|
||||||
|
dbg_printf(" prefer existing package\n");
|
||||||
return (pkgA != NULL) - (pkgB != NULL);
|
return (pkgA != NULL) - (pkgB != NULL);
|
||||||
|
}
|
||||||
|
|
||||||
/* Latest version required? */
|
/* Latest version required? */
|
||||||
solver_flags = pkgA->ss.solver_flags | pkgB->ss.solver_flags;
|
solver_flags = pkgA->ss.solver_flags | pkgB->ss.solver_flags;
|
||||||
|
@ -521,77 +523,103 @@ static int compare_providers(struct apk_solver_state *ss,
|
||||||
(pkgB->ss.pinning_allowed == APK_DEFAULT_PINNING_MASK)) {
|
(pkgB->ss.pinning_allowed == APK_DEFAULT_PINNING_MASK)) {
|
||||||
/* Prefer allowed pinning */
|
/* Prefer allowed pinning */
|
||||||
r = (int)pkgA->ss.tag_ok - (int)pkgB->ss.tag_ok;
|
r = (int)pkgA->ss.tag_ok - (int)pkgB->ss.tag_ok;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer allowed pinning\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer available */
|
/* Prefer available */
|
||||||
if (solver_flags & APK_SOLVERF_AVAILABLE) {
|
if (solver_flags & APK_SOLVERF_AVAILABLE) {
|
||||||
r = (int)pkgA->ss.pkg_available - (int)pkgB->ss.pkg_available;
|
r = (int)pkgA->ss.pkg_available - (int)pkgB->ss.pkg_available;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer available\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
} else if (solver_flags & APK_SOLVERF_REINSTALL) {
|
} else if (solver_flags & APK_SOLVERF_REINSTALL) {
|
||||||
r = (int)pkgA->ss.pkg_selectable - (int)pkgB->ss.pkg_selectable;
|
r = (int)pkgA->ss.pkg_selectable - (int)pkgB->ss.pkg_selectable;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer available (reinstall)\n");
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
/* Prefer without errors */
|
/* Prefer without errors */
|
||||||
r = (int)pkgA->ss.pkg_selectable - (int)pkgB->ss.pkg_selectable;
|
r = (int)pkgA->ss.pkg_selectable - (int)pkgB->ss.pkg_selectable;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer without errors\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer those that were in last dependency merging group */
|
/* Prefer those that were in last dependency merging group */
|
||||||
r = (int)pkgA->ss.dependencies_used - (int)pkgB->ss.dependencies_used;
|
r = (int)pkgA->ss.dependencies_used - (int)pkgB->ss.dependencies_used;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer those that were in last dependency merging group\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
r = pkgB->ss.conflicts - pkgA->ss.conflicts;
|
r = pkgB->ss.conflicts - pkgA->ss.conflicts;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer those that were in last dependency merging group (#2)\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer installed on self-upgrade */
|
/* Prefer installed on self-upgrade */
|
||||||
if ((db->performing_self_upgrade && !(solver_flags & APK_SOLVERF_UPGRADE)) ||
|
if ((db->performing_self_upgrade && !(solver_flags & APK_SOLVERF_UPGRADE)) ||
|
||||||
(solver_flags & APK_SOLVERF_IGNORE_UPGRADE)) {
|
(solver_flags & APK_SOLVERF_IGNORE_UPGRADE)) {
|
||||||
r = (pkgA->ipkg != NULL) - (pkgB->ipkg != NULL);
|
r = (pkgA->ipkg != NULL) - (pkgB->ipkg != NULL);
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer installed on self-upgrade\n");
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer allowed pinning */
|
/* Prefer allowed pinning */
|
||||||
r = (int)pkgA->ss.tag_ok - (int)pkgB->ss.tag_ok;
|
r = (int)pkgA->ss.tag_ok - (int)pkgB->ss.tag_ok;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer allowed pinning\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer available */
|
/* Prefer available */
|
||||||
if (solver_flags & APK_SOLVERF_AVAILABLE) {
|
if (solver_flags & APK_SOLVERF_AVAILABLE) {
|
||||||
r = (int)pkgA->ss.pkg_available - (int)pkgB->ss.pkg_available;
|
r = (int)pkgA->ss.pkg_available - (int)pkgB->ss.pkg_available;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer available\n");
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer preferred pinning */
|
/* Prefer preferred pinning */
|
||||||
r = (int)pkgA->ss.tag_preferred - (int)pkgB->ss.tag_preferred;
|
r = (int)pkgA->ss.tag_preferred - (int)pkgB->ss.tag_preferred;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer preferred pinning\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer highest requirer count. */
|
/* Prefer highest requirer count. */
|
||||||
r = count_requirers(pkgA) - count_requirers(pkgB);
|
r = count_requirers(pkgA) - count_requirers(pkgB);
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer highest requirer count\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer installed */
|
/* Prefer installed */
|
||||||
if (!(solver_flags & APK_SOLVERF_UPGRADE) ||
|
if (!(solver_flags & APK_SOLVERF_UPGRADE) ||
|
||||||
(solver_flags & APK_SOLVERF_IGNORE_UPGRADE)) {
|
(solver_flags & APK_SOLVERF_IGNORE_UPGRADE)) {
|
||||||
r = (pkgA->ipkg != NULL) - (pkgB->ipkg != NULL);
|
r = (pkgA->ipkg != NULL) - (pkgB->ipkg != NULL);
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer installed\n");
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Select latest by requested name */
|
/* Select latest by requested name */
|
||||||
switch (apk_version_compare_blob(*pA->version, *pB->version)) {
|
switch (apk_version_compare_blob(*pA->version, *pB->version)) {
|
||||||
case APK_VERSION_LESS:
|
case APK_VERSION_LESS:
|
||||||
|
dbg_printf(" select latest by requested name (less)\n");
|
||||||
return -1;
|
return -1;
|
||||||
case APK_VERSION_GREATER:
|
case APK_VERSION_GREATER:
|
||||||
|
dbg_printf(" select latest by requested name (greater)\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -599,28 +627,37 @@ static int compare_providers(struct apk_solver_state *ss,
|
||||||
if (pkgA->name == pkgB->name) {
|
if (pkgA->name == pkgB->name) {
|
||||||
switch (apk_version_compare_blob(*pkgA->version, *pkgB->version)) {
|
switch (apk_version_compare_blob(*pkgA->version, *pkgB->version)) {
|
||||||
case APK_VERSION_LESS:
|
case APK_VERSION_LESS:
|
||||||
|
dbg_printf(" select latest by principal name (less)\n");
|
||||||
return -1;
|
return -1;
|
||||||
case APK_VERSION_GREATER:
|
case APK_VERSION_GREATER:
|
||||||
|
dbg_printf(" select latest by principal name (greater)\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Prefer installed (matches here if upgrading) */
|
/* Prefer installed (matches here if upgrading) */
|
||||||
r = (pkgA->ipkg != NULL) - (pkgB->ipkg != NULL);
|
r = (pkgA->ipkg != NULL) - (pkgB->ipkg != NULL);
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer installed (upgrading)\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer highest declared provider priority. */
|
/* Prefer highest declared provider priority. */
|
||||||
r = pkgA->provider_priority - pkgB->provider_priority;
|
r = pkgA->provider_priority - pkgB->provider_priority;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer highest declared provider priority\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer without errors (mostly if --latest used, and different provider) */
|
/* Prefer without errors (mostly if --latest used, and different provider) */
|
||||||
r = (int)pkgA->ss.pkg_selectable - (int)pkgB->ss.pkg_selectable;
|
r = (int)pkgA->ss.pkg_selectable - (int)pkgB->ss.pkg_selectable;
|
||||||
if (r)
|
if (r) {
|
||||||
|
dbg_printf(" prefer without errors (#2)\n");
|
||||||
return r;
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
/* Prefer lowest available repository */
|
/* Prefer lowest available repository */
|
||||||
|
dbg_printf(" prefer lowest available repository\n");
|
||||||
return ffs(pkgB->repos) - ffs(pkgA->repos);
|
return ffs(pkgB->repos) - ffs(pkgA->repos);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -685,19 +722,25 @@ static void select_package(struct apk_solver_state *ss, struct apk_name *name)
|
||||||
/* Ensure valid pinning and install-if trigger */
|
/* Ensure valid pinning and install-if trigger */
|
||||||
if (name->ss.requirers == 0 &&
|
if (name->ss.requirers == 0 &&
|
||||||
(!p->pkg->ss.iif_triggered ||
|
(!p->pkg->ss.iif_triggered ||
|
||||||
!p->pkg->ss.tag_ok))
|
!p->pkg->ss.tag_ok)) {
|
||||||
|
dbg_printf(" ignore: invalid install-if trigger or invalid pinning\n");
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
/* Virtual packages without provider_priority cannot be autoselected,
|
/* Virtual packages without provider_priority cannot be autoselected,
|
||||||
* unless there is only one provider */
|
* unless there is only one provider */
|
||||||
if (p->version == &apk_atom_null &&
|
if (p->version == &apk_atom_null &&
|
||||||
p->pkg->name->auto_select_virtual == 0 &&
|
p->pkg->name->auto_select_virtual == 0 &&
|
||||||
p->pkg->name->ss.requirers == 0 &&
|
p->pkg->name->ss.requirers == 0 &&
|
||||||
(p->pkg->provider_priority == 0 && name->providers->num > 1))
|
(p->pkg->provider_priority == 0 && name->providers->num > 1)) {
|
||||||
|
dbg_printf(" ignore: virtual package without provider_priority with >1 provider\n");
|
||||||
continue;
|
continue;
|
||||||
if (compare_providers(ss, p, &chosen) > 0)
|
}
|
||||||
|
if (compare_providers(ss, p, &chosen) > 0) {
|
||||||
|
dbg_printf(" choose as new provider\n");
|
||||||
chosen = *p;
|
chosen = *p;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pkg = chosen.pkg;
|
pkg = chosen.pkg;
|
||||||
if (pkg) {
|
if (pkg) {
|
||||||
|
|
Loading…
Reference in New Issue