negotiator/noop: add noop fetch negotiator

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>
This commit is contained in:
Jonathan Tan
2020-08-17 21:01:31 -07:00
committed by Junio C Hamano
parent 887952b8c6
commit cbe566a071
8 changed files with 87 additions and 1 deletions

44
negotiator/noop.c Normal file
View File

@ -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;
}

8
negotiator/noop.h Normal file
View File

@ -0,0 +1,8 @@
#ifndef NEGOTIATOR_NOOP_H
#define NEGOTIATOR_NOOP_H
struct fetch_negotiator;
void noop_negotiator_init(struct fetch_negotiator *negotiator);
#endif