mirror of
https://github.com/git/git
synced 2024-11-05 01:58:18 +00:00
bundle: use OPT_PASSTHRU_ARGV
"git bundle" passes the progress control options to "git pack-objects"
by parsing and then recreating them explicitly. Simplify that process
by using OPT_PASSTHRU_ARGV instead.
This also fixes --no-quiet, which has been doing the same as --quiet
since its introduction by 79862b6b77
(bundle-create: progress output
control, 2019-11-10) because it had been defined using OPT_SET_INT with
a value of 0, which sets 0 when negated as well.
Signed-off-by: René Scharfe <l.s.r@web.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
fb7d80edca
commit
d089a06421
2 changed files with 23 additions and 23 deletions
|
@ -69,42 +69,36 @@ static int parse_options_cmd_bundle(int argc,
|
|||
}
|
||||
|
||||
static int cmd_bundle_create(int argc, const char **argv, const char *prefix) {
|
||||
int all_progress_implied = 1;
|
||||
int progress = isatty(STDERR_FILENO);
|
||||
struct strvec pack_opts;
|
||||
struct strvec pack_opts = STRVEC_INIT;
|
||||
int version = -1;
|
||||
int ret;
|
||||
struct option options[] = {
|
||||
OPT_SET_INT('q', "quiet", &progress,
|
||||
N_("do not show progress meter"), 0),
|
||||
OPT_SET_INT(0, "progress", &progress,
|
||||
N_("show progress meter"), 1),
|
||||
OPT_SET_INT_F(0, "all-progress", &progress,
|
||||
N_("historical; same as --progress"), 2,
|
||||
PARSE_OPT_HIDDEN),
|
||||
OPT_HIDDEN_BOOL(0, "all-progress-implied",
|
||||
&all_progress_implied,
|
||||
N_("historical; does nothing")),
|
||||
OPT_PASSTHRU_ARGV('q', "quiet", &pack_opts, NULL,
|
||||
N_("do not show progress meter"),
|
||||
PARSE_OPT_NOARG),
|
||||
OPT_PASSTHRU_ARGV(0, "progress", &pack_opts, NULL,
|
||||
N_("show progress meter"),
|
||||
PARSE_OPT_NOARG),
|
||||
OPT_PASSTHRU_ARGV(0, "all-progress", &pack_opts, NULL,
|
||||
N_("historical; same as --progress"),
|
||||
PARSE_OPT_NOARG | PARSE_OPT_HIDDEN),
|
||||
OPT_PASSTHRU_ARGV(0, "all-progress-implied", &pack_opts, NULL,
|
||||
N_("historical; does nothing"),
|
||||
PARSE_OPT_NOARG | PARSE_OPT_HIDDEN),
|
||||
OPT_INTEGER(0, "version", &version,
|
||||
N_("specify bundle format version")),
|
||||
OPT_END()
|
||||
};
|
||||
char *bundle_file;
|
||||
|
||||
if (isatty(STDERR_FILENO))
|
||||
strvec_push(&pack_opts, "--progress");
|
||||
strvec_push(&pack_opts, "--all-progress-implied");
|
||||
|
||||
argc = parse_options_cmd_bundle(argc, argv, prefix,
|
||||
builtin_bundle_create_usage, options, &bundle_file);
|
||||
/* bundle internals use argv[1] as further parameters */
|
||||
|
||||
strvec_init(&pack_opts);
|
||||
if (progress == 0)
|
||||
strvec_push(&pack_opts, "--quiet");
|
||||
else if (progress == 1)
|
||||
strvec_push(&pack_opts, "--progress");
|
||||
else if (progress == 2)
|
||||
strvec_push(&pack_opts, "--all-progress");
|
||||
if (progress && all_progress_implied)
|
||||
strvec_push(&pack_opts, "--all-progress-implied");
|
||||
|
||||
if (!startup_info->have_repository)
|
||||
die(_("Need a repository to create a bundle."));
|
||||
ret = !!create_bundle(the_repository, bundle_file, argc, argv, &pack_opts, version);
|
||||
|
|
|
@ -619,6 +619,12 @@ test_expect_success TTY 'create --quiet disables all bundle progress' '
|
|||
test_must_be_empty err
|
||||
'
|
||||
|
||||
test_expect_success 'bundle progress with --no-quiet' '
|
||||
GIT_PROGRESS_DELAY=0 \
|
||||
git bundle create --no-quiet out.bundle --all 2>err &&
|
||||
grep "%" err
|
||||
'
|
||||
|
||||
test_expect_success 'read bundle over stdin' '
|
||||
git bundle create some.bundle HEAD &&
|
||||
|
||||
|
|
Loading…
Reference in a new issue