solver: add more dbg_printfs

cute-signatures
Oliver Smith 2020-08-18 23:15:26 +02:00 committed by Timo Teräs
parent edb45ae464
commit f3cf824948
1 changed files with 62 additions and 19 deletions

View File

@ -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) {