From: Nathan Wagner Date: Mon, 3 Dec 2018 09:00:16 +0000 (+0000) Subject: improve syncfs output X-Git-Tag: v0.3.4~7 X-Git-Url: https://pd.if.org/git/?p=zpackage;a=commitdiff_plain;h=24b5f57f47823105a26f391c52131ec4c6374dce improve syncfs output --- diff --git a/zpm-syncfs.c b/zpm-syncfs.c index aac86b5..51b010e 100644 --- a/zpm-syncfs.c +++ b/zpm-syncfs.c @@ -32,6 +32,9 @@ struct config { int reverse, exitonerror; int overwrite, accept, acceptdir, ignoredirmd; int ops_total, ops_completed; + int ops_remove, ops_remove_completed; + int ops_update, ops_update_completed; + int ops_install, ops_install_completed; int progress; /* type of progress meter */ }; @@ -57,6 +60,18 @@ static void usage() { printf("usage: zpm $scriptname [-fncC] args ...\n"); } +static void pdots(int len, int ch, int was, int now, int total) { + was = len * was / total; + if (now > total) { + now = total; + } + now = len * now / total; + while (was++ < now) { + putchar(ch); + } + fflush(stdout); +} + static int seterror(struct config *conf, char *msgfmt, ...) { char msg[1024]; va_list ap; @@ -623,7 +638,17 @@ static int remove_files(void *f, int ncols, char **vals, char **cols) { /* TODO check that expected filetype matches actual filetype */ if (conf->verbose) { - fprintf(stderr, "%s(%s)\n", flags ? "rmdir" : "unlink", dest); + if (conf->progress == 2) { + fprintf(stderr, "%s(%s)\n", flags ? "rmdir" : "unlink", dest); + } else if (conf->progress == 1) { + /* overwrite */ + pdots(50, '.', conf->ops_completed, conf->ops_completed + 1, conf->ops_total); + conf->ops_completed++; + conf->ops_completed++; + } else { + pdots(50, '.', conf->ops_completed, conf->ops_completed + 1, conf->ops_total); + conf->ops_completed++; + } } errno = 0; @@ -946,20 +971,11 @@ static int install_files(void *f, int ncols, char **vals, char **cols) { nitem.dest); } else if (conf->progress == 1) { /* overwrite */ - /* one dot per 2% */ - int was = 50 * conf->ops_completed / conf->ops_total; - int now = 50 * (conf->ops_completed+1) / conf->ops_total; - while (was++ < now) { - fprintf(stderr, "."); - } + pdots(50, '.', conf->ops_completed, conf->ops_completed + 1, conf->ops_total); + conf->ops_completed++; conf->ops_completed++; } else { - /* one dot per 2% */ - int was = 50 * conf->ops_completed / conf->ops_total; - int now = 50 * (conf->ops_completed+1) / conf->ops_total; - while (was++ < now) { - fprintf(stderr, "."); - } + pdots(50, '.', conf->ops_completed, conf->ops_completed + 1, conf->ops_total); conf->ops_completed++; } } @@ -1321,8 +1337,11 @@ static void runstage(struct config *conf, char *stage, /* TODO final report function in conf var */ } -static int count_ops(struct config *conf) { - return zpm_db_int(conf->log, "select count(*) from syncinfo where op in ('remove', 'update', 'new')"); +static void count_ops(struct config *conf) { + conf->ops_remove = zpm_db_int(conf->log, "select count(*) from syncinfo where op = 'remove'"); + conf->ops_update = zpm_db_int(conf->log, "select count(*) from syncinfo where op = 'update'"); + conf->ops_install = zpm_db_int(conf->log, "select count(*) from syncinfo where op = 'new'"); + conf->ops_total = conf->ops_remove + conf->ops_update + conf->ops_install; } int main(int ac, char **av) { @@ -1452,25 +1471,48 @@ int main(int ac, char **av) { if (!conf.errors) { conf.exitonerror = conf.dryrun ? 0 : 1; conf.errabort = conf.dryrun ? 0 : 1; - conf.reverse = 1; - conf.ops_total = count_ops(&conf); + count_ops(&conf); fprintf(stderr, "file ops: %d\n", conf.ops_total); - if (conf.verbose) { - fprintf(stderr, "removing old files\n"); - } - runstage(&conf, "remove", remove_files); - conf.reverse = 0; - if (conf.verbose) { - fprintf(stderr, "updating files\n"); + if (conf.ops_remove > 0) { + if (conf.verbose) { + fprintf(stderr, "removing %d files\n", conf.ops_remove); + } + conf.reverse = 1; + conf.ops_completed = 0; + conf.ops_total = conf.ops_remove; + runstage(&conf, "remove", remove_files); + if (conf.verbose && conf.progress < 2) { + fprintf(stderr, " done\n"); + fflush(stderr); + } } - runstage(&conf, "update", install_files); - if (conf.verbose) { - fprintf(stderr, "installing %d files\n", conf.ops_total); + + if (conf.ops_update > 0) { + if (conf.verbose) { + fprintf(stderr, "updating %d files\n", conf.ops_update); + } + conf.reverse = 0; + conf.ops_completed = 0; + conf.ops_total = conf.ops_update; + runstage(&conf, "update", install_files); + if (conf.verbose && conf.progress < 2) { + fprintf(stderr, " done\n"); + fflush(stderr); + } } - runstage(&conf, "new", install_files); - if (conf.verbose && conf.progress < 2) { - fprintf(stderr, " done\n"); - fflush(stderr); + + if (conf.ops_install > 0) { + if (conf.verbose) { + fprintf(stderr, "installing %d files\n", conf.ops_install); + } + conf.reverse = 0; + conf.ops_completed = 0; + conf.ops_total = conf.ops_install; + runstage(&conf, "new", install_files); + if (conf.verbose && conf.progress < 2) { + fprintf(stderr, " done\n"); + fflush(stderr); + } } } }