]> git.ipfire.org Git - thirdparty/git.git/commit - fetch-pack.c
fetch: teach independent negotiation (no packfile)
authorJonathan Tan <jonathantanmy@google.com>
Tue, 4 May 2021 21:16:01 +0000 (14:16 -0700)
committerJunio C Hamano <gitster@pobox.com>
Wed, 5 May 2021 01:41:29 +0000 (10:41 +0900)
commit9c1e657a8fd26fa3ed8d13fb8c796cef8db8b124
tree79ed7a1763a89a1be268af86dda6110a2d0c2a1a
parent6871d0cec62dc12d0c5f7390eee8a80614919578
fetch: teach independent negotiation (no packfile)

Currently, the packfile negotiation step within a Git fetch cannot be
done independent of sending the packfile, even though there is at least
one application wherein this is useful. Therefore, make it possible for
this negotiation step to be done independently. A subsequent commit will
use this for one such application - push negotiation.

This feature is for protocol v2 only. (An implementation for protocol v0
would require a separate implementation in the fetch, transport, and
transport helper code.)

In the protocol, the main hindrance towards independent negotiation is
that the server can unilaterally decide to send the packfile. This is
solved by a "wait-for-done" argument: the server will then wait for the
client to say "done". In practice, the client will never say it; instead
it will cease requests once it is satisfied.

In the client, the main change lies in the transport and transport
helper code. fetch_refs_via_pack() performs everything needed - protocol
version and capability checks, and the negotiation itself.

There are 2 code paths that do not go through fetch_refs_via_pack() that
needed to be individually excluded: the bundle transport (excluded
through requiring smart_options, which the bundle transport doesn't
support) and transport helpers that do not support takeover. If or when
we support independent negotiation for protocol v0, we will need to
modify these 2 code paths to support it. But for now, report failure if
independent negotiation is requested in these cases.

Signed-off-by: Jonathan Tan <jonathantanmy@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Documentation/technical/protocol-v2.txt
builtin/fetch.c
fetch-pack.c
fetch-pack.h
object.h
t/t5701-git-serve.sh
t/t5702-protocol-v2.sh
transport-helper.c
transport.c
transport.h
upload-pack.c