move setup_alternate_shallow and write_shallow_commits to shallow.c
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
2c2b6646c2
commit
3125fe528b
3
commit.h
3
commit.h
@ -198,6 +198,9 @@ extern struct commit_list *get_shallow_commits(struct object_array *heads,
|
|||||||
int depth, int shallow_flag, int not_shallow_flag);
|
int depth, int shallow_flag, int not_shallow_flag);
|
||||||
extern void check_shallow_file_for_update(void);
|
extern void check_shallow_file_for_update(void);
|
||||||
extern void set_alternate_shallow_file(const char *path);
|
extern void set_alternate_shallow_file(const char *path);
|
||||||
|
extern int write_shallow_commits(struct strbuf *out, int use_pack_protocol);
|
||||||
|
extern void setup_alternate_shallow(struct lock_file *shallow_lock,
|
||||||
|
const char **alternate_shallow_file);
|
||||||
|
|
||||||
int is_descendant_of(struct commit *, struct commit_list *);
|
int is_descendant_of(struct commit *, struct commit_list *);
|
||||||
int in_merge_bases(struct commit *, struct commit *);
|
int in_merge_bases(struct commit *, struct commit *);
|
||||||
|
53
fetch-pack.c
53
fetch-pack.c
@ -184,36 +184,6 @@ static void consume_shallow_list(struct fetch_pack_args *args, int fd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct write_shallow_data {
|
|
||||||
struct strbuf *out;
|
|
||||||
int use_pack_protocol;
|
|
||||||
int count;
|
|
||||||
};
|
|
||||||
|
|
||||||
static int write_one_shallow(const struct commit_graft *graft, void *cb_data)
|
|
||||||
{
|
|
||||||
struct write_shallow_data *data = cb_data;
|
|
||||||
const char *hex = sha1_to_hex(graft->sha1);
|
|
||||||
data->count++;
|
|
||||||
if (data->use_pack_protocol)
|
|
||||||
packet_buf_write(data->out, "shallow %s", hex);
|
|
||||||
else {
|
|
||||||
strbuf_addstr(data->out, hex);
|
|
||||||
strbuf_addch(data->out, '\n');
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int write_shallow_commits(struct strbuf *out, int use_pack_protocol)
|
|
||||||
{
|
|
||||||
struct write_shallow_data data;
|
|
||||||
data.out = out;
|
|
||||||
data.use_pack_protocol = use_pack_protocol;
|
|
||||||
data.count = 0;
|
|
||||||
for_each_commit_graft(write_one_shallow, &data);
|
|
||||||
return data.count;
|
|
||||||
}
|
|
||||||
|
|
||||||
static enum ack_type get_ack(int fd, unsigned char *result_sha1)
|
static enum ack_type get_ack(int fd, unsigned char *result_sha1)
|
||||||
{
|
{
|
||||||
int len;
|
int len;
|
||||||
@ -795,27 +765,6 @@ static int cmp_ref_by_name(const void *a_, const void *b_)
|
|||||||
return strcmp(a->name, b->name);
|
return strcmp(a->name, b->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setup_alternate_shallow(void)
|
|
||||||
{
|
|
||||||
struct strbuf sb = STRBUF_INIT;
|
|
||||||
int fd;
|
|
||||||
|
|
||||||
check_shallow_file_for_update();
|
|
||||||
fd = hold_lock_file_for_update(&shallow_lock, git_path("shallow"),
|
|
||||||
LOCK_DIE_ON_ERROR);
|
|
||||||
if (write_shallow_commits(&sb, 0)) {
|
|
||||||
if (write_in_full(fd, sb.buf, sb.len) != sb.len)
|
|
||||||
die_errno("failed to write to %s", shallow_lock.filename);
|
|
||||||
alternate_shallow_file = shallow_lock.filename;
|
|
||||||
} else
|
|
||||||
/*
|
|
||||||
* is_repository_shallow() sees empty string as "no
|
|
||||||
* shallow file".
|
|
||||||
*/
|
|
||||||
alternate_shallow_file = "";
|
|
||||||
strbuf_release(&sb);
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct ref *do_fetch_pack(struct fetch_pack_args *args,
|
static struct ref *do_fetch_pack(struct fetch_pack_args *args,
|
||||||
int fd[2],
|
int fd[2],
|
||||||
const struct ref *orig_ref,
|
const struct ref *orig_ref,
|
||||||
@ -896,7 +845,7 @@ static struct ref *do_fetch_pack(struct fetch_pack_args *args,
|
|||||||
if (args->stateless_rpc)
|
if (args->stateless_rpc)
|
||||||
packet_flush(fd[1]);
|
packet_flush(fd[1]);
|
||||||
if (args->depth > 0)
|
if (args->depth > 0)
|
||||||
setup_alternate_shallow();
|
setup_alternate_shallow(&shallow_lock, &alternate_shallow_file);
|
||||||
if (get_pack(args, fd, pack_lockfile))
|
if (get_pack(args, fd, pack_lockfile))
|
||||||
die("git fetch-pack: fetch failed.");
|
die("git fetch-pack: fetch failed.");
|
||||||
|
|
||||||
|
54
shallow.c
54
shallow.c
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
|
#include "pkt-line.h"
|
||||||
|
|
||||||
static int is_shallow = -1;
|
static int is_shallow = -1;
|
||||||
static struct stat shallow_stat;
|
static struct stat shallow_stat;
|
||||||
@ -141,3 +142,56 @@ void check_shallow_file_for_update(void)
|
|||||||
)
|
)
|
||||||
die("shallow file was changed during fetch");
|
die("shallow file was changed during fetch");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct write_shallow_data {
|
||||||
|
struct strbuf *out;
|
||||||
|
int use_pack_protocol;
|
||||||
|
int count;
|
||||||
|
};
|
||||||
|
|
||||||
|
static int write_one_shallow(const struct commit_graft *graft, void *cb_data)
|
||||||
|
{
|
||||||
|
struct write_shallow_data *data = cb_data;
|
||||||
|
const char *hex = sha1_to_hex(graft->sha1);
|
||||||
|
data->count++;
|
||||||
|
if (data->use_pack_protocol)
|
||||||
|
packet_buf_write(data->out, "shallow %s", hex);
|
||||||
|
else {
|
||||||
|
strbuf_addstr(data->out, hex);
|
||||||
|
strbuf_addch(data->out, '\n');
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int write_shallow_commits(struct strbuf *out, int use_pack_protocol)
|
||||||
|
{
|
||||||
|
struct write_shallow_data data;
|
||||||
|
data.out = out;
|
||||||
|
data.use_pack_protocol = use_pack_protocol;
|
||||||
|
data.count = 0;
|
||||||
|
for_each_commit_graft(write_one_shallow, &data);
|
||||||
|
return data.count;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setup_alternate_shallow(struct lock_file *shallow_lock,
|
||||||
|
const char **alternate_shallow_file)
|
||||||
|
{
|
||||||
|
struct strbuf sb = STRBUF_INIT;
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
check_shallow_file_for_update();
|
||||||
|
fd = hold_lock_file_for_update(shallow_lock, git_path("shallow"),
|
||||||
|
LOCK_DIE_ON_ERROR);
|
||||||
|
if (write_shallow_commits(&sb, 0)) {
|
||||||
|
if (write_in_full(fd, sb.buf, sb.len) != sb.len)
|
||||||
|
die_errno("failed to write to %s",
|
||||||
|
shallow_lock->filename);
|
||||||
|
*alternate_shallow_file = shallow_lock->filename;
|
||||||
|
} else
|
||||||
|
/*
|
||||||
|
* is_repository_shallow() sees empty string as "no
|
||||||
|
* shallow file".
|
||||||
|
*/
|
||||||
|
*alternate_shallow_file = "";
|
||||||
|
strbuf_release(&sb);
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user