summaryrefslogtreecommitdiff
path: root/src/commit.c
diff options
context:
space:
mode:
authorTimo Teräs <timo.teras@iki.fi>2020-10-05 16:47:24 +0300
committerTimo Teräs <timo.teras@iki.fi>2020-10-09 16:09:19 +0300
commit7a7eca86709fcf31dbb1acf8b82ff411828fb67b (patch)
treeeb737b2604480caa4140f53b106e2cb361678e4d /src/commit.c
parent9afb4e8fd117d7d130e5b4b75869765ecfbe2fa7 (diff)
downloadapk-tools-7a7eca86709fcf31dbb1acf8b82ff411828fb67b.tar.gz
apk-tools-7a7eca86709fcf31dbb1acf8b82ff411828fb67b.tar.bz2
apk-tools-7a7eca86709fcf31dbb1acf8b82ff411828fb67b.tar.xz
apk-tools-7a7eca86709fcf31dbb1acf8b82ff411828fb67b.zip
make apk_flags non-global, make progress printing state non-global
ref #10682
Diffstat (limited to 'src/commit.c')
-rw-r--r--src/commit.c23
1 files changed, 12 insertions, 11 deletions
diff --git a/src/commit.c b/src/commit.c
index fe9b1ad..6cc60b7 100644
--- a/src/commit.c
+++ b/src/commit.c
@@ -112,6 +112,7 @@ static void count_change(struct apk_change *change, struct apk_stats *stats)
}
struct progress {
+ struct apk_progress prog;
struct apk_stats done;
struct apk_stats total;
struct apk_package *pkg;
@@ -120,7 +121,8 @@ struct progress {
static void progress_cb(void *ctx, size_t installed_bytes)
{
struct progress *prog = (struct progress *) ctx;
- apk_print_progress(prog->done.bytes + prog->done.packages + installed_bytes,
+ apk_print_progress(&prog->prog,
+ prog->done.bytes + prog->done.packages + installed_bytes,
prog->total.bytes + prog->total.packages);
}
@@ -232,10 +234,10 @@ static int run_commit_hook(void *ctx, int dirfd, const char *file)
char fn[PATH_MAX], *argv[] = { fn, (char *) commit_hook_str[hook->type], NULL };
if (file[0] == '.') return 0;
- if ((apk_flags & (APK_NO_SCRIPTS | APK_SIMULATE)) != 0) return 0;
+ if ((db->flags & (APK_NO_SCRIPTS | APK_SIMULATE)) != 0) return 0;
snprintf(fn, sizeof(fn), "etc/apk/commit_hooks.d" "/%s", file);
- if ((apk_flags & APK_NO_COMMIT_HOOKS) != 0) {
+ if ((db->flags & APK_NO_COMMIT_HOOKS) != 0) {
apk_message("Skipping: %s %s", fn, commit_hook_str[hook->type]);
return 0;
}
@@ -258,7 +260,7 @@ int apk_solver_commit_changeset(struct apk_database *db,
struct apk_changeset *changeset,
struct apk_dependency_array *world)
{
- struct progress prog;
+ struct progress prog = { .prog = db->progress };
struct apk_change *change;
char buf[32];
const char *size_unit;
@@ -276,7 +278,6 @@ int apk_solver_commit_changeset(struct apk_database *db,
goto all_done;
/* Count what needs to be done */
- memset(&prog, 0, sizeof(prog));
foreach_array_item(change, changeset->changes) {
count_change(change, &prog.total);
if (change->new_pkg)
@@ -286,13 +287,13 @@ int apk_solver_commit_changeset(struct apk_database *db,
}
size_unit = apk_get_human_size(llabs(size_diff), &humanized);
- if ((apk_verbosity > 1 || (apk_flags & APK_INTERACTIVE)) &&
- !(apk_flags & APK_SIMULATE)) {
+ if ((apk_verbosity > 1 || (db->flags & APK_INTERACTIVE)) &&
+ !(db->flags & APK_SIMULATE)) {
r = dump_packages(changeset, cmp_remove,
"The following packages will be REMOVED");
r += dump_packages(changeset, cmp_downgrade,
"The following packages will be DOWNGRADED");
- if (r || (apk_flags & APK_INTERACTIVE) || apk_verbosity > 2) {
+ if (r || (db->flags & APK_INTERACTIVE) || apk_verbosity > 2) {
r += dump_packages(changeset, cmp_new,
"The following NEW packages will be installed");
r += dump_packages(changeset, cmp_upgrade,
@@ -306,7 +307,7 @@ int apk_solver_commit_changeset(struct apk_database *db,
"disk space will be freed" :
"additional disk space will be used");
}
- if (r > 0 && (apk_flags & APK_INTERACTIVE)) {
+ if (r > 0 && (db->flags & APK_INTERACTIVE)) {
printf("Do you want to continue [Y/n]? ");
fflush(stdout);
r = fgetc(stdin);
@@ -327,7 +328,7 @@ int apk_solver_commit_changeset(struct apk_database *db,
prog.pkg = change->new_pkg;
progress_cb(&prog, 0);
- if (!(apk_flags & APK_SIMULATE) &&
+ if (!(db->flags & APK_SIMULATE) &&
((change->old_pkg != change->new_pkg) ||
(change->reinstall && pkg_available(db, change->new_pkg)))) {
r = apk_db_install_pkg(db, change->old_pkg, change->new_pkg,
@@ -339,7 +340,7 @@ int apk_solver_commit_changeset(struct apk_database *db,
errors += r;
count_change(change, &prog.done);
}
- apk_print_progress(prog.total.bytes + prog.total.packages,
+ apk_print_progress(&prog.prog, prog.total.bytes + prog.total.packages,
prog.total.bytes + prog.total.packages);
apk_db_update_directory_permissions(db);