Browse Source
Add a noop fetch negotiator. This is introduced to allow partial clones to skip the unneeded negotiation step when fetching missing objects using a "git fetch" subprocess. (The implementation of spawning a "git fetch" subprocess will be done in a subsequent patch.) But this can also be useful for end users, e.g. as a blunt fix for object corruption. Signed-off-by: Jonathan Tan <jonathantanmy@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
Jonathan Tan
4 years ago
committed by
Junio C Hamano
8 changed files with 87 additions and 1 deletions
@ -0,0 +1,44 @@
@@ -0,0 +1,44 @@
|
||||
#include "cache.h" |
||||
#include "noop.h" |
||||
#include "../commit.h" |
||||
#include "../fetch-negotiator.h" |
||||
|
||||
static void known_common(struct fetch_negotiator *n, struct commit *c) |
||||
{ |
||||
/* do nothing */ |
||||
} |
||||
|
||||
static void add_tip(struct fetch_negotiator *n, struct commit *c) |
||||
{ |
||||
/* do nothing */ |
||||
} |
||||
|
||||
static const struct object_id *next(struct fetch_negotiator *n) |
||||
{ |
||||
return NULL; |
||||
} |
||||
|
||||
static int ack(struct fetch_negotiator *n, struct commit *c) |
||||
{ |
||||
/* |
||||
* This negotiator does not emit any commits, so there is no commit to |
||||
* be acknowledged. If there is any ack, there is a bug. |
||||
*/ |
||||
BUG("ack with noop negotiator, which does not emit any commits"); |
||||
return 0; |
||||
} |
||||
|
||||
static void release(struct fetch_negotiator *n) |
||||
{ |
||||
/* nothing to release */ |
||||
} |
||||
|
||||
void noop_negotiator_init(struct fetch_negotiator *negotiator) |
||||
{ |
||||
negotiator->known_common = known_common; |
||||
negotiator->add_tip = add_tip; |
||||
negotiator->next = next; |
||||
negotiator->ack = ack; |
||||
negotiator->release = release; |
||||
negotiator->data = NULL; |
||||
} |
@ -0,0 +1,8 @@
@@ -0,0 +1,8 @@
|
||||
#ifndef NEGOTIATOR_NOOP_H |
||||
#define NEGOTIATOR_NOOP_H |
||||
|
||||
struct fetch_negotiator; |
||||
|
||||
void noop_negotiator_init(struct fetch_negotiator *negotiator); |
||||
|
||||
#endif |
@ -0,0 +1,22 @@
@@ -0,0 +1,22 @@
|
||||
#!/bin/sh |
||||
|
||||
test_description='test noop fetch negotiator' |
||||
. ./test-lib.sh |
||||
|
||||
test_expect_success 'noop negotiator does not emit any "have"' ' |
||||
rm -f trace && |
||||
|
||||
test_create_repo server && |
||||
test_commit -C server to_fetch && |
||||
|
||||
test_create_repo client && |
||||
test_commit -C client we_have && |
||||
|
||||
test_config -C client fetch.negotiationalgorithm noop && |
||||
GIT_TRACE_PACKET="$(pwd)/trace" git -C client fetch "$(pwd)/server" && |
||||
|
||||
! grep "fetch> have" trace && |
||||
grep "fetch> done" trace |
||||
' |
||||
|
||||
test_done |
Loading…
Reference in new issue