@@ -519,11 +519,7 @@ static int git_push_config(const char *k, const char *v,
} else if (!strcmp(k, "push.pushoption")) {
if (!v)
return config_error_nonbool(k);
- else
- if (!*v)
- string_list_clear(&push_options_config, 0);
- else
- string_list_append(&push_options_config, v);
+ parse_transport_option(v, &push_options_config);
return 0;
} else if (!strcmp(k, "color.push")) {
push_use_color = git_config_colorbool(k, v);
@@ -1091,6 +1091,14 @@ int is_transport_allowed(const char *type, int from_user)
BUG("invalid protocol_allow_config type");
}
+void parse_transport_option(const char *option, struct string_list *transport_options)
+{
+ if (!*option)
+ string_list_clear(transport_options, 0);
+ else
+ string_list_append(transport_options, option);
+}
+
void transport_check_allowed(const char *type)
{
if (!is_transport_allowed(type, -1))
@@ -342,4 +342,7 @@ void transport_print_push_status(const char *dest, struct ref *refs,
/* common method used by transport-helper.c and send-pack.c */
void reject_atomic_push(struct ref *refs, int mirror_mode);
+/* common method to parse push-option for pushes or server-option for fetches */
+void parse_transport_option(const char *option, struct string_list *transport_options);
+
#endif