+static int process_connect_service(struct transport *transport,
+ const char *name, const char *exec)
+{
+ struct helper_data *data = transport->data;
+ struct strbuf cmdbuf = STRBUF_INIT;
+ int ret = 0;
+
+ /*
+ * Handle --upload-pack and friends. This is fire and forget...
+ * just warn if it fails.
+ */
+ if (strcmp(name, exec)) {
+ int r = set_helper_option(transport, "servpath", exec);
+ if (r > 0)
+ warning(_("setting remote service path not supported by protocol"));
+ else if (r < 0)
+ warning(_("invalid remote service path"));
+ }
+
+ if (data->connect) {
+ strbuf_addf(&cmdbuf, "connect %s\n", name);
+ ret = run_connect(transport, &cmdbuf);
+ } else if (data->stateless_connect &&
+ (get_protocol_version_config() == protocol_v2) &&
+ !strcmp("git-upload-pack", name)) {
+ strbuf_addf(&cmdbuf, "stateless-connect %s\n", name);
+ ret = run_connect(transport, &cmdbuf);
+ if (ret)
+ transport->stateless_rpc = 1;
+ }
+
+ strbuf_release(&cmdbuf);
+ return ret;
+}
+