diff options
author | Timo Teräs <timo.teras@iki.fi> | 2017-02-27 14:56:06 +0200 |
---|---|---|
committer | Timo Teräs <timo.teras@iki.fi> | 2017-02-27 14:56:57 +0200 |
commit | 0fe3f3964b8b5accc1e79f5f8a7d848e8fc2cba8 (patch) | |
tree | f2ad11a8a6e5cef36d53745f780600a7d738b0cd | |
parent | 6542d4ca2c69c7275ce8fc4fe6df185595a97ed6 (diff) | |
download | apk-tools-0fe3f3964b8b5accc1e79f5f8a7d848e8fc2cba8.tar.gz apk-tools-0fe3f3964b8b5accc1e79f5f8a7d848e8fc2cba8.tar.bz2 apk-tools-0fe3f3964b8b5accc1e79f5f8a7d848e8fc2cba8.tar.xz apk-tools-0fe3f3964b8b5accc1e79f5f8a7d848e8fc2cba8.zip |
fetch: fix --recursive mode to work with pure virtual packages
The virtual package provider still needs to be explicitly
given on command line.
-rw-r--r-- | src/apk_database.h | 1 | ||||
-rw-r--r-- | src/fetch.c | 13 | ||||
-rw-r--r-- | src/solver.c | 4 |
3 files changed, 16 insertions, 2 deletions
diff --git a/src/apk_database.h b/src/apk_database.h index 80d7432..610595f 100644 --- a/src/apk_database.h +++ b/src/apk_database.h @@ -100,6 +100,7 @@ struct apk_name { struct apk_name_array *rdepends; struct apk_name_array *rinstall_if; unsigned is_dependency : 1; + unsigned auto_select_virtual: 1; unsigned int foreach_genid; union { struct apk_solver_name_state ss; diff --git a/src/fetch.c b/src/fetch.c index bc63983..48848af 100644 --- a/src/fetch.c +++ b/src/fetch.c @@ -216,6 +216,11 @@ static void mark_error(struct fetch_ctx *ctx, const char *match, struct apk_name ctx->errors++; } +static void mark_name_flags(struct apk_database *db, const char *match, struct apk_name *name, void *ctx) +{ + name->auto_select_virtual = 1; +} + static void mark_name_recursive(struct apk_database *db, const char *match, struct apk_name *name, void *ctx) { struct apk_changeset changeset = {}; @@ -299,7 +304,7 @@ static int purge_package(void *pctx, int dirfd, const char *filename) static int fetch_main(void *pctx, struct apk_database *db, struct apk_string_array *args) { struct fetch_ctx *ctx = (struct fetch_ctx *) pctx; - void *mark = (ctx->flags & FETCH_RECURSIVE) ? mark_name_recursive : mark_name; + void *mark; if (ctx->flags & FETCH_STDOUT) { apk_flags &= ~APK_PROGRESS; @@ -318,6 +323,12 @@ static int fetch_main(void *pctx, struct apk_database *db, struct apk_string_arr ctx->db = db; + if (ctx->flags & FETCH_RECURSIVE) { + apk_name_foreach_matching(db, args, apk_foreach_genid(), mark_name_flags, ctx); + mark = mark_name_recursive; + } else { + mark = mark_name; + } apk_name_foreach_matching(db, args, apk_foreach_genid(), mark, ctx); if (!ctx->errors) apk_hash_foreach(&db->available.packages, fetch_package, ctx); diff --git a/src/solver.c b/src/solver.c index f41dffd..248fa27 100644 --- a/src/solver.c +++ b/src/solver.c @@ -640,7 +640,9 @@ static void select_package(struct apk_solver_state *ss, struct apk_name *name) !p->pkg->ss.tag_ok)) continue; /* Virtual packages cannot be autoselected */ - if (p->version == &apk_null_blob && p->pkg->name->ss.requirers == 0) + if (p->version == &apk_null_blob && + p->pkg->name->auto_select_virtual == 0 && + p->pkg->name->ss.requirers == 0) continue; if (compare_providers(ss, p, &chosen) > 0) chosen = *p; |