summaryrefslogtreecommitdiffstats
path: root/object-file.c
diff options
context:
space:
mode:
authorJonathan Tan <jonathantanmy@google.com>2022-10-04 23:13:41 +0200
committerJunio C Hamano <gitster@pobox.com>2022-10-05 20:06:53 +0200
commit301f1e3ac1531dc3a15064a06b24fa98f02a3b78 (patch)
tree7c6a16c1ec7d57dadd06fed09fb57bf8d4bf1523 /object-file.c
parentpromisor-remote: remove a return value (diff)
downloadgit-301f1e3ac1531dc3a15064a06b24fa98f02a3b78.tar.xz
git-301f1e3ac1531dc3a15064a06b24fa98f02a3b78.zip
promisor-remote: die upon failing fetch
In a partial clone, an attempt to read a missing object results in an attempt to fetch that single object. In order to avoid multiple sequential fetches, which would occur when multiple objects are missing (which is the typical case), some commands have been taught to prefetch in a batch: such a command would, in a partial clone, notice that several objects that it will eventually need are missing, and call promisor_remote_get_direct() with all such objects at once. When this batch prefetch fails, these commands fall back to the sequential fetches. But at $DAYJOB we have noticed that this results in a bad user experience: a command would take unexpectedly long to finish (and possibly use up a lot of bandwidth) if the batch prefetch would fail for some intermittent reason, but all subsequent fetches would work. It would be a better user experience for such a command would just fail. Therefore, make it a fatal error if the prefetch fails and at least one object being fetched is known to be a promisor object. (The latter criterion is to make sure that we are not misleading the user that such an object would be present from the promisor remote. For example, a missing object may be a result of repository corruption and not because it is expectedly missing due to the repository being a partial clone.) Signed-off-by: Jonathan Tan <jonathantanmy@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'object-file.c')
-rw-r--r--object-file.c4
1 files changed, 0 insertions, 4 deletions
diff --git a/object-file.c b/object-file.c
index 6c8e3b1660..a5e0160d28 100644
--- a/object-file.c
+++ b/object-file.c
@@ -1599,10 +1599,6 @@ static int do_oid_object_info_extended(struct repository *r,
if (fetch_if_missing && repo_has_promisor_remote(r) &&
!already_retried &&
!(flags & OBJECT_INFO_SKIP_FETCH_OBJECT)) {
- /*
- * TODO Investigate checking promisor_remote_get_direct()
- * TODO return value and stopping on error here.
- */
promisor_remote_get_direct(r, real, 1);
already_retried = 1;
continue;