mirror of
https://github.com/git/git.git
synced 2024-11-27 12:03:55 +08:00
remote-curl: rediscover repository when fetching refs
The reftable format encodes the hash function used by the repository inside of its tables. The reftable backend thus needs to be initialized with the correct hash function right from the start, or otherwise we may end up writing tables with the wrong hash function. But git-clone(1) initializes the reference database before learning about the hash function used by the remote repository, which has never been a problem with the reffiles backend. To fix this, we'll have to change git-clone(1) to be more careful and only create the reference backend once it learned about the remote hash function. This creates a problem for git-remote-curl(1), which will then be spawned at a time where the repository is not yet fully-initialized. Consequentially, git-remote-curl(1) will fail to detect the repository, which eventually causes it to error out once it is asked to fetch remote objects. We can address this issue by trying to re-discover the Git repository in case none was detected at startup time. With this change, the clone will look as following: 1. git-clone(1) sets up the initial repository, excluding the reference database. 2. git-clone(1) spawns git-remote-curl(1), which will be unable to detect the repository due to a missing "HEAD". 3. git-clone(1) asks git-remote-curl(1) to list remote references. This works just fine as this step does not require a local repository 4. git-clone(1) creates the reference database as it has now learned about the hash function. 5. git-clone(1) asks git-remote-curl(1) to fetch the remote packfile. The latter notices that it doesn't have a repository available, but it now knows to try and re-discover it. If the re-discovery succeeds in the last step we can continue with the clone. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
56cd0334f7
commit
bab2283ec6
@ -1564,8 +1564,11 @@ int cmd_main(int argc, const char **argv)
|
|||||||
if (buf.len == 0)
|
if (buf.len == 0)
|
||||||
break;
|
break;
|
||||||
if (starts_with(buf.buf, "fetch ")) {
|
if (starts_with(buf.buf, "fetch ")) {
|
||||||
if (nongit)
|
if (nongit) {
|
||||||
die(_("remote-curl: fetch attempted without a local repo"));
|
setup_git_directory_gently(&nongit);
|
||||||
|
if (nongit)
|
||||||
|
die(_("remote-curl: fetch attempted without a local repo"));
|
||||||
|
}
|
||||||
parse_fetch(&buf);
|
parse_fetch(&buf);
|
||||||
|
|
||||||
} else if (!strcmp(buf.buf, "list") || starts_with(buf.buf, "list ")) {
|
} else if (!strcmp(buf.buf, "list") || starts_with(buf.buf, "list ")) {
|
||||||
|
Loading…
Reference in New Issue
Block a user