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>
			
			
				maint
			
			
		
							parent
							
								
									fb7d80edca
								
							
						
					
					
						commit
						d089a06421
					
				|  | @ -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 New Issue
	
	 René Scharfe
						René Scharfe