submodule: use argv_array instead of hand-building arrays
fetch_populated_submodules() allocates the full argv array it uses to recurse into the submodules from the number of given options plus the six argv values it is going to add. It then initializes it with those values which won't change during the iteration and copies the given options into it. Inside the loop the two argv values different for each submodule get replaced with those currently valid. However, this technique is brittle and error-prone (as the comment to explain the magic number 6 indicates), so let's replace it with an argv_array. Instead of replacing the argv values, push them to the argv_array just before the run_command() call (including the option separating them) and pop them from the argv_array right after that. Signed-off-by: Jens Lehmann <Jens.Lehmann@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
							parent
							
								
									85556d4e37
								
							
						
					
					
						commit
						50d89ad654
					
				|  | @ -1012,7 +1012,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix) | ||||||
| 		struct argv_array options = ARGV_ARRAY_INIT; | 		struct argv_array options = ARGV_ARRAY_INIT; | ||||||
|  |  | ||||||
| 		add_options_to_argv(&options); | 		add_options_to_argv(&options); | ||||||
| 		result = fetch_populated_submodules(options.argc, options.argv, | 		result = fetch_populated_submodules(&options, | ||||||
| 						    submodule_prefix, | 						    submodule_prefix, | ||||||
| 						    recurse_submodules, | 						    recurse_submodules, | ||||||
| 						    verbosity < 0); | 						    verbosity < 0); | ||||||
|  |  | ||||||
							
								
								
									
										31
									
								
								submodule.c
								
								
								
								
							
							
						
						
									
										31
									
								
								submodule.c
								
								
								
								
							|  | @ -586,13 +586,13 @@ static void calculate_changed_submodule_paths(void) | ||||||
| 	initialized_fetch_ref_tips = 0; | 	initialized_fetch_ref_tips = 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int fetch_populated_submodules(int num_options, const char **options, | int fetch_populated_submodules(const struct argv_array *options, | ||||||
| 			       const char *prefix, int command_line_option, | 			       const char *prefix, int command_line_option, | ||||||
| 			       int quiet) | 			       int quiet) | ||||||
| { | { | ||||||
| 	int i, result = 0, argc = 0, default_argc; | 	int i, result = 0; | ||||||
| 	struct child_process cp; | 	struct child_process cp; | ||||||
| 	const char **argv; | 	struct argv_array argv = ARGV_ARRAY_INIT; | ||||||
| 	struct string_list_item *name_for_path; | 	struct string_list_item *name_for_path; | ||||||
| 	const char *work_tree = get_git_work_tree(); | 	const char *work_tree = get_git_work_tree(); | ||||||
| 	if (!work_tree) | 	if (!work_tree) | ||||||
|  | @ -602,17 +602,13 @@ int fetch_populated_submodules(int num_options, const char **options, | ||||||
| 		if (read_cache() < 0) | 		if (read_cache() < 0) | ||||||
| 			die("index file corrupt"); | 			die("index file corrupt"); | ||||||
|  |  | ||||||
| 	/* 6: "fetch" (options) --recurse-submodules-default default "--submodule-prefix" prefix NULL */ | 	argv_array_push(&argv, "fetch"); | ||||||
| 	argv = xcalloc(num_options + 6, sizeof(const char *)); | 	for (i = 0; i < options->argc; i++) | ||||||
| 	argv[argc++] = "fetch"; | 		argv_array_push(&argv, options->argv[i]); | ||||||
| 	for (i = 0; i < num_options; i++) | 	argv_array_push(&argv, "--recurse-submodules-default"); | ||||||
| 		argv[argc++] = options[i]; | 	/* default value, "--submodule-prefix" and its value are added later */ | ||||||
| 	argv[argc++] = "--recurse-submodules-default"; |  | ||||||
| 	default_argc = argc++; |  | ||||||
| 	argv[argc++] = "--submodule-prefix"; |  | ||||||
|  |  | ||||||
| 	memset(&cp, 0, sizeof(cp)); | 	memset(&cp, 0, sizeof(cp)); | ||||||
| 	cp.argv = argv; |  | ||||||
| 	cp.env = local_repo_env; | 	cp.env = local_repo_env; | ||||||
| 	cp.git_cmd = 1; | 	cp.git_cmd = 1; | ||||||
| 	cp.no_stdin = 1; | 	cp.no_stdin = 1; | ||||||
|  | @ -672,16 +668,21 @@ int fetch_populated_submodules(int num_options, const char **options, | ||||||
| 			if (!quiet) | 			if (!quiet) | ||||||
| 				printf("Fetching submodule %s%s\n", prefix, ce->name); | 				printf("Fetching submodule %s%s\n", prefix, ce->name); | ||||||
| 			cp.dir = submodule_path.buf; | 			cp.dir = submodule_path.buf; | ||||||
| 			argv[default_argc] = default_argv; | 			argv_array_push(&argv, default_argv); | ||||||
| 			argv[argc] = submodule_prefix.buf; | 			argv_array_push(&argv, "--submodule-prefix"); | ||||||
|  | 			argv_array_push(&argv, submodule_prefix.buf); | ||||||
|  | 			cp.argv = argv.argv; | ||||||
| 			if (run_command(&cp)) | 			if (run_command(&cp)) | ||||||
| 				result = 1; | 				result = 1; | ||||||
|  | 			argv_array_pop(&argv); | ||||||
|  | 			argv_array_pop(&argv); | ||||||
|  | 			argv_array_pop(&argv); | ||||||
| 		} | 		} | ||||||
| 		strbuf_release(&submodule_path); | 		strbuf_release(&submodule_path); | ||||||
| 		strbuf_release(&submodule_git_dir); | 		strbuf_release(&submodule_git_dir); | ||||||
| 		strbuf_release(&submodule_prefix); | 		strbuf_release(&submodule_prefix); | ||||||
| 	} | 	} | ||||||
| 	free(argv); | 	argv_array_clear(&argv); | ||||||
| out: | out: | ||||||
| 	string_list_clear(&changed_submodule_paths, 1); | 	string_list_clear(&changed_submodule_paths, 1); | ||||||
| 	return result; | 	return result; | ||||||
|  |  | ||||||
|  | @ -2,6 +2,7 @@ | ||||||
| #define SUBMODULE_H | #define SUBMODULE_H | ||||||
|  |  | ||||||
| struct diff_options; | struct diff_options; | ||||||
|  | struct argv_array; | ||||||
|  |  | ||||||
| enum { | enum { | ||||||
| 	RECURSE_SUBMODULES_ON_DEMAND = -1, | 	RECURSE_SUBMODULES_ON_DEMAND = -1, | ||||||
|  | @ -23,7 +24,7 @@ void show_submodule_summary(FILE *f, const char *path, | ||||||
| 		const char *del, const char *add, const char *reset); | 		const char *del, const char *add, const char *reset); | ||||||
| void set_config_fetch_recurse_submodules(int value); | void set_config_fetch_recurse_submodules(int value); | ||||||
| void check_for_new_submodule_commits(unsigned char new_sha1[20]); | void check_for_new_submodule_commits(unsigned char new_sha1[20]); | ||||||
| int fetch_populated_submodules(int num_options, const char **options, | int fetch_populated_submodules(const struct argv_array *options, | ||||||
| 			       const char *prefix, int command_line_option, | 			       const char *prefix, int command_line_option, | ||||||
| 			       int quiet); | 			       int quiet); | ||||||
| unsigned is_submodule_modified(const char *path, int ignore_untracked); | unsigned is_submodule_modified(const char *path, int ignore_untracked); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Jens Lehmann
						Jens Lehmann