Skip to content

Commit 56e8bb4

Browse files
pks-tgitster
authored andcommitted
fetch: use fetch_config to store "fetch.recurseSubmodules" value
Move the parsed "fetch.recurseSubmodules" config value into the `fetch_config` structure. This reduces our reliance on global variables and further unifies the way we parse the configuration in git-fetch(1). Signed-off-by: Patrick Steinhardt <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent ba28b2c commit 56e8bb4

File tree

1 file changed

+16
-15
lines changed

1 file changed

+16
-15
lines changed

builtin/fetch.c

Lines changed: 16 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -97,7 +97,6 @@ static struct string_list deepen_not = STRING_LIST_INIT_NODUP;
9797
static struct strbuf default_rla = STRBUF_INIT;
9898
static struct transport *gtransport;
9999
static struct transport *gsecondary;
100-
static int recurse_submodules = RECURSE_SUBMODULES_DEFAULT;
101100
static struct refspec refmap = REFSPEC_INIT_FETCH;
102101
static struct list_objects_filter_options filter_options = LIST_OBJECTS_FILTER_INIT;
103102
static struct string_list server_options = STRING_LIST_INIT_DUP;
@@ -108,6 +107,7 @@ struct fetch_config {
108107
int prune;
109108
int prune_tags;
110109
int show_forced_updates;
110+
int recurse_submodules;
111111
};
112112

113113
static int git_fetch_config(const char *k, const char *v, void *cb)
@@ -132,14 +132,14 @@ static int git_fetch_config(const char *k, const char *v, void *cb)
132132
if (!strcmp(k, "submodule.recurse")) {
133133
int r = git_config_bool(k, v) ?
134134
RECURSE_SUBMODULES_ON : RECURSE_SUBMODULES_OFF;
135-
recurse_submodules = r;
135+
fetch_config->recurse_submodules = r;
136136
}
137137

138138
if (!strcmp(k, "submodule.fetchjobs")) {
139139
submodule_fetch_jobs_config = parse_submodule_fetchjobs(k, v);
140140
return 0;
141141
} else if (!strcmp(k, "fetch.recursesubmodules")) {
142-
recurse_submodules = parse_fetch_recurse_submodules_arg(k, v);
142+
fetch_config->recurse_submodules = parse_fetch_recurse_submodules_arg(k, v);
143143
return 0;
144144
}
145145

@@ -1210,7 +1210,7 @@ static int store_updated_refs(struct display_state *display_state,
12101210
ref->force = rm->peer_ref->force;
12111211
}
12121212

1213-
if (recurse_submodules != RECURSE_SUBMODULES_OFF &&
1213+
if (config->recurse_submodules != RECURSE_SUBMODULES_OFF &&
12141214
(!rm->peer_ref || !oideq(&ref->old_oid, &ref->new_oid))) {
12151215
check_for_new_submodule_commits(&rm->old_oid);
12161216
}
@@ -1849,11 +1849,11 @@ static void add_options_to_argv(struct strvec *argv,
18491849
strvec_push(argv, "--force");
18501850
if (keep)
18511851
strvec_push(argv, "--keep");
1852-
if (recurse_submodules == RECURSE_SUBMODULES_ON)
1852+
if (config->recurse_submodules == RECURSE_SUBMODULES_ON)
18531853
strvec_push(argv, "--recurse-submodules");
1854-
else if (recurse_submodules == RECURSE_SUBMODULES_OFF)
1854+
else if (config->recurse_submodules == RECURSE_SUBMODULES_OFF)
18551855
strvec_push(argv, "--no-recurse-submodules");
1856-
else if (recurse_submodules == RECURSE_SUBMODULES_ON_DEMAND)
1856+
else if (config->recurse_submodules == RECURSE_SUBMODULES_ON_DEMAND)
18571857
strvec_push(argv, "--recurse-submodules=on-demand");
18581858
if (tags == TAGS_SET)
18591859
strvec_push(argv, "--tags");
@@ -2117,6 +2117,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
21172117
.prune = -1,
21182118
.prune_tags = -1,
21192119
.show_forced_updates = 1,
2120+
.recurse_submodules = RECURSE_SUBMODULES_DEFAULT,
21202121
};
21212122
const char *submodule_prefix = "";
21222123
const char *bundle_uri;
@@ -2245,7 +2246,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
22452246
builtin_fetch_options, builtin_fetch_usage, 0);
22462247

22472248
if (recurse_submodules_cli != RECURSE_SUBMODULES_DEFAULT)
2248-
recurse_submodules = recurse_submodules_cli;
2249+
config.recurse_submodules = recurse_submodules_cli;
22492250

22502251
if (negotiate_only) {
22512252
switch (recurse_submodules_cli) {
@@ -2256,7 +2257,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
22562257
* submodules. Skip it by setting recurse_submodules to
22572258
* RECURSE_SUBMODULES_OFF.
22582259
*/
2259-
recurse_submodules = RECURSE_SUBMODULES_OFF;
2260+
config.recurse_submodules = RECURSE_SUBMODULES_OFF;
22602261
break;
22612262

22622263
default:
@@ -2265,11 +2266,11 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
22652266
}
22662267
}
22672268

2268-
if (recurse_submodules != RECURSE_SUBMODULES_OFF) {
2269+
if (config.recurse_submodules != RECURSE_SUBMODULES_OFF) {
22692270
int *sfjc = submodule_fetch_jobs_config == -1
22702271
? &submodule_fetch_jobs_config : NULL;
2271-
int *rs = recurse_submodules == RECURSE_SUBMODULES_DEFAULT
2272-
? &recurse_submodules : NULL;
2272+
int *rs = config.recurse_submodules == RECURSE_SUBMODULES_DEFAULT
2273+
? &config.recurse_submodules : NULL;
22732274

22742275
fetch_config_from_gitmodules(sfjc, rs);
22752276
}
@@ -2283,7 +2284,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
22832284
* Reference updates in submodules would be ambiguous
22842285
* in porcelain mode, so we reject this combination.
22852286
*/
2286-
recurse_submodules = RECURSE_SUBMODULES_OFF;
2287+
config.recurse_submodules = RECURSE_SUBMODULES_OFF;
22872288
break;
22882289

22892290
default:
@@ -2425,7 +2426,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
24252426
* the fetched history from each remote, so there is no need
24262427
* to fetch submodules from here.
24272428
*/
2428-
if (!result && remote && (recurse_submodules != RECURSE_SUBMODULES_OFF)) {
2429+
if (!result && remote && (config.recurse_submodules != RECURSE_SUBMODULES_OFF)) {
24292430
struct strvec options = STRVEC_INIT;
24302431
int max_children = max_jobs;
24312432

@@ -2438,7 +2439,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
24382439
result = fetch_submodules(the_repository,
24392440
&options,
24402441
submodule_prefix,
2441-
recurse_submodules,
2442+
config.recurse_submodules,
24422443
recurse_submodules_default,
24432444
verbosity < 0,
24442445
max_children);

0 commit comments

Comments
 (0)