Ilari Liusvaara <ilari.liusvaara@xxxxxxxxxxx> wrote: > diff --git a/transport-helper.c b/transport-helper.c > index 3d99fe1..e0254bc 100644 > --- a/transport-helper.c > +++ b/transport-helper.c > static int fetch(struct transport *transport, > int nr_heads, struct ref **to_fetch) > { > struct helper_data *data = transport->data; > int i, count; > > + if (process_connect(transport, 0)) { > + transport_take_over(transport); > + return transport->fetch(transport, nr_heads, to_fetch); > + } We should already be connected because of the prior call into get_refs_list(). If I read your code correctly we'd try to open a new connection right here, which makes no sense. But its also possible for us to be in a different transport, so we do code with the assumption that we didn't get invoked through get_refs_list() first and therefore need to open the connection ourselves. Also, given the above invocation pattern, I see no reason why you need the disown virtual function on struct transport*. Just pass the #@!**! struct child* into transport_take_over() from the 3 call sites here and get rid of that unnecessary indirection. -- Shawn. -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html