]> git.ipfire.org Git - thirdparty/git.git/commit - fetch-pack.c
fetch-pack: fix deepen shallow over smart http with no-done cap
authorNguyễn Thái Ngọc Duy <pclouds@gmail.com>
Thu, 6 Feb 2014 15:10:39 +0000 (22:10 +0700)
committerJunio C Hamano <gitster@pobox.com>
Mon, 10 Feb 2014 18:21:33 +0000 (10:21 -0800)
commitff62eca7d1f9716e36550adedc6e8edc35ff9a15
tree44d09cf73bccf31083e82d46fa6c279488445325
parentc9cd60f6fa064595e4c1a8a84b9a15cc016a09e1
fetch-pack: fix deepen shallow over smart http with no-done cap

In smart http, upload-pack adds new shallow lines at the beginning of
each rpc response. Only shallow lines from the first rpc call are
useful. After that they are thrown away. It's designed this way
because upload-pack is stateless and has no idea when its shallow
lines are helpful or not.

So after refs are negotiated with multi_ack_detailed and the server
thinks it learned enough, it sends "ACK obj-id ready", terminates the
rpc call and waits for the final rpc round. The client sends "done".
The server sends another response, which also has shallow lines at
the beginning, and the last "ACK obj-id" line.

When no-done is active, the last round is cut out, the server sends
"ACK obj-id ready" and "ACK obj-id" in the same rpc
response. fetch-pack is updated to recognize this and not send
"done". However it still tries to consume shallow lines, which are
never sent.

Update the code, make sure to skip consuming shallow lines when
no-done is enabled.

Reported-by: Jeff King <peff@peff.net>
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
fetch-pack.c
t/t5537-fetch-shallow.sh