fetch: define shallow boundary with --shallow-since
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
569e554be9
commit
508ea88226
12
fetch-pack.c
12
fetch-pack.c
@ -21,6 +21,7 @@ static int fetch_unpack_limit = -1;
|
||||
static int unpack_limit = 100;
|
||||
static int prefer_ofs_delta = 1;
|
||||
static int no_done;
|
||||
static int deepen_since_ok;
|
||||
static int fetch_fsck_objects = -1;
|
||||
static int transfer_fsck_objects = -1;
|
||||
static int agent_supported;
|
||||
@ -326,6 +327,7 @@ static int find_common(struct fetch_pack_args *args,
|
||||
if (args->no_progress) strbuf_addstr(&c, " no-progress");
|
||||
if (args->include_tag) strbuf_addstr(&c, " include-tag");
|
||||
if (prefer_ofs_delta) strbuf_addstr(&c, " ofs-delta");
|
||||
if (deepen_since_ok) strbuf_addstr(&c, " deepen-since");
|
||||
if (agent_supported) strbuf_addf(&c, " agent=%s",
|
||||
git_user_agent_sanitized());
|
||||
packet_buf_write(&req_buf, "want %s%s\n", remote_hex, c.buf);
|
||||
@ -345,6 +347,10 @@ static int find_common(struct fetch_pack_args *args,
|
||||
write_shallow_commits(&req_buf, 1, NULL);
|
||||
if (args->depth > 0)
|
||||
packet_buf_write(&req_buf, "deepen %d", args->depth);
|
||||
if (args->deepen_since) {
|
||||
unsigned long max_age = approxidate(args->deepen_since);
|
||||
packet_buf_write(&req_buf, "deepen-since %lu", max_age);
|
||||
}
|
||||
packet_buf_flush(&req_buf);
|
||||
state_len = req_buf.len;
|
||||
|
||||
@ -812,7 +818,7 @@ static struct ref *do_fetch_pack(struct fetch_pack_args *args,
|
||||
|
||||
if ((args->depth > 0 || is_repository_shallow()) && !server_supports("shallow"))
|
||||
die(_("Server does not support shallow clients"));
|
||||
if (args->depth > 0)
|
||||
if (args->depth > 0 || args->deepen_since)
|
||||
args->deepen = 1;
|
||||
if (server_supports("multi_ack_detailed")) {
|
||||
print_verbose(args, _("Server supports multi_ack_detailed"));
|
||||
@ -860,6 +866,10 @@ static struct ref *do_fetch_pack(struct fetch_pack_args *args,
|
||||
print_verbose(args, _("Server version is %.*s"),
|
||||
agent_len, agent_feature);
|
||||
}
|
||||
if (server_supports("deepen-since"))
|
||||
deepen_since_ok = 1;
|
||||
else if (args->deepen_since)
|
||||
die(_("Server does not support --shallow-since"));
|
||||
|
||||
if (everything_local(args, &ref, sought, nr_sought)) {
|
||||
packet_flush(fd[1]);
|
||||
|
Reference in New Issue
Block a user