Commit c4cba4e9 by Patrick Steinhardt

transports: http: reset `connected` flag when re-connecting transport

When calling `http_connect` on a subtransport whose stream is already
connected, we first close the stream in case no keep-alive is in use.
When doing so, we do not reset the transport's connection state,
though. Usually, this will do no harm in case the subsequent connect
will succeed. But when the connection fails we are left with a
substransport which is tagged as connected but which has no valid
stream attached.

Fix the issue by resetting the subtransport's connected-state when
closing its stream in `http_connect`.
parent 26a8617d
...@@ -599,6 +599,7 @@ static int http_connect(http_subtransport *t) ...@@ -599,6 +599,7 @@ static int http_connect(http_subtransport *t)
git_stream_close(t->io); git_stream_close(t->io);
git_stream_free(t->io); git_stream_free(t->io);
t->io = NULL; t->io = NULL;
t->connected = 0;
} }
if (t->connection_data.use_ssl) { if (t->connection_data.use_ssl) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment