Merge branch 'sb/object-store-grafts' into sb/object-store-lookup
* sb/object-store-grafts: commit: allow lookup_commit_graft to handle arbitrary repositories commit: allow prepare_commit_graft to handle arbitrary repositories shallow: migrate shallow information into the object parser path.c: migrate global git_path_* to take a repository argument cache: convert get_graft_file to handle arbitrary repositories commit: convert read_graft_file to handle arbitrary repositories commit: convert register_commit_graft to handle arbitrary repositories commit: convert commit_graft_pos() to handle arbitrary repositories shallow: add repository argument to is_repository_shallow shallow: add repository argument to check_shallow_file_for_update shallow: add repository argument to register_shallow shallow: add repository argument to set_alternate_shallow_file commit: add repository argument to lookup_commit_graft commit: add repository argument to prepare_commit_graft commit: add repository argument to read_graft_file commit: add repository argument to register_commit_graft commit: add repository argument to commit_graft_pos object: move grafts to object parser object-store: move object access functions to object-store.h
This commit is contained in:
commit
b16b60f71b
1
apply.c
1
apply.c
@ -9,6 +9,7 @@
|
|||||||
|
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "delta.h"
|
#include "delta.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "tar.h"
|
#include "tar.h"
|
||||||
#include "archive.h"
|
#include "archive.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "streaming.h"
|
#include "streaming.h"
|
||||||
#include "run-command.h"
|
#include "run-command.h"
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#include "archive.h"
|
#include "archive.h"
|
||||||
#include "streaming.h"
|
#include "streaming.h"
|
||||||
#include "utf8.h"
|
#include "utf8.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "userdiff.h"
|
#include "userdiff.h"
|
||||||
#include "xdiff-interface.h"
|
#include "xdiff-interface.h"
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
#include "attr.h"
|
#include "attr.h"
|
||||||
|
9
blame.c
9
blame.c
@ -1,5 +1,6 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "cache-tree.h"
|
#include "cache-tree.h"
|
||||||
#include "mergesort.h"
|
#include "mergesort.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
@ -129,17 +130,19 @@ static void append_merge_parents(struct commit_list **tail)
|
|||||||
int merge_head;
|
int merge_head;
|
||||||
struct strbuf line = STRBUF_INIT;
|
struct strbuf line = STRBUF_INIT;
|
||||||
|
|
||||||
merge_head = open(git_path_merge_head(), O_RDONLY);
|
merge_head = open(git_path_merge_head(the_repository), O_RDONLY);
|
||||||
if (merge_head < 0) {
|
if (merge_head < 0) {
|
||||||
if (errno == ENOENT)
|
if (errno == ENOENT)
|
||||||
return;
|
return;
|
||||||
die("cannot open '%s' for reading", git_path_merge_head());
|
die("cannot open '%s' for reading",
|
||||||
|
git_path_merge_head(the_repository));
|
||||||
}
|
}
|
||||||
|
|
||||||
while (!strbuf_getwholeline_fd(&line, merge_head, '\n')) {
|
while (!strbuf_getwholeline_fd(&line, merge_head, '\n')) {
|
||||||
struct object_id oid;
|
struct object_id oid;
|
||||||
if (line.len < GIT_SHA1_HEXSZ || get_oid_hex(line.buf, &oid))
|
if (line.len < GIT_SHA1_HEXSZ || get_oid_hex(line.buf, &oid))
|
||||||
die("unknown line in '%s': %s", git_path_merge_head(), line.buf);
|
die("unknown line in '%s': %s",
|
||||||
|
git_path_merge_head(the_repository), line.buf);
|
||||||
tail = append_parent(tail, &oid);
|
tail = append_parent(tail, &oid);
|
||||||
}
|
}
|
||||||
close(merge_head);
|
close(merge_head);
|
||||||
|
14
branch.c
14
branch.c
@ -340,13 +340,13 @@ void create_branch(const char *name, const char *start_name,
|
|||||||
|
|
||||||
void remove_branch_state(void)
|
void remove_branch_state(void)
|
||||||
{
|
{
|
||||||
unlink(git_path_cherry_pick_head());
|
unlink(git_path_cherry_pick_head(the_repository));
|
||||||
unlink(git_path_revert_head());
|
unlink(git_path_revert_head(the_repository));
|
||||||
unlink(git_path_merge_head());
|
unlink(git_path_merge_head(the_repository));
|
||||||
unlink(git_path_merge_rr());
|
unlink(git_path_merge_rr(the_repository));
|
||||||
unlink(git_path_merge_msg());
|
unlink(git_path_merge_msg(the_repository));
|
||||||
unlink(git_path_merge_mode());
|
unlink(git_path_merge_mode(the_repository));
|
||||||
unlink(git_path_squash_msg());
|
unlink(git_path_squash_msg(the_repository));
|
||||||
}
|
}
|
||||||
|
|
||||||
void die_if_checked_out(const char *branch, int ignore_current_worktree)
|
void die_if_checked_out(const char *branch, int ignore_current_worktree)
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "color.h"
|
#include "color.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
|
#include "repository.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
#include "revision.h"
|
#include "revision.h"
|
||||||
@ -23,6 +24,7 @@
|
|||||||
#include "line-log.h"
|
#include "line-log.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
#include "progress.h"
|
#include "progress.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blame.h"
|
#include "blame.h"
|
||||||
#include "string-list.h"
|
#include "string-list.h"
|
||||||
|
|
||||||
@ -576,7 +578,7 @@ static int read_ancestry(const char *graft_file)
|
|||||||
/* The format is just "Commit Parent1 Parent2 ...\n" */
|
/* The format is just "Commit Parent1 Parent2 ...\n" */
|
||||||
struct commit_graft *graft = read_graft_line(&buf);
|
struct commit_graft *graft = read_graft_line(&buf);
|
||||||
if (graft)
|
if (graft)
|
||||||
register_commit_graft(graft, 0);
|
register_commit_graft(the_repository, graft, 0);
|
||||||
}
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
strbuf_release(&buf);
|
strbuf_release(&buf);
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
#include "sha1-array.h"
|
#include "sha1-array.h"
|
||||||
#include "packfile.h"
|
#include "packfile.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
struct batch_options {
|
struct batch_options {
|
||||||
int enabled;
|
int enabled;
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#include "lockfile.h"
|
#include "lockfile.h"
|
||||||
#include "parse-options.h"
|
#include "parse-options.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include "fetch-pack.h"
|
#include "fetch-pack.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "refspec.h"
|
#include "refspec.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
#include "unpack-trees.h"
|
#include "unpack-trees.h"
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
*/
|
*/
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
|
@ -168,9 +168,9 @@ static int opt_parse_rename_score(const struct option *opt, const char *arg, int
|
|||||||
|
|
||||||
static void determine_whence(struct wt_status *s)
|
static void determine_whence(struct wt_status *s)
|
||||||
{
|
{
|
||||||
if (file_exists(git_path_merge_head()))
|
if (file_exists(git_path_merge_head(the_repository)))
|
||||||
whence = FROM_MERGE;
|
whence = FROM_MERGE;
|
||||||
else if (file_exists(git_path_cherry_pick_head())) {
|
else if (file_exists(git_path_cherry_pick_head(the_repository))) {
|
||||||
whence = FROM_CHERRY_PICK;
|
whence = FROM_CHERRY_PICK;
|
||||||
if (file_exists(git_path_seq_dir()))
|
if (file_exists(git_path_seq_dir()))
|
||||||
sequencer_in_use = 1;
|
sequencer_in_use = 1;
|
||||||
@ -718,21 +718,21 @@ static int prepare_to_commit(const char *index_file, const char *prefix,
|
|||||||
if (have_option_m)
|
if (have_option_m)
|
||||||
strbuf_addbuf(&sb, &message);
|
strbuf_addbuf(&sb, &message);
|
||||||
hook_arg1 = "message";
|
hook_arg1 = "message";
|
||||||
} else if (!stat(git_path_merge_msg(), &statbuf)) {
|
} else if (!stat(git_path_merge_msg(the_repository), &statbuf)) {
|
||||||
/*
|
/*
|
||||||
* prepend SQUASH_MSG here if it exists and a
|
* prepend SQUASH_MSG here if it exists and a
|
||||||
* "merge --squash" was originally performed
|
* "merge --squash" was originally performed
|
||||||
*/
|
*/
|
||||||
if (!stat(git_path_squash_msg(), &statbuf)) {
|
if (!stat(git_path_squash_msg(the_repository), &statbuf)) {
|
||||||
if (strbuf_read_file(&sb, git_path_squash_msg(), 0) < 0)
|
if (strbuf_read_file(&sb, git_path_squash_msg(the_repository), 0) < 0)
|
||||||
die_errno(_("could not read SQUASH_MSG"));
|
die_errno(_("could not read SQUASH_MSG"));
|
||||||
hook_arg1 = "squash";
|
hook_arg1 = "squash";
|
||||||
} else
|
} else
|
||||||
hook_arg1 = "merge";
|
hook_arg1 = "merge";
|
||||||
if (strbuf_read_file(&sb, git_path_merge_msg(), 0) < 0)
|
if (strbuf_read_file(&sb, git_path_merge_msg(the_repository), 0) < 0)
|
||||||
die_errno(_("could not read MERGE_MSG"));
|
die_errno(_("could not read MERGE_MSG"));
|
||||||
} else if (!stat(git_path_squash_msg(), &statbuf)) {
|
} else if (!stat(git_path_squash_msg(the_repository), &statbuf)) {
|
||||||
if (strbuf_read_file(&sb, git_path_squash_msg(), 0) < 0)
|
if (strbuf_read_file(&sb, git_path_squash_msg(the_repository), 0) < 0)
|
||||||
die_errno(_("could not read SQUASH_MSG"));
|
die_errno(_("could not read SQUASH_MSG"));
|
||||||
hook_arg1 = "squash";
|
hook_arg1 = "squash";
|
||||||
} else if (template_file) {
|
} else if (template_file) {
|
||||||
@ -813,8 +813,8 @@ static int prepare_to_commit(const char *index_file, const char *prefix,
|
|||||||
" %s\n"
|
" %s\n"
|
||||||
"and try again.\n"),
|
"and try again.\n"),
|
||||||
whence == FROM_MERGE ?
|
whence == FROM_MERGE ?
|
||||||
git_path_merge_head() :
|
git_path_merge_head(the_repository) :
|
||||||
git_path_cherry_pick_head());
|
git_path_cherry_pick_head(the_repository));
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(s->fp, "\n");
|
fprintf(s->fp, "\n");
|
||||||
@ -1564,7 +1564,7 @@ int cmd_commit(int argc, const char **argv, const char *prefix)
|
|||||||
if (!reflog_msg)
|
if (!reflog_msg)
|
||||||
reflog_msg = "commit (merge)";
|
reflog_msg = "commit (merge)";
|
||||||
pptr = commit_list_append(current_head, pptr);
|
pptr = commit_list_append(current_head, pptr);
|
||||||
fp = xfopen(git_path_merge_head(), "r");
|
fp = xfopen(git_path_merge_head(the_repository), "r");
|
||||||
while (strbuf_getline_lf(&m, fp) != EOF) {
|
while (strbuf_getline_lf(&m, fp) != EOF) {
|
||||||
struct commit *parent;
|
struct commit *parent;
|
||||||
|
|
||||||
@ -1575,8 +1575,8 @@ int cmd_commit(int argc, const char **argv, const char *prefix)
|
|||||||
}
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
strbuf_release(&m);
|
strbuf_release(&m);
|
||||||
if (!stat(git_path_merge_mode(), &statbuf)) {
|
if (!stat(git_path_merge_mode(the_repository), &statbuf)) {
|
||||||
if (strbuf_read_file(&sb, git_path_merge_mode(), 0) < 0)
|
if (strbuf_read_file(&sb, git_path_merge_mode(the_repository), 0) < 0)
|
||||||
die_errno(_("could not read MERGE_MODE"));
|
die_errno(_("could not read MERGE_MODE"));
|
||||||
if (!strcmp(sb.buf, "no-ff"))
|
if (!strcmp(sb.buf, "no-ff"))
|
||||||
allow_fast_forward = 0;
|
allow_fast_forward = 0;
|
||||||
@ -1639,12 +1639,12 @@ int cmd_commit(int argc, const char **argv, const char *prefix)
|
|||||||
die("%s", err.buf);
|
die("%s", err.buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
unlink(git_path_cherry_pick_head());
|
unlink(git_path_cherry_pick_head(the_repository));
|
||||||
unlink(git_path_revert_head());
|
unlink(git_path_revert_head(the_repository));
|
||||||
unlink(git_path_merge_head());
|
unlink(git_path_merge_head(the_repository));
|
||||||
unlink(git_path_merge_msg());
|
unlink(git_path_merge_msg(the_repository));
|
||||||
unlink(git_path_merge_mode());
|
unlink(git_path_merge_mode(the_repository));
|
||||||
unlink(git_path_squash_msg());
|
unlink(git_path_squash_msg(the_repository));
|
||||||
|
|
||||||
if (commit_index_files())
|
if (commit_index_files())
|
||||||
die (_("Repository has been updated, but unable to write\n"
|
die (_("Repository has been updated, but unable to write\n"
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "argv-array.h"
|
#include "argv-array.h"
|
||||||
#include "run-command.h"
|
#include "run-command.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "revision.h"
|
#include "revision.h"
|
||||||
#include "list-objects.h"
|
#include "list-objects.h"
|
||||||
#include "commit-slab.h"
|
#include "commit-slab.h"
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
#include "argv-array.h"
|
#include "argv-array.h"
|
||||||
#include "strbuf.h"
|
#include "strbuf.h"
|
||||||
#include "lockfile.h"
|
#include "lockfile.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
|
|
||||||
static char *diff_gui_tool;
|
static char *diff_gui_tool;
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "refspec.h"
|
#include "refspec.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#include "repository.h"
|
#include "repository.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "refspec.h"
|
#include "refspec.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "string-list.h"
|
#include "string-list.h"
|
||||||
@ -777,7 +778,7 @@ static int store_updated_refs(const char *raw_url, const char *remote_name,
|
|||||||
const char *what, *kind;
|
const char *what, *kind;
|
||||||
struct ref *rm;
|
struct ref *rm;
|
||||||
char *url;
|
char *url;
|
||||||
const char *filename = dry_run ? "/dev/null" : git_path_fetch_head();
|
const char *filename = dry_run ? "/dev/null" : git_path_fetch_head(the_repository);
|
||||||
int want_status;
|
int want_status;
|
||||||
int summary_width = transport_summary_width(ref_map);
|
int summary_width = transport_summary_width(ref_map);
|
||||||
|
|
||||||
@ -1029,7 +1030,7 @@ static void check_not_current_branch(struct ref *ref_map)
|
|||||||
|
|
||||||
static int truncate_fetch_head(void)
|
static int truncate_fetch_head(void)
|
||||||
{
|
{
|
||||||
const char *filename = git_path_fetch_head();
|
const char *filename = git_path_fetch_head(the_repository);
|
||||||
FILE *fp = fopen_for_writing(filename);
|
FILE *fp = fopen_for_writing(filename);
|
||||||
|
|
||||||
if (!fp)
|
if (!fp)
|
||||||
@ -1449,7 +1450,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
|
|||||||
if (unshallow) {
|
if (unshallow) {
|
||||||
if (depth)
|
if (depth)
|
||||||
die(_("--depth and --unshallow cannot be used together"));
|
die(_("--depth and --unshallow cannot be used together"));
|
||||||
else if (!is_repository_shallow())
|
else if (!is_repository_shallow(the_repository))
|
||||||
die(_("--unshallow on a complete repository does not make sense"));
|
die(_("--unshallow on a complete repository does not make sense"));
|
||||||
else
|
else
|
||||||
depth = xstrfmt("%d", INFINITE_DEPTH);
|
depth = xstrfmt("%d", INFINITE_DEPTH);
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
#include "revision.h"
|
#include "revision.h"
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
*/
|
*/
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "quote.h"
|
#include "quote.h"
|
||||||
#include "parse-options.h"
|
#include "parse-options.h"
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "color.h"
|
#include "color.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
*/
|
*/
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
#include "xdiff-interface.h"
|
#include "xdiff-interface.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "exec-cmd.h"
|
#include "exec-cmd.h"
|
||||||
#include "merge-blobs.h"
|
#include "merge-blobs.h"
|
||||||
|
@ -247,9 +247,9 @@ static struct option builtin_merge_options[] = {
|
|||||||
/* Cleans up metadata that is uninteresting after a succeeded merge. */
|
/* Cleans up metadata that is uninteresting after a succeeded merge. */
|
||||||
static void drop_save(void)
|
static void drop_save(void)
|
||||||
{
|
{
|
||||||
unlink(git_path_merge_head());
|
unlink(git_path_merge_head(the_repository));
|
||||||
unlink(git_path_merge_msg());
|
unlink(git_path_merge_msg(the_repository));
|
||||||
unlink(git_path_merge_mode());
|
unlink(git_path_merge_mode(the_repository));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int save_state(struct object_id *stash)
|
static int save_state(struct object_id *stash)
|
||||||
@ -382,7 +382,7 @@ static void squash_message(struct commit *commit, struct commit_list *remotehead
|
|||||||
oid_to_hex(&commit->object.oid));
|
oid_to_hex(&commit->object.oid));
|
||||||
pretty_print_commit(&ctx, commit, &out);
|
pretty_print_commit(&ctx, commit, &out);
|
||||||
}
|
}
|
||||||
write_file_buf(git_path_squash_msg(), out.buf, out.len);
|
write_file_buf(git_path_squash_msg(the_repository), out.buf, out.len);
|
||||||
strbuf_release(&out);
|
strbuf_release(&out);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -741,7 +741,7 @@ static void add_strategies(const char *string, unsigned attr)
|
|||||||
|
|
||||||
static void read_merge_msg(struct strbuf *msg)
|
static void read_merge_msg(struct strbuf *msg)
|
||||||
{
|
{
|
||||||
const char *filename = git_path_merge_msg();
|
const char *filename = git_path_merge_msg(the_repository);
|
||||||
strbuf_reset(msg);
|
strbuf_reset(msg);
|
||||||
if (strbuf_read_file(msg, filename, 0) < 0)
|
if (strbuf_read_file(msg, filename, 0) < 0)
|
||||||
die_errno(_("Could not read from '%s'"), filename);
|
die_errno(_("Could not read from '%s'"), filename);
|
||||||
@ -778,18 +778,18 @@ static void prepare_to_commit(struct commit_list *remoteheads)
|
|||||||
if (signoff)
|
if (signoff)
|
||||||
append_signoff(&msg, ignore_non_trailer(msg.buf, msg.len), 0);
|
append_signoff(&msg, ignore_non_trailer(msg.buf, msg.len), 0);
|
||||||
write_merge_heads(remoteheads);
|
write_merge_heads(remoteheads);
|
||||||
write_file_buf(git_path_merge_msg(), msg.buf, msg.len);
|
write_file_buf(git_path_merge_msg(the_repository), msg.buf, msg.len);
|
||||||
if (run_commit_hook(0 < option_edit, get_index_file(), "prepare-commit-msg",
|
if (run_commit_hook(0 < option_edit, get_index_file(), "prepare-commit-msg",
|
||||||
git_path_merge_msg(), "merge", NULL))
|
git_path_merge_msg(the_repository), "merge", NULL))
|
||||||
abort_commit(remoteheads, NULL);
|
abort_commit(remoteheads, NULL);
|
||||||
if (0 < option_edit) {
|
if (0 < option_edit) {
|
||||||
if (launch_editor(git_path_merge_msg(), NULL, NULL))
|
if (launch_editor(git_path_merge_msg(the_repository), NULL, NULL))
|
||||||
abort_commit(remoteheads, NULL);
|
abort_commit(remoteheads, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (verify_msg && run_commit_hook(0 < option_edit, get_index_file(),
|
if (verify_msg && run_commit_hook(0 < option_edit, get_index_file(),
|
||||||
"commit-msg",
|
"commit-msg",
|
||||||
git_path_merge_msg(), NULL))
|
git_path_merge_msg(the_repository), NULL))
|
||||||
abort_commit(remoteheads, NULL);
|
abort_commit(remoteheads, NULL);
|
||||||
|
|
||||||
read_merge_msg(&msg);
|
read_merge_msg(&msg);
|
||||||
@ -859,7 +859,7 @@ static int suggest_conflicts(void)
|
|||||||
FILE *fp;
|
FILE *fp;
|
||||||
struct strbuf msgbuf = STRBUF_INIT;
|
struct strbuf msgbuf = STRBUF_INIT;
|
||||||
|
|
||||||
filename = git_path_merge_msg();
|
filename = git_path_merge_msg(the_repository);
|
||||||
fp = xfopen(filename, "a");
|
fp = xfopen(filename, "a");
|
||||||
|
|
||||||
append_conflicts_hint(&msgbuf);
|
append_conflicts_hint(&msgbuf);
|
||||||
@ -942,12 +942,12 @@ static void write_merge_heads(struct commit_list *remoteheads)
|
|||||||
}
|
}
|
||||||
strbuf_addf(&buf, "%s\n", oid_to_hex(oid));
|
strbuf_addf(&buf, "%s\n", oid_to_hex(oid));
|
||||||
}
|
}
|
||||||
write_file_buf(git_path_merge_head(), buf.buf, buf.len);
|
write_file_buf(git_path_merge_head(the_repository), buf.buf, buf.len);
|
||||||
|
|
||||||
strbuf_reset(&buf);
|
strbuf_reset(&buf);
|
||||||
if (fast_forward == FF_NO)
|
if (fast_forward == FF_NO)
|
||||||
strbuf_addstr(&buf, "no-ff");
|
strbuf_addstr(&buf, "no-ff");
|
||||||
write_file_buf(git_path_merge_mode(), buf.buf, buf.len);
|
write_file_buf(git_path_merge_mode(the_repository), buf.buf, buf.len);
|
||||||
strbuf_release(&buf);
|
strbuf_release(&buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -955,7 +955,8 @@ static void write_merge_state(struct commit_list *remoteheads)
|
|||||||
{
|
{
|
||||||
write_merge_heads(remoteheads);
|
write_merge_heads(remoteheads);
|
||||||
strbuf_addch(&merge_msg, '\n');
|
strbuf_addch(&merge_msg, '\n');
|
||||||
write_file_buf(git_path_merge_msg(), merge_msg.buf, merge_msg.len);
|
write_file_buf(git_path_merge_msg(the_repository), merge_msg.buf,
|
||||||
|
merge_msg.len);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int default_edit_option(void)
|
static int default_edit_option(void)
|
||||||
@ -1038,7 +1039,7 @@ static void handle_fetch_head(struct commit_list **remotes, struct strbuf *merge
|
|||||||
if (!merge_names)
|
if (!merge_names)
|
||||||
merge_names = &fetch_head_file;
|
merge_names = &fetch_head_file;
|
||||||
|
|
||||||
filename = git_path_fetch_head();
|
filename = git_path_fetch_head(the_repository);
|
||||||
fd = open(filename, O_RDONLY);
|
fd = open(filename, O_RDONLY);
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
die_errno(_("could not open '%s' for reading"), filename);
|
die_errno(_("could not open '%s' for reading"), filename);
|
||||||
@ -1213,7 +1214,7 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
|
|||||||
usage_msg_opt(_("--abort expects no arguments"),
|
usage_msg_opt(_("--abort expects no arguments"),
|
||||||
builtin_merge_usage, builtin_merge_options);
|
builtin_merge_usage, builtin_merge_options);
|
||||||
|
|
||||||
if (!file_exists(git_path_merge_head()))
|
if (!file_exists(git_path_merge_head(the_repository)))
|
||||||
die(_("There is no merge to abort (MERGE_HEAD missing)."));
|
die(_("There is no merge to abort (MERGE_HEAD missing)."));
|
||||||
|
|
||||||
/* Invoke 'git reset --merge' */
|
/* Invoke 'git reset --merge' */
|
||||||
@ -1229,7 +1230,7 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
|
|||||||
usage_msg_opt(_("--continue expects no arguments"),
|
usage_msg_opt(_("--continue expects no arguments"),
|
||||||
builtin_merge_usage, builtin_merge_options);
|
builtin_merge_usage, builtin_merge_options);
|
||||||
|
|
||||||
if (!file_exists(git_path_merge_head()))
|
if (!file_exists(git_path_merge_head(the_repository)))
|
||||||
die(_("There is no merge in progress (MERGE_HEAD missing)."));
|
die(_("There is no merge in progress (MERGE_HEAD missing)."));
|
||||||
|
|
||||||
/* Invoke 'git commit' */
|
/* Invoke 'git commit' */
|
||||||
@ -1240,7 +1241,7 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
|
|||||||
if (read_cache_unmerged())
|
if (read_cache_unmerged())
|
||||||
die_resolve_conflict("merge");
|
die_resolve_conflict("merge");
|
||||||
|
|
||||||
if (file_exists(git_path_merge_head())) {
|
if (file_exists(git_path_merge_head(the_repository))) {
|
||||||
/*
|
/*
|
||||||
* There is no unmerged entry, don't advise 'git
|
* There is no unmerged entry, don't advise 'git
|
||||||
* add/rm <file>', just 'git commit'.
|
* add/rm <file>', just 'git commit'.
|
||||||
@ -1251,7 +1252,7 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
|
|||||||
else
|
else
|
||||||
die(_("You have not concluded your merge (MERGE_HEAD exists)."));
|
die(_("You have not concluded your merge (MERGE_HEAD exists)."));
|
||||||
}
|
}
|
||||||
if (file_exists(git_path_cherry_pick_head())) {
|
if (file_exists(git_path_cherry_pick_head(the_repository))) {
|
||||||
if (advice_resolve_conflict)
|
if (advice_resolve_conflict)
|
||||||
die(_("You have not concluded your cherry-pick (CHERRY_PICK_HEAD exists).\n"
|
die(_("You have not concluded your cherry-pick (CHERRY_PICK_HEAD exists).\n"
|
||||||
"Please, commit your changes before you merge."));
|
"Please, commit your changes before you merge."));
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "replace-object.h"
|
#include "replace-object.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* A signature file has a very simple fixed format: four lines
|
* A signature file has a very simple fixed format: four lines
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
#include "quote.h"
|
#include "quote.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "parse-options.h"
|
#include "parse-options.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
static struct treeent {
|
static struct treeent {
|
||||||
unsigned mode;
|
unsigned mode;
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "notes.h"
|
#include "notes.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "pretty.h"
|
#include "pretty.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
@ -2969,7 +2969,7 @@ static void get_object_list(int ac, const char **av)
|
|||||||
setup_revisions(ac, av, &revs, NULL);
|
setup_revisions(ac, av, &revs, NULL);
|
||||||
|
|
||||||
/* make sure shallows are read */
|
/* make sure shallows are read */
|
||||||
is_repository_shallow();
|
is_repository_shallow(the_repository);
|
||||||
|
|
||||||
while (fgets(line, sizeof(line), stdin) != NULL) {
|
while (fgets(line, sizeof(line), stdin) != NULL) {
|
||||||
int len = strlen(line);
|
int len = strlen(line);
|
||||||
@ -2987,7 +2987,7 @@ static void get_object_list(int ac, const char **av)
|
|||||||
struct object_id oid;
|
struct object_id oid;
|
||||||
if (get_oid_hex(line + 10, &oid))
|
if (get_oid_hex(line + 10, &oid))
|
||||||
die("not an SHA-1 '%s'", line + 10);
|
die("not an SHA-1 '%s'", line + 10);
|
||||||
register_shallow(&oid);
|
register_shallow(the_repository, &oid);
|
||||||
use_bitmap_index = 0;
|
use_bitmap_index = 0;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -3299,7 +3299,7 @@ int cmd_pack_objects(int argc, const char **argv, const char *prefix)
|
|||||||
use_bitmap_index = use_bitmap_index_default;
|
use_bitmap_index = use_bitmap_index_default;
|
||||||
|
|
||||||
/* "hard" reasons not to use bitmaps; these just won't work at all */
|
/* "hard" reasons not to use bitmaps; these just won't work at all */
|
||||||
if (!use_internal_rev_list || (!pack_to_stdout && write_bitmap_index) || is_repository_shallow())
|
if (!use_internal_rev_list || (!pack_to_stdout && write_bitmap_index) || is_repository_shallow(the_repository))
|
||||||
use_bitmap_index = 0;
|
use_bitmap_index = 0;
|
||||||
|
|
||||||
if (pack_to_stdout || !rev_list_all)
|
if (pack_to_stdout || !rev_list_all)
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#include "reachable.h"
|
#include "reachable.h"
|
||||||
#include "parse-options.h"
|
#include "parse-options.h"
|
||||||
#include "progress.h"
|
#include "progress.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
static const char * const prune_usage[] = {
|
static const char * const prune_usage[] = {
|
||||||
N_("git prune [-n] [-v] [--progress] [--expire <time>] [--] [<head>...]"),
|
N_("git prune [-n] [-v] [--progress] [--expire <time>] [--] [<head>...]"),
|
||||||
@ -159,7 +160,7 @@ int cmd_prune(int argc, const char **argv, const char *prefix)
|
|||||||
remove_temporary_files(s);
|
remove_temporary_files(s);
|
||||||
free(s);
|
free(s);
|
||||||
|
|
||||||
if (is_repository_shallow())
|
if (is_repository_shallow(the_repository))
|
||||||
prune_shallow(show_only);
|
prune_shallow(show_only);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -356,7 +356,7 @@ static int git_pull_config(const char *var, const char *value, void *cb)
|
|||||||
*/
|
*/
|
||||||
static void get_merge_heads(struct oid_array *merge_heads)
|
static void get_merge_heads(struct oid_array *merge_heads)
|
||||||
{
|
{
|
||||||
const char *filename = git_path_fetch_head();
|
const char *filename = git_path_fetch_head(the_repository);
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
struct strbuf sb = STRBUF_INIT;
|
struct strbuf sb = STRBUF_INIT;
|
||||||
struct object_id oid;
|
struct object_id oid;
|
||||||
@ -864,7 +864,7 @@ int cmd_pull(int argc, const char **argv, const char *prefix)
|
|||||||
if (read_cache_unmerged())
|
if (read_cache_unmerged())
|
||||||
die_resolve_conflict("pull");
|
die_resolve_conflict("pull");
|
||||||
|
|
||||||
if (file_exists(git_path_merge_head()))
|
if (file_exists(git_path_merge_head(the_repository)))
|
||||||
die_conclude_merge();
|
die_conclude_merge();
|
||||||
|
|
||||||
if (get_oid("HEAD", &orig_head))
|
if (get_oid("HEAD", &orig_head))
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#include "tmp-objdir.h"
|
#include "tmp-objdir.h"
|
||||||
#include "oidset.h"
|
#include "oidset.h"
|
||||||
#include "packfile.h"
|
#include "packfile.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "protocol.h"
|
#include "protocol.h"
|
||||||
|
|
||||||
static const char * const receive_pack_usage[] = {
|
static const char * const receive_pack_usage[] = {
|
||||||
@ -905,7 +906,7 @@ static int update_shallow_ref(struct command *cmd, struct shallow_info *si)
|
|||||||
* not lose these new roots..
|
* not lose these new roots..
|
||||||
*/
|
*/
|
||||||
for (i = 0; i < extra.nr; i++)
|
for (i = 0; i < extra.nr; i++)
|
||||||
register_shallow(&extra.oid[i]);
|
register_shallow(the_repository, &extra.oid[i]);
|
||||||
|
|
||||||
si->shallow_ref[cmd->index] = 0;
|
si->shallow_ref[cmd->index] = 0;
|
||||||
oid_array_clear(&extra);
|
oid_array_clear(&extra);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "lockfile.h"
|
#include "lockfile.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include "run-command.h"
|
#include "run-command.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "refspec.h"
|
#include "refspec.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "argv-array.h"
|
#include "argv-array.h"
|
||||||
|
|
||||||
static const char * const builtin_remote_usage[] = {
|
static const char * const builtin_remote_usage[] = {
|
||||||
|
@ -487,7 +487,7 @@ static int create_graft(int argc, const char **argv, int force, int gentle)
|
|||||||
|
|
||||||
static int convert_graft_file(int force)
|
static int convert_graft_file(int force)
|
||||||
{
|
{
|
||||||
const char *graft_file = get_graft_file();
|
const char *graft_file = get_graft_file(the_repository);
|
||||||
FILE *fp = fopen_or_warn(graft_file, "r");
|
FILE *fp = fopen_or_warn(graft_file, "r");
|
||||||
struct strbuf buf = STRBUF_INIT, err = STRBUF_INIT;
|
struct strbuf buf = STRBUF_INIT, err = STRBUF_INIT;
|
||||||
struct argv_array args = ARGV_ARRAY_INIT;
|
struct argv_array args = ARGV_ARRAY_INIT;
|
||||||
|
@ -39,7 +39,7 @@ static const char *reset_type_names[] = {
|
|||||||
|
|
||||||
static inline int is_merge(void)
|
static inline int is_merge(void)
|
||||||
{
|
{
|
||||||
return !access(git_path_merge_head(), F_OK);
|
return !access(git_path_merge_head(the_repository), F_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int reset_index(const struct object_id *oid, int reset_type, int quiet)
|
static int reset_index(const struct object_id *oid, int reset_type, int quiet)
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#include "list-objects.h"
|
#include "list-objects.h"
|
||||||
#include "list-objects-filter.h"
|
#include "list-objects-filter.h"
|
||||||
#include "list-objects-filter-options.h"
|
#include "list-objects-filter-options.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "pack.h"
|
#include "pack.h"
|
||||||
#include "pack-bitmap.h"
|
#include "pack-bitmap.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
|
@ -883,7 +883,8 @@ int cmd_rev_parse(int argc, const char **argv, const char *prefix)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!strcmp(arg, "--is-shallow-repository")) {
|
if (!strcmp(arg, "--is-shallow-repository")) {
|
||||||
printf("%s\n", is_repository_shallow() ? "true"
|
printf("%s\n",
|
||||||
|
is_repository_shallow(the_repository) ? "true"
|
||||||
: "false");
|
: "false");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "string-list.h"
|
#include "string-list.h"
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "run-command.h"
|
#include "run-command.h"
|
||||||
#include "parse-options.h"
|
#include "parse-options.h"
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
static char *create_temp_file(struct object_id *oid)
|
static char *create_temp_file(struct object_id *oid)
|
||||||
{
|
{
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "delta.h"
|
#include "delta.h"
|
||||||
#include "pack.h"
|
#include "pack.h"
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "run-command.h"
|
#include "run-command.h"
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include "pack.h"
|
#include "pack.h"
|
||||||
#include "strbuf.h"
|
#include "strbuf.h"
|
||||||
#include "packfile.h"
|
#include "packfile.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
static struct bulk_checkin_state {
|
static struct bulk_checkin_state {
|
||||||
unsigned plugged:1;
|
unsigned plugged:1;
|
||||||
|
1
bundle.c
1
bundle.c
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "lockfile.h"
|
#include "lockfile.h"
|
||||||
#include "bundle.h"
|
#include "bundle.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
#include "cache-tree.h"
|
#include "cache-tree.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
#ifndef DEBUG
|
#ifndef DEBUG
|
||||||
#define DEBUG 0
|
#define DEBUG 0
|
||||||
|
119
cache.h
119
cache.h
@ -484,7 +484,7 @@ extern const char *get_git_dir(void);
|
|||||||
extern const char *get_git_common_dir(void);
|
extern const char *get_git_common_dir(void);
|
||||||
extern char *get_object_directory(void);
|
extern char *get_object_directory(void);
|
||||||
extern char *get_index_file(void);
|
extern char *get_index_file(void);
|
||||||
extern char *get_graft_file(void);
|
extern char *get_graft_file(struct repository *r);
|
||||||
extern void set_git_dir(const char *path);
|
extern void set_git_dir(const char *path);
|
||||||
extern int get_common_dir_noenv(struct strbuf *sb, const char *gitdir);
|
extern int get_common_dir_noenv(struct strbuf *sb, const char *gitdir);
|
||||||
extern int get_common_dir(struct strbuf *sb, const char *gitdir);
|
extern int get_common_dir(struct strbuf *sb, const char *gitdir);
|
||||||
@ -1192,32 +1192,6 @@ extern char *xdg_config_home(const char *filename);
|
|||||||
*/
|
*/
|
||||||
extern char *xdg_cache_home(const char *filename);
|
extern char *xdg_cache_home(const char *filename);
|
||||||
|
|
||||||
extern void *read_object_file_extended(const struct object_id *oid,
|
|
||||||
enum object_type *type,
|
|
||||||
unsigned long *size, int lookup_replace);
|
|
||||||
static inline void *read_object_file(const struct object_id *oid, enum object_type *type, unsigned long *size)
|
|
||||||
{
|
|
||||||
return read_object_file_extended(oid, type, size, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Read and unpack an object file into memory, write memory to an object file */
|
|
||||||
int oid_object_info(struct repository *r, const struct object_id *, unsigned long *);
|
|
||||||
|
|
||||||
extern int hash_object_file(const void *buf, unsigned long len,
|
|
||||||
const char *type, struct object_id *oid);
|
|
||||||
|
|
||||||
extern int write_object_file(const void *buf, unsigned long len,
|
|
||||||
const char *type, struct object_id *oid);
|
|
||||||
|
|
||||||
extern int hash_object_file_literally(const void *buf, unsigned long len,
|
|
||||||
const char *type, struct object_id *oid,
|
|
||||||
unsigned flags);
|
|
||||||
|
|
||||||
extern int pretend_object_file(void *, unsigned long, enum object_type,
|
|
||||||
struct object_id *oid);
|
|
||||||
|
|
||||||
extern int force_object_loose(const struct object_id *oid, time_t mtime);
|
|
||||||
|
|
||||||
extern int git_open_cloexec(const char *name, int flags);
|
extern int git_open_cloexec(const char *name, int flags);
|
||||||
#define git_open(name) git_open_cloexec(name, O_RDONLY)
|
#define git_open(name) git_open_cloexec(name, O_RDONLY)
|
||||||
extern int unpack_sha1_header(git_zstream *stream, unsigned char *map, unsigned long mapsize, void *buffer, unsigned long bufsiz);
|
extern int unpack_sha1_header(git_zstream *stream, unsigned char *map, unsigned long mapsize, void *buffer, unsigned long bufsiz);
|
||||||
@ -1227,43 +1201,6 @@ extern int check_object_signature(const struct object_id *oid, void *buf, unsign
|
|||||||
|
|
||||||
extern int finalize_object_file(const char *tmpfile, const char *filename);
|
extern int finalize_object_file(const char *tmpfile, const char *filename);
|
||||||
|
|
||||||
/*
|
|
||||||
* Open the loose object at path, check its hash, and return the contents,
|
|
||||||
* type, and size. If the object is a blob, then "contents" may return NULL,
|
|
||||||
* to allow streaming of large blobs.
|
|
||||||
*
|
|
||||||
* Returns 0 on success, negative on error (details may be written to stderr).
|
|
||||||
*/
|
|
||||||
int read_loose_object(const char *path,
|
|
||||||
const struct object_id *expected_oid,
|
|
||||||
enum object_type *type,
|
|
||||||
unsigned long *size,
|
|
||||||
void **contents);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Convenience for sha1_object_info_extended() with a NULL struct
|
|
||||||
* object_info. OBJECT_INFO_SKIP_CACHED is automatically set; pass
|
|
||||||
* nonzero flags to also set other flags.
|
|
||||||
*/
|
|
||||||
extern int has_sha1_file_with_flags(const unsigned char *sha1, int flags);
|
|
||||||
static inline int has_sha1_file(const unsigned char *sha1)
|
|
||||||
{
|
|
||||||
return has_sha1_file_with_flags(sha1, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Same as the above, except for struct object_id. */
|
|
||||||
extern int has_object_file(const struct object_id *oid);
|
|
||||||
extern int has_object_file_with_flags(const struct object_id *oid, int flags);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Return true iff an alternate object database has a loose object
|
|
||||||
* with the specified name. This function does not respect replace
|
|
||||||
* references.
|
|
||||||
*/
|
|
||||||
extern int has_loose_object_nonlocal(const struct object_id *oid);
|
|
||||||
|
|
||||||
extern void assert_oid_type(const struct object_id *oid, enum object_type expect);
|
|
||||||
|
|
||||||
/* Helper to check and "touch" a file */
|
/* Helper to check and "touch" a file */
|
||||||
extern int check_and_freshen_file(const char *fn, int freshen);
|
extern int check_and_freshen_file(const char *fn, int freshen);
|
||||||
|
|
||||||
@ -1631,60 +1568,6 @@ int for_each_loose_file_in_objdir_buf(struct strbuf *path,
|
|||||||
#define FOR_EACH_OBJECT_LOCAL_ONLY 0x1
|
#define FOR_EACH_OBJECT_LOCAL_ONLY 0x1
|
||||||
extern int for_each_loose_object(each_loose_object_fn, void *, unsigned flags);
|
extern int for_each_loose_object(each_loose_object_fn, void *, unsigned flags);
|
||||||
|
|
||||||
struct object_info {
|
|
||||||
/* Request */
|
|
||||||
enum object_type *typep;
|
|
||||||
unsigned long *sizep;
|
|
||||||
off_t *disk_sizep;
|
|
||||||
unsigned char *delta_base_sha1;
|
|
||||||
struct strbuf *type_name;
|
|
||||||
void **contentp;
|
|
||||||
|
|
||||||
/* Response */
|
|
||||||
enum {
|
|
||||||
OI_CACHED,
|
|
||||||
OI_LOOSE,
|
|
||||||
OI_PACKED,
|
|
||||||
OI_DBCACHED
|
|
||||||
} whence;
|
|
||||||
union {
|
|
||||||
/*
|
|
||||||
* struct {
|
|
||||||
* ... Nothing to expose in this case
|
|
||||||
* } cached;
|
|
||||||
* struct {
|
|
||||||
* ... Nothing to expose in this case
|
|
||||||
* } loose;
|
|
||||||
*/
|
|
||||||
struct {
|
|
||||||
struct packed_git *pack;
|
|
||||||
off_t offset;
|
|
||||||
unsigned int is_delta;
|
|
||||||
} packed;
|
|
||||||
} u;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Initializer for a "struct object_info" that wants no items. You may
|
|
||||||
* also memset() the memory to all-zeroes.
|
|
||||||
*/
|
|
||||||
#define OBJECT_INFO_INIT {NULL}
|
|
||||||
|
|
||||||
/* Invoke lookup_replace_object() on the given hash */
|
|
||||||
#define OBJECT_INFO_LOOKUP_REPLACE 1
|
|
||||||
/* Allow reading from a loose object file of unknown/bogus type */
|
|
||||||
#define OBJECT_INFO_ALLOW_UNKNOWN_TYPE 2
|
|
||||||
/* Do not check cached storage */
|
|
||||||
#define OBJECT_INFO_SKIP_CACHED 4
|
|
||||||
/* Do not retry packed storage after checking packed and loose storage */
|
|
||||||
#define OBJECT_INFO_QUICK 8
|
|
||||||
/* Do not check loose object */
|
|
||||||
#define OBJECT_INFO_IGNORE_LOOSE 16
|
|
||||||
|
|
||||||
int oid_object_info_extended(struct repository *r,
|
|
||||||
const struct object_id *,
|
|
||||||
struct object_info *, unsigned flags);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Set this to 0 to prevent sha1_object_info_extended() from fetching missing
|
* Set this to 0 to prevent sha1_object_info_extended() from fetching missing
|
||||||
* blobs. This has a difference only if extensions.partialClone is set.
|
* blobs. This has a difference only if extensions.partialClone is set.
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
|
77
commit.c
77
commit.c
@ -2,6 +2,8 @@
|
|||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "commit-graph.h"
|
#include "commit-graph.h"
|
||||||
|
#include "repository.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "pkt-line.h"
|
#include "pkt-line.h"
|
||||||
#include "utf8.h"
|
#include "utf8.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
@ -98,41 +100,44 @@ static timestamp_t parse_commit_date(const char *buf, const char *tail)
|
|||||||
return parse_timestamp(dateptr, NULL, 10);
|
return parse_timestamp(dateptr, NULL, 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct commit_graft **commit_graft;
|
|
||||||
static int commit_graft_alloc, commit_graft_nr;
|
|
||||||
|
|
||||||
static const unsigned char *commit_graft_sha1_access(size_t index, void *table)
|
static const unsigned char *commit_graft_sha1_access(size_t index, void *table)
|
||||||
{
|
{
|
||||||
struct commit_graft **commit_graft_table = table;
|
struct commit_graft **commit_graft_table = table;
|
||||||
return commit_graft_table[index]->oid.hash;
|
return commit_graft_table[index]->oid.hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int commit_graft_pos(const unsigned char *sha1)
|
static int commit_graft_pos(struct repository *r, const unsigned char *sha1)
|
||||||
{
|
{
|
||||||
return sha1_pos(sha1, commit_graft, commit_graft_nr,
|
return sha1_pos(sha1, r->parsed_objects->grafts,
|
||||||
|
r->parsed_objects->grafts_nr,
|
||||||
commit_graft_sha1_access);
|
commit_graft_sha1_access);
|
||||||
}
|
}
|
||||||
|
|
||||||
int register_commit_graft(struct commit_graft *graft, int ignore_dups)
|
int register_commit_graft(struct repository *r, struct commit_graft *graft,
|
||||||
|
int ignore_dups)
|
||||||
{
|
{
|
||||||
int pos = commit_graft_pos(graft->oid.hash);
|
int pos = commit_graft_pos(r, graft->oid.hash);
|
||||||
|
|
||||||
if (0 <= pos) {
|
if (0 <= pos) {
|
||||||
if (ignore_dups)
|
if (ignore_dups)
|
||||||
free(graft);
|
free(graft);
|
||||||
else {
|
else {
|
||||||
free(commit_graft[pos]);
|
free(r->parsed_objects->grafts[pos]);
|
||||||
commit_graft[pos] = graft;
|
r->parsed_objects->grafts[pos] = graft;
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
pos = -pos - 1;
|
pos = -pos - 1;
|
||||||
ALLOC_GROW(commit_graft, commit_graft_nr + 1, commit_graft_alloc);
|
ALLOC_GROW(r->parsed_objects->grafts,
|
||||||
commit_graft_nr++;
|
r->parsed_objects->grafts_nr + 1,
|
||||||
if (pos < commit_graft_nr)
|
r->parsed_objects->grafts_alloc);
|
||||||
MOVE_ARRAY(commit_graft + pos + 1, commit_graft + pos,
|
r->parsed_objects->grafts_nr++;
|
||||||
commit_graft_nr - pos - 1);
|
if (pos < r->parsed_objects->grafts_nr)
|
||||||
commit_graft[pos] = graft;
|
memmove(r->parsed_objects->grafts + pos + 1,
|
||||||
|
r->parsed_objects->grafts + pos,
|
||||||
|
(r->parsed_objects->grafts_nr - pos - 1) *
|
||||||
|
sizeof(*r->parsed_objects->grafts));
|
||||||
|
r->parsed_objects->grafts[pos] = graft;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -174,7 +179,7 @@ bad_graft_data:
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int read_graft_file(const char *graft_file)
|
static int read_graft_file(struct repository *r, const char *graft_file)
|
||||||
{
|
{
|
||||||
FILE *fp = fopen_or_warn(graft_file, "r");
|
FILE *fp = fopen_or_warn(graft_file, "r");
|
||||||
struct strbuf buf = STRBUF_INIT;
|
struct strbuf buf = STRBUF_INIT;
|
||||||
@ -194,7 +199,7 @@ static int read_graft_file(const char *graft_file)
|
|||||||
struct commit_graft *graft = read_graft_line(&buf);
|
struct commit_graft *graft = read_graft_line(&buf);
|
||||||
if (!graft)
|
if (!graft)
|
||||||
continue;
|
continue;
|
||||||
if (register_commit_graft(graft, 1))
|
if (register_commit_graft(r, graft, 1))
|
||||||
error("duplicate graft data: %s", buf.buf);
|
error("duplicate graft data: %s", buf.buf);
|
||||||
}
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
@ -202,50 +207,50 @@ static int read_graft_file(const char *graft_file)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void prepare_commit_graft(void)
|
static void prepare_commit_graft(struct repository *r)
|
||||||
{
|
{
|
||||||
static int commit_graft_prepared;
|
|
||||||
char *graft_file;
|
char *graft_file;
|
||||||
|
|
||||||
if (commit_graft_prepared)
|
if (r->parsed_objects->commit_graft_prepared)
|
||||||
return;
|
return;
|
||||||
if (!startup_info->have_repository)
|
if (!startup_info->have_repository)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
graft_file = get_graft_file();
|
graft_file = get_graft_file(r);
|
||||||
read_graft_file(graft_file);
|
read_graft_file(r, graft_file);
|
||||||
/* make sure shallows are read */
|
/* make sure shallows are read */
|
||||||
is_repository_shallow();
|
is_repository_shallow(r);
|
||||||
commit_graft_prepared = 1;
|
r->parsed_objects->commit_graft_prepared = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct commit_graft *lookup_commit_graft(const struct object_id *oid)
|
struct commit_graft *lookup_commit_graft(struct repository *r, const struct object_id *oid)
|
||||||
{
|
{
|
||||||
int pos;
|
int pos;
|
||||||
prepare_commit_graft();
|
prepare_commit_graft(r);
|
||||||
pos = commit_graft_pos(oid->hash);
|
pos = commit_graft_pos(r, oid->hash);
|
||||||
if (pos < 0)
|
if (pos < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
return commit_graft[pos];
|
return r->parsed_objects->grafts[pos];
|
||||||
}
|
}
|
||||||
|
|
||||||
int for_each_commit_graft(each_commit_graft_fn fn, void *cb_data)
|
int for_each_commit_graft(each_commit_graft_fn fn, void *cb_data)
|
||||||
{
|
{
|
||||||
int i, ret;
|
int i, ret;
|
||||||
for (i = ret = 0; i < commit_graft_nr && !ret; i++)
|
for (i = ret = 0; i < the_repository->parsed_objects->grafts_nr && !ret; i++)
|
||||||
ret = fn(commit_graft[i], cb_data);
|
ret = fn(the_repository->parsed_objects->grafts[i], cb_data);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int unregister_shallow(const struct object_id *oid)
|
int unregister_shallow(const struct object_id *oid)
|
||||||
{
|
{
|
||||||
int pos = commit_graft_pos(oid->hash);
|
int pos = commit_graft_pos(the_repository, oid->hash);
|
||||||
if (pos < 0)
|
if (pos < 0)
|
||||||
return -1;
|
return -1;
|
||||||
if (pos + 1 < commit_graft_nr)
|
if (pos + 1 < the_repository->parsed_objects->grafts_nr)
|
||||||
MOVE_ARRAY(commit_graft + pos, commit_graft + pos + 1,
|
MOVE_ARRAY(the_repository->parsed_objects->grafts + pos,
|
||||||
commit_graft_nr - pos - 1);
|
the_repository->parsed_objects->grafts + pos + 1,
|
||||||
commit_graft_nr--;
|
the_repository->parsed_objects->grafts_nr - pos - 1);
|
||||||
|
the_repository->parsed_objects->grafts_nr--;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -381,7 +386,7 @@ int parse_commit_buffer(struct commit *item, const void *buffer, unsigned long s
|
|||||||
bufptr += tree_entry_len + 1; /* "tree " + "hex sha1" + "\n" */
|
bufptr += tree_entry_len + 1; /* "tree " + "hex sha1" + "\n" */
|
||||||
pptr = &item->parents;
|
pptr = &item->parents;
|
||||||
|
|
||||||
graft = lookup_commit_graft(&item->object.oid);
|
graft = lookup_commit_graft(the_repository, &item->object.oid);
|
||||||
while (bufptr + parent_entry_len < tail && !memcmp(bufptr, "parent ", 7)) {
|
while (bufptr + parent_entry_len < tail && !memcmp(bufptr, "parent ", 7)) {
|
||||||
struct commit *new_parent;
|
struct commit *new_parent;
|
||||||
|
|
||||||
|
10
commit.h
10
commit.h
@ -194,8 +194,8 @@ struct commit_graft {
|
|||||||
typedef int (*each_commit_graft_fn)(const struct commit_graft *, void *);
|
typedef int (*each_commit_graft_fn)(const struct commit_graft *, void *);
|
||||||
|
|
||||||
struct commit_graft *read_graft_line(struct strbuf *line);
|
struct commit_graft *read_graft_line(struct strbuf *line);
|
||||||
int register_commit_graft(struct commit_graft *, int);
|
int register_commit_graft(struct repository *r, struct commit_graft *, int);
|
||||||
struct commit_graft *lookup_commit_graft(const struct object_id *oid);
|
struct commit_graft *lookup_commit_graft(struct repository *r, const struct object_id *oid);
|
||||||
|
|
||||||
extern struct commit_list *get_merge_bases(struct commit *rev1, struct commit *rev2);
|
extern struct commit_list *get_merge_bases(struct commit *rev1, struct commit *rev2);
|
||||||
extern struct commit_list *get_merge_bases_many(struct commit *one, int n, struct commit **twos);
|
extern struct commit_list *get_merge_bases_many(struct commit *one, int n, struct commit **twos);
|
||||||
@ -209,15 +209,15 @@ extern struct commit_list *get_merge_bases_many_dirty(struct commit *one, int n,
|
|||||||
|
|
||||||
struct oid_array;
|
struct oid_array;
|
||||||
struct ref;
|
struct ref;
|
||||||
extern int register_shallow(const struct object_id *oid);
|
extern int register_shallow(struct repository *r, const struct object_id *oid);
|
||||||
extern int unregister_shallow(const struct object_id *oid);
|
extern int unregister_shallow(const struct object_id *oid);
|
||||||
extern int for_each_commit_graft(each_commit_graft_fn, void *);
|
extern int for_each_commit_graft(each_commit_graft_fn, void *);
|
||||||
extern int is_repository_shallow(void);
|
extern int is_repository_shallow(struct repository *r);
|
||||||
extern struct commit_list *get_shallow_commits(struct object_array *heads,
|
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 struct commit_list *get_shallow_commits_by_rev_list(
|
extern struct commit_list *get_shallow_commits_by_rev_list(
|
||||||
int ac, const char **av, int shallow_flag, int not_shallow_flag);
|
int ac, const char **av, int shallow_flag, int not_shallow_flag);
|
||||||
extern void set_alternate_shallow_file(const char *path, int override);
|
extern void set_alternate_shallow_file(struct repository *r, const char *path, int override);
|
||||||
extern int write_shallow_commits(struct strbuf *out, int use_pack_protocol,
|
extern int write_shallow_commits(struct strbuf *out, int use_pack_protocol,
|
||||||
const struct oid_array *extra);
|
const struct oid_array *extra);
|
||||||
extern void setup_alternate_shallow(struct lock_file *shallow_lock,
|
extern void setup_alternate_shallow(struct lock_file *shallow_lock,
|
||||||
|
1
config.c
1
config.c
@ -14,6 +14,7 @@
|
|||||||
#include "quote.h"
|
#include "quote.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "string-list.h"
|
#include "string-list.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "utf8.h"
|
#include "utf8.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
#include "color.h"
|
#include "color.h"
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#define NO_THE_INDEX_COMPATIBILITY_MACROS
|
#define NO_THE_INDEX_COMPATIBILITY_MACROS
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "attr.h"
|
#include "attr.h"
|
||||||
#include "run-command.h"
|
#include "run-command.h"
|
||||||
#include "quote.h"
|
#include "quote.h"
|
||||||
|
1
diff.c
1
diff.c
@ -13,6 +13,7 @@
|
|||||||
#include "attr.h"
|
#include "attr.h"
|
||||||
#include "run-command.h"
|
#include "run-command.h"
|
||||||
#include "utf8.h"
|
#include "utf8.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "userdiff.h"
|
#include "userdiff.h"
|
||||||
#include "submodule-config.h"
|
#include "submodule-config.h"
|
||||||
#include "submodule.h"
|
#include "submodule.h"
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
#include "diffcore.h"
|
#include "diffcore.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "progress.h"
|
#include "progress.h"
|
||||||
|
|
||||||
|
1
dir.c
1
dir.c
@ -11,6 +11,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "attr.h"
|
#include "attr.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "wildmatch.h"
|
#include "wildmatch.h"
|
||||||
|
1
entry.c
1
entry.c
@ -1,5 +1,6 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
#include "streaming.h"
|
#include "streaming.h"
|
||||||
#include "submodule.h"
|
#include "submodule.h"
|
||||||
|
@ -192,7 +192,7 @@ void setup_git_env(const char *git_dir)
|
|||||||
git_namespace = expand_namespace(getenv(GIT_NAMESPACE_ENVIRONMENT));
|
git_namespace = expand_namespace(getenv(GIT_NAMESPACE_ENVIRONMENT));
|
||||||
shallow_file = getenv(GIT_SHALLOW_FILE_ENVIRONMENT);
|
shallow_file = getenv(GIT_SHALLOW_FILE_ENVIRONMENT);
|
||||||
if (shallow_file)
|
if (shallow_file)
|
||||||
set_alternate_shallow_file(shallow_file, 0);
|
set_alternate_shallow_file(the_repository, shallow_file, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int is_bare_repository(void)
|
int is_bare_repository(void)
|
||||||
@ -319,11 +319,11 @@ char *get_index_file(void)
|
|||||||
return the_repository->index_file;
|
return the_repository->index_file;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *get_graft_file(void)
|
char *get_graft_file(struct repository *r)
|
||||||
{
|
{
|
||||||
if (!the_repository->graft_file)
|
if (!r->graft_file)
|
||||||
BUG("git environment hasn't been setup");
|
BUG("git environment hasn't been setup");
|
||||||
return the_repository->graft_file;
|
return r->graft_file;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void set_git_dir_1(const char *path)
|
static void set_git_dir_1(const char *path)
|
||||||
|
15
fetch-pack.c
15
fetch-pack.c
@ -19,6 +19,7 @@
|
|||||||
#include "sha1-array.h"
|
#include "sha1-array.h"
|
||||||
#include "oidset.h"
|
#include "oidset.h"
|
||||||
#include "packfile.h"
|
#include "packfile.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
static int transfer_unpack_limit = -1;
|
static int transfer_unpack_limit = -1;
|
||||||
static int fetch_unpack_limit = -1;
|
static int fetch_unpack_limit = -1;
|
||||||
@ -396,7 +397,7 @@ static int find_common(struct fetch_pack_args *args,
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_repository_shallow())
|
if (is_repository_shallow(the_repository))
|
||||||
write_shallow_commits(&req_buf, 1, NULL);
|
write_shallow_commits(&req_buf, 1, NULL);
|
||||||
if (args->depth > 0)
|
if (args->depth > 0)
|
||||||
packet_buf_write(&req_buf, "deepen %d", args->depth);
|
packet_buf_write(&req_buf, "deepen %d", args->depth);
|
||||||
@ -427,7 +428,7 @@ static int find_common(struct fetch_pack_args *args,
|
|||||||
if (skip_prefix(line, "shallow ", &arg)) {
|
if (skip_prefix(line, "shallow ", &arg)) {
|
||||||
if (get_oid_hex(arg, &oid))
|
if (get_oid_hex(arg, &oid))
|
||||||
die(_("invalid shallow line: %s"), line);
|
die(_("invalid shallow line: %s"), line);
|
||||||
register_shallow(&oid);
|
register_shallow(the_repository, &oid);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (skip_prefix(line, "unshallow ", &arg)) {
|
if (skip_prefix(line, "unshallow ", &arg)) {
|
||||||
@ -985,7 +986,7 @@ static struct ref *do_fetch_pack(struct fetch_pack_args *args,
|
|||||||
sort_ref_list(&ref, ref_compare_name);
|
sort_ref_list(&ref, ref_compare_name);
|
||||||
QSORT(sought, nr_sought, cmp_ref_by_name);
|
QSORT(sought, nr_sought, cmp_ref_by_name);
|
||||||
|
|
||||||
if ((args->depth > 0 || is_repository_shallow()) && !server_supports("shallow"))
|
if ((args->depth > 0 || is_repository_shallow(the_repository)) && !server_supports("shallow"))
|
||||||
die(_("Server does not support shallow clients"));
|
die(_("Server does not support shallow clients"));
|
||||||
if (args->depth > 0 || args->deepen_since || args->deepen_not)
|
if (args->depth > 0 || args->deepen_since || args->deepen_not)
|
||||||
args->deepen = 1;
|
args->deepen = 1;
|
||||||
@ -1083,7 +1084,7 @@ static struct ref *do_fetch_pack(struct fetch_pack_args *args,
|
|||||||
static void add_shallow_requests(struct strbuf *req_buf,
|
static void add_shallow_requests(struct strbuf *req_buf,
|
||||||
const struct fetch_pack_args *args)
|
const struct fetch_pack_args *args)
|
||||||
{
|
{
|
||||||
if (is_repository_shallow())
|
if (is_repository_shallow(the_repository))
|
||||||
write_shallow_commits(req_buf, 1, NULL);
|
write_shallow_commits(req_buf, 1, NULL);
|
||||||
if (args->depth > 0)
|
if (args->depth > 0)
|
||||||
packet_buf_write(req_buf, "deepen %d", args->depth);
|
packet_buf_write(req_buf, "deepen %d", args->depth);
|
||||||
@ -1195,7 +1196,7 @@ static int send_fetch_request(int fd_out, const struct fetch_pack_args *args,
|
|||||||
/* Add shallow-info and deepen request */
|
/* Add shallow-info and deepen request */
|
||||||
if (server_supports_feature("fetch", "shallow", 0))
|
if (server_supports_feature("fetch", "shallow", 0))
|
||||||
add_shallow_requests(&req_buf, args);
|
add_shallow_requests(&req_buf, args);
|
||||||
else if (is_repository_shallow() || args->deepen)
|
else if (is_repository_shallow(the_repository) || args->deepen)
|
||||||
die(_("Server does not support shallow requests"));
|
die(_("Server does not support shallow requests"));
|
||||||
|
|
||||||
/* Add filter */
|
/* Add filter */
|
||||||
@ -1308,7 +1309,7 @@ static void receive_shallow_info(struct fetch_pack_args *args,
|
|||||||
if (skip_prefix(reader->line, "shallow ", &arg)) {
|
if (skip_prefix(reader->line, "shallow ", &arg)) {
|
||||||
if (get_oid_hex(arg, &oid))
|
if (get_oid_hex(arg, &oid))
|
||||||
die(_("invalid shallow line: %s"), reader->line);
|
die(_("invalid shallow line: %s"), reader->line);
|
||||||
register_shallow(&oid);
|
register_shallow(the_repository, &oid);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (skip_prefix(reader->line, "unshallow ", &arg)) {
|
if (skip_prefix(reader->line, "unshallow ", &arg)) {
|
||||||
@ -1479,7 +1480,7 @@ static void update_shallow(struct fetch_pack_args *args,
|
|||||||
|
|
||||||
if (args->deepen && alternate_shallow_file) {
|
if (args->deepen && alternate_shallow_file) {
|
||||||
if (*alternate_shallow_file == '\0') { /* --unshallow */
|
if (*alternate_shallow_file == '\0') { /* --unshallow */
|
||||||
unlink_or_warn(git_path_shallow());
|
unlink_or_warn(git_path_shallow(the_repository));
|
||||||
rollback_lock_file(&shallow_lock);
|
rollback_lock_file(&shallow_lock);
|
||||||
} else
|
} else
|
||||||
commit_lock_file(&shallow_lock);
|
commit_lock_file(&shallow_lock);
|
||||||
|
3
fsck.c
3
fsck.c
@ -1,4 +1,5 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
@ -795,7 +796,7 @@ static int fsck_commit_buffer(struct commit *commit, const char *buffer,
|
|||||||
buffer = p + 1;
|
buffer = p + 1;
|
||||||
parent_line_count++;
|
parent_line_count++;
|
||||||
}
|
}
|
||||||
graft = lookup_commit_graft(&commit->object.oid);
|
graft = lookup_commit_graft(the_repository, &commit->object.oid);
|
||||||
parent_count = commit_list_count(commit->parents);
|
parent_count = commit_list_count(commit->parents);
|
||||||
if (graft) {
|
if (graft) {
|
||||||
if (graft->nr_parent == -1 && !parent_count)
|
if (graft->nr_parent == -1 && !parent_count)
|
||||||
|
2
git.c
2
git.c
@ -267,7 +267,7 @@ static int handle_options(const char ***argv, int *argc, int *envchanged)
|
|||||||
} else if (!strcmp(cmd, "--shallow-file")) {
|
} else if (!strcmp(cmd, "--shallow-file")) {
|
||||||
(*argv)++;
|
(*argv)++;
|
||||||
(*argc)--;
|
(*argc)--;
|
||||||
set_alternate_shallow_file((*argv)[0], 1);
|
set_alternate_shallow_file(the_repository, (*argv)[0], 1);
|
||||||
if (envchanged)
|
if (envchanged)
|
||||||
*envchanged = 1;
|
*envchanged = 1;
|
||||||
} else if (!strcmp(cmd, "-C")) {
|
} else if (!strcmp(cmd, "-C")) {
|
||||||
|
1
grep.c
1
grep.c
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "grep.h"
|
#include "grep.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "userdiff.h"
|
#include "userdiff.h"
|
||||||
#include "xdiff-interface.h"
|
#include "xdiff-interface.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include "list-objects-filter.h"
|
#include "list-objects-filter.h"
|
||||||
#include "list-objects-filter-options.h"
|
#include "list-objects-filter-options.h"
|
||||||
#include "oidset.h"
|
#include "oidset.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
/* Remember to update object flag allocation in object.h */
|
/* Remember to update object flag allocation in object.h */
|
||||||
/*
|
/*
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include "list-objects-filter.h"
|
#include "list-objects-filter.h"
|
||||||
#include "list-objects-filter-options.h"
|
#include "list-objects-filter-options.h"
|
||||||
#include "packfile.h"
|
#include "packfile.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
static void process_blob(struct rev_info *revs,
|
static void process_blob(struct rev_info *revs,
|
||||||
struct blob *blob,
|
struct blob *blob,
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "graph.h"
|
#include "graph.h"
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "string-list.h"
|
#include "string-list.h"
|
||||||
#include "mailmap.h"
|
#include "mailmap.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
#define DEBUG_MAILMAP 0
|
#define DEBUG_MAILMAP 0
|
||||||
#if DEBUG_MAILMAP
|
#if DEBUG_MAILMAP
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
static int score_missing(unsigned mode, const char *path)
|
static int score_missing(unsigned mode, const char *path)
|
||||||
{
|
{
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#include "ll-merge.h"
|
#include "ll-merge.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "merge-blobs.h"
|
#include "merge-blobs.h"
|
||||||
|
#include "object-store.h"
|
||||||
|
|
||||||
static int fill_mmfile_blob(mmfile_t *f, struct blob *obj)
|
static int fill_mmfile_blob(mmfile_t *f, struct blob *obj)
|
||||||
{
|
{
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include "advice.h"
|
#include "advice.h"
|
||||||
#include "lockfile.h"
|
#include "lockfile.h"
|
||||||
#include "cache-tree.h"
|
#include "cache-tree.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "builtin.h"
|
#include "builtin.h"
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "notes-cache.h"
|
#include "notes-cache.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
#include "diffcore.h"
|
#include "diffcore.h"
|
||||||
#include "xdiff-interface.h"
|
#include "xdiff-interface.h"
|
||||||
|
1
notes.c
1
notes.c
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "notes.h"
|
#include "notes.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "utf8.h"
|
#include "utf8.h"
|
||||||
|
117
object-store.h
117
object-store.h
@ -139,4 +139,121 @@ void sha1_file_name(struct repository *r, struct strbuf *buf, const unsigned cha
|
|||||||
|
|
||||||
void *map_sha1_file(struct repository *r, const unsigned char *sha1, unsigned long *size);
|
void *map_sha1_file(struct repository *r, const unsigned char *sha1, unsigned long *size);
|
||||||
|
|
||||||
|
extern void *read_object_file_extended(const struct object_id *oid,
|
||||||
|
enum object_type *type,
|
||||||
|
unsigned long *size, int lookup_replace);
|
||||||
|
static inline void *read_object_file(const struct object_id *oid, enum object_type *type, unsigned long *size)
|
||||||
|
{
|
||||||
|
return read_object_file_extended(oid, type, size, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Read and unpack an object file into memory, write memory to an object file */
|
||||||
|
int oid_object_info(struct repository *r, const struct object_id *, unsigned long *);
|
||||||
|
|
||||||
|
extern int hash_object_file(const void *buf, unsigned long len,
|
||||||
|
const char *type, struct object_id *oid);
|
||||||
|
|
||||||
|
extern int write_object_file(const void *buf, unsigned long len,
|
||||||
|
const char *type, struct object_id *oid);
|
||||||
|
|
||||||
|
extern int hash_object_file_literally(const void *buf, unsigned long len,
|
||||||
|
const char *type, struct object_id *oid,
|
||||||
|
unsigned flags);
|
||||||
|
|
||||||
|
extern int pretend_object_file(void *, unsigned long, enum object_type,
|
||||||
|
struct object_id *oid);
|
||||||
|
|
||||||
|
extern int force_object_loose(const struct object_id *oid, time_t mtime);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Open the loose object at path, check its hash, and return the contents,
|
||||||
|
* type, and size. If the object is a blob, then "contents" may return NULL,
|
||||||
|
* to allow streaming of large blobs.
|
||||||
|
*
|
||||||
|
* Returns 0 on success, negative on error (details may be written to stderr).
|
||||||
|
*/
|
||||||
|
int read_loose_object(const char *path,
|
||||||
|
const struct object_id *expected_oid,
|
||||||
|
enum object_type *type,
|
||||||
|
unsigned long *size,
|
||||||
|
void **contents);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Convenience for sha1_object_info_extended() with a NULL struct
|
||||||
|
* object_info. OBJECT_INFO_SKIP_CACHED is automatically set; pass
|
||||||
|
* nonzero flags to also set other flags.
|
||||||
|
*/
|
||||||
|
extern int has_sha1_file_with_flags(const unsigned char *sha1, int flags);
|
||||||
|
static inline int has_sha1_file(const unsigned char *sha1)
|
||||||
|
{
|
||||||
|
return has_sha1_file_with_flags(sha1, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Same as the above, except for struct object_id. */
|
||||||
|
extern int has_object_file(const struct object_id *oid);
|
||||||
|
extern int has_object_file_with_flags(const struct object_id *oid, int flags);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return true iff an alternate object database has a loose object
|
||||||
|
* with the specified name. This function does not respect replace
|
||||||
|
* references.
|
||||||
|
*/
|
||||||
|
extern int has_loose_object_nonlocal(const struct object_id *);
|
||||||
|
|
||||||
|
extern void assert_oid_type(const struct object_id *oid, enum object_type expect);
|
||||||
|
|
||||||
|
struct object_info {
|
||||||
|
/* Request */
|
||||||
|
enum object_type *typep;
|
||||||
|
unsigned long *sizep;
|
||||||
|
off_t *disk_sizep;
|
||||||
|
unsigned char *delta_base_sha1;
|
||||||
|
struct strbuf *type_name;
|
||||||
|
void **contentp;
|
||||||
|
|
||||||
|
/* Response */
|
||||||
|
enum {
|
||||||
|
OI_CACHED,
|
||||||
|
OI_LOOSE,
|
||||||
|
OI_PACKED,
|
||||||
|
OI_DBCACHED
|
||||||
|
} whence;
|
||||||
|
union {
|
||||||
|
/*
|
||||||
|
* struct {
|
||||||
|
* ... Nothing to expose in this case
|
||||||
|
* } cached;
|
||||||
|
* struct {
|
||||||
|
* ... Nothing to expose in this case
|
||||||
|
* } loose;
|
||||||
|
*/
|
||||||
|
struct {
|
||||||
|
struct packed_git *pack;
|
||||||
|
off_t offset;
|
||||||
|
unsigned int is_delta;
|
||||||
|
} packed;
|
||||||
|
} u;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Initializer for a "struct object_info" that wants no items. You may
|
||||||
|
* also memset() the memory to all-zeroes.
|
||||||
|
*/
|
||||||
|
#define OBJECT_INFO_INIT {NULL}
|
||||||
|
|
||||||
|
/* Invoke lookup_replace_object() on the given hash */
|
||||||
|
#define OBJECT_INFO_LOOKUP_REPLACE 1
|
||||||
|
/* Allow reading from a loose object file of unknown/bogus type */
|
||||||
|
#define OBJECT_INFO_ALLOW_UNKNOWN_TYPE 2
|
||||||
|
/* Do not check cached storage */
|
||||||
|
#define OBJECT_INFO_SKIP_CACHED 4
|
||||||
|
/* Do not retry packed storage after checking packed and loose storage */
|
||||||
|
#define OBJECT_INFO_QUICK 8
|
||||||
|
/* Do not check loose object */
|
||||||
|
#define OBJECT_INFO_IGNORE_LOOSE 16
|
||||||
|
|
||||||
|
int oid_object_info_extended(struct repository *r,
|
||||||
|
const struct object_id *,
|
||||||
|
struct object_info *, unsigned flags);
|
||||||
|
|
||||||
#endif /* OBJECT_STORE_H */
|
#endif /* OBJECT_STORE_H */
|
||||||
|
4
object.c
4
object.c
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "replace-object.h"
|
#include "replace-object.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
@ -463,6 +464,9 @@ struct parsed_object_pool *parsed_object_pool_new(void)
|
|||||||
o->tag_state = allocate_alloc_state();
|
o->tag_state = allocate_alloc_state();
|
||||||
o->object_state = allocate_alloc_state();
|
o->object_state = allocate_alloc_state();
|
||||||
|
|
||||||
|
o->is_shallow = -1;
|
||||||
|
o->shallow_stat = xcalloc(1, sizeof(*o->shallow_stat));
|
||||||
|
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
10
object.h
10
object.h
@ -12,6 +12,16 @@ struct parsed_object_pool {
|
|||||||
struct alloc_state *tag_state;
|
struct alloc_state *tag_state;
|
||||||
struct alloc_state *object_state;
|
struct alloc_state *object_state;
|
||||||
unsigned commit_count;
|
unsigned commit_count;
|
||||||
|
|
||||||
|
/* parent substitutions from .git/info/grafts and .git/shallow */
|
||||||
|
struct commit_graft **grafts;
|
||||||
|
int grafts_alloc, grafts_nr;
|
||||||
|
|
||||||
|
int is_shallow;
|
||||||
|
struct stat_validity *shallow_stat;
|
||||||
|
char *alternate_shallow_file;
|
||||||
|
|
||||||
|
int commit_graft_prepared;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct parsed_object_pool *parsed_object_pool_new(void);
|
struct parsed_object_pool *parsed_object_pool_new(void);
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
|
@ -3,6 +3,11 @@
|
|||||||
|
|
||||||
#include "oidset.h"
|
#include "oidset.h"
|
||||||
|
|
||||||
|
/* in object-store.h */
|
||||||
|
struct packed_git;
|
||||||
|
struct object_info;
|
||||||
|
enum object_type;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Generate the filename to be used for a pack file with checksum "sha1" and
|
* Generate the filename to be used for a pack file with checksum "sha1" and
|
||||||
* extension "ext". The result is written into the strbuf "buf", overwriting
|
* extension "ext". The result is written into the strbuf "buf", overwriting
|
||||||
|
18
path.c
18
path.c
@ -1442,12 +1442,12 @@ char *xdg_cache_home(const char *filename)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
GIT_PATH_FUNC(git_path_cherry_pick_head, "CHERRY_PICK_HEAD")
|
REPO_GIT_PATH_FUNC(cherry_pick_head, "CHERRY_PICK_HEAD")
|
||||||
GIT_PATH_FUNC(git_path_revert_head, "REVERT_HEAD")
|
REPO_GIT_PATH_FUNC(revert_head, "REVERT_HEAD")
|
||||||
GIT_PATH_FUNC(git_path_squash_msg, "SQUASH_MSG")
|
REPO_GIT_PATH_FUNC(squash_msg, "SQUASH_MSG")
|
||||||
GIT_PATH_FUNC(git_path_merge_msg, "MERGE_MSG")
|
REPO_GIT_PATH_FUNC(merge_msg, "MERGE_MSG")
|
||||||
GIT_PATH_FUNC(git_path_merge_rr, "MERGE_RR")
|
REPO_GIT_PATH_FUNC(merge_rr, "MERGE_RR")
|
||||||
GIT_PATH_FUNC(git_path_merge_mode, "MERGE_MODE")
|
REPO_GIT_PATH_FUNC(merge_mode, "MERGE_MODE")
|
||||||
GIT_PATH_FUNC(git_path_merge_head, "MERGE_HEAD")
|
REPO_GIT_PATH_FUNC(merge_head, "MERGE_HEAD")
|
||||||
GIT_PATH_FUNC(git_path_fetch_head, "FETCH_HEAD")
|
REPO_GIT_PATH_FUNC(fetch_head, "FETCH_HEAD")
|
||||||
GIT_PATH_FUNC(git_path_shallow, "shallow")
|
REPO_GIT_PATH_FUNC(shallow, "shallow")
|
||||||
|
40
path.h
40
path.h
@ -160,14 +160,36 @@ extern void report_linked_checkout_garbage(void);
|
|||||||
return ret; \
|
return ret; \
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *git_path_cherry_pick_head(void);
|
#define REPO_GIT_PATH_FUNC(var, filename) \
|
||||||
const char *git_path_revert_head(void);
|
const char *git_path_##var(struct repository *r) \
|
||||||
const char *git_path_squash_msg(void);
|
{ \
|
||||||
const char *git_path_merge_msg(void);
|
if (!r->cached_paths.var) \
|
||||||
const char *git_path_merge_rr(void);
|
r->cached_paths.var = git_pathdup(filename); \
|
||||||
const char *git_path_merge_mode(void);
|
return r->cached_paths.var; \
|
||||||
const char *git_path_merge_head(void);
|
}
|
||||||
const char *git_path_fetch_head(void);
|
|
||||||
const char *git_path_shallow(void);
|
struct path_cache {
|
||||||
|
const char *cherry_pick_head;
|
||||||
|
const char *revert_head;
|
||||||
|
const char *squash_msg;
|
||||||
|
const char *merge_msg;
|
||||||
|
const char *merge_rr;
|
||||||
|
const char *merge_mode;
|
||||||
|
const char *merge_head;
|
||||||
|
const char *fetch_head;
|
||||||
|
const char *shallow;
|
||||||
|
};
|
||||||
|
|
||||||
|
#define PATH_CACHE_INIT { NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL }
|
||||||
|
|
||||||
|
const char *git_path_cherry_pick_head(struct repository *r);
|
||||||
|
const char *git_path_revert_head(struct repository *r);
|
||||||
|
const char *git_path_squash_msg(struct repository *r);
|
||||||
|
const char *git_path_merge_msg(struct repository *r);
|
||||||
|
const char *git_path_merge_rr(struct repository *r);
|
||||||
|
const char *git_path_merge_mode(struct repository *r);
|
||||||
|
const char *git_path_merge_head(struct repository *r);
|
||||||
|
const char *git_path_fetch_head(struct repository *r);
|
||||||
|
const char *git_path_shallow(struct repository *r);
|
||||||
|
|
||||||
#endif /* PATH_H */
|
#endif /* PATH_H */
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include "cache-tree.h"
|
#include "cache-tree.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
#include "parse-options.h"
|
#include "parse-options.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "wildmatch.h"
|
#include "wildmatch.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "remote.h"
|
#include "remote.h"
|
||||||
#include "color.h"
|
#include "color.h"
|
||||||
|
1
refs.c
1
refs.c
@ -9,6 +9,7 @@
|
|||||||
#include "iterator.h"
|
#include "iterator.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "refs/refs-internal.h"
|
#include "refs/refs-internal.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "submodule.h"
|
#include "submodule.h"
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "remote.h"
|
#include "remote.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "strbuf.h"
|
#include "strbuf.h"
|
||||||
#include "url.h"
|
#include "url.h"
|
||||||
#include "exec-cmd.h"
|
#include "exec-cmd.h"
|
||||||
|
1
remote.c
1
remote.c
@ -3,6 +3,7 @@
|
|||||||
#include "remote.h"
|
#include "remote.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "refspec.h"
|
#include "refspec.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "diff.h"
|
#include "diff.h"
|
||||||
#include "revision.h"
|
#include "revision.h"
|
||||||
|
@ -38,6 +38,11 @@ struct repository {
|
|||||||
/* The store in which the refs are held. */
|
/* The store in which the refs are held. */
|
||||||
struct ref_store *refs;
|
struct ref_store *refs;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Contains path to often used file names.
|
||||||
|
*/
|
||||||
|
struct path_cache cached_paths;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Path to the repository's graft file.
|
* Path to the repository's graft file.
|
||||||
* Cannot be NULL after initialization.
|
* Cannot be NULL after initialization.
|
||||||
|
8
rerere.c
8
rerere.c
@ -9,6 +9,7 @@
|
|||||||
#include "ll-merge.h"
|
#include "ll-merge.h"
|
||||||
#include "attr.h"
|
#include "attr.h"
|
||||||
#include "pathspec.h"
|
#include "pathspec.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "sha1-lookup.h"
|
#include "sha1-lookup.h"
|
||||||
|
|
||||||
#define RESOLVED 0
|
#define RESOLVED 0
|
||||||
@ -200,7 +201,7 @@ static struct rerere_id *new_rerere_id(unsigned char *sha1)
|
|||||||
static void read_rr(struct string_list *rr)
|
static void read_rr(struct string_list *rr)
|
||||||
{
|
{
|
||||||
struct strbuf buf = STRBUF_INIT;
|
struct strbuf buf = STRBUF_INIT;
|
||||||
FILE *in = fopen_or_warn(git_path_merge_rr(), "r");
|
FILE *in = fopen_or_warn(git_path_merge_rr(the_repository), "r");
|
||||||
|
|
||||||
if (!in)
|
if (!in)
|
||||||
return;
|
return;
|
||||||
@ -895,7 +896,8 @@ int setup_rerere(struct string_list *merge_rr, int flags)
|
|||||||
if (flags & RERERE_READONLY)
|
if (flags & RERERE_READONLY)
|
||||||
fd = 0;
|
fd = 0;
|
||||||
else
|
else
|
||||||
fd = hold_lock_file_for_update(&write_lock, git_path_merge_rr(),
|
fd = hold_lock_file_for_update(&write_lock,
|
||||||
|
git_path_merge_rr(the_repository),
|
||||||
LOCK_DIE_ON_ERROR);
|
LOCK_DIE_ON_ERROR);
|
||||||
read_rr(merge_rr);
|
read_rr(merge_rr);
|
||||||
return fd;
|
return fd;
|
||||||
@ -1245,6 +1247,6 @@ void rerere_clear(struct string_list *merge_rr)
|
|||||||
rmdir(rerere_path(id, NULL));
|
rmdir(rerere_path(id, NULL));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
unlink_or_warn(git_path_merge_rr());
|
unlink_or_warn(git_path_merge_rr(the_repository));
|
||||||
rollback_lock_file(&write_lock);
|
rollback_lock_file(&write_lock);
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "pkt-line.h"
|
#include "pkt-line.h"
|
||||||
#include "sideband.h"
|
#include "sideband.h"
|
||||||
#include "run-command.h"
|
#include "run-command.h"
|
||||||
@ -75,7 +76,7 @@ static int pack_objects(int fd, struct ref *refs, struct oid_array *extra, struc
|
|||||||
argv_array_push(&po.args, "-q");
|
argv_array_push(&po.args, "-q");
|
||||||
if (args->progress)
|
if (args->progress)
|
||||||
argv_array_push(&po.args, "--progress");
|
argv_array_push(&po.args, "--progress");
|
||||||
if (is_repository_shallow())
|
if (is_repository_shallow(the_repository))
|
||||||
argv_array_push(&po.args, "--shallow");
|
argv_array_push(&po.args, "--shallow");
|
||||||
po.in = -1;
|
po.in = -1;
|
||||||
po.out = args->stateless_rpc ? -1 : fd;
|
po.out = args->stateless_rpc ? -1 : fd;
|
||||||
@ -220,7 +221,7 @@ static int advertise_shallow_grafts_cb(const struct commit_graft *graft, void *c
|
|||||||
|
|
||||||
static void advertise_shallow_grafts_buf(struct strbuf *sb)
|
static void advertise_shallow_grafts_buf(struct strbuf *sb)
|
||||||
{
|
{
|
||||||
if (!is_repository_shallow())
|
if (!is_repository_shallow(the_repository))
|
||||||
return;
|
return;
|
||||||
for_each_commit_graft(advertise_shallow_grafts_cb, sb);
|
for_each_commit_graft(advertise_shallow_grafts_cb, sb);
|
||||||
}
|
}
|
||||||
@ -537,7 +538,7 @@ int send_pack(struct send_pack_args *args,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (args->stateless_rpc) {
|
if (args->stateless_rpc) {
|
||||||
if (!args->dry_run && (cmds_sent || is_repository_shallow())) {
|
if (!args->dry_run && (cmds_sent || is_repository_shallow(the_repository))) {
|
||||||
packet_buf_flush(&req_buf);
|
packet_buf_flush(&req_buf);
|
||||||
send_sideband(out, -1, req_buf.buf, req_buf.len, LARGE_PACKET_MAX);
|
send_sideband(out, -1, req_buf.buf, req_buf.len, LARGE_PACKET_MAX);
|
||||||
}
|
}
|
||||||
|
52
sequencer.c
52
sequencer.c
@ -2,6 +2,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "lockfile.h"
|
#include "lockfile.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "sequencer.h"
|
#include "sequencer.h"
|
||||||
@ -357,7 +358,7 @@ static void print_advice(int show_hint, struct replay_opts *opts)
|
|||||||
* (typically rebase --interactive) wants to take care
|
* (typically rebase --interactive) wants to take care
|
||||||
* of the commit itself so remove CHERRY_PICK_HEAD
|
* of the commit itself so remove CHERRY_PICK_HEAD
|
||||||
*/
|
*/
|
||||||
unlink(git_path_cherry_pick_head());
|
unlink(git_path_cherry_pick_head(the_repository));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1324,8 +1325,8 @@ static int do_commit(const char *msg_file, const char *author,
|
|||||||
&oid);
|
&oid);
|
||||||
strbuf_release(&sb);
|
strbuf_release(&sb);
|
||||||
if (!res) {
|
if (!res) {
|
||||||
unlink(git_path_cherry_pick_head());
|
unlink(git_path_cherry_pick_head(the_repository));
|
||||||
unlink(git_path_merge_msg());
|
unlink(git_path_merge_msg(the_repository));
|
||||||
if (!is_rebase_i(opts))
|
if (!is_rebase_i(opts))
|
||||||
print_commit_summary(NULL, &oid,
|
print_commit_summary(NULL, &oid,
|
||||||
SUMMARY_SHOW_AUTHOR_DATE);
|
SUMMARY_SHOW_AUTHOR_DATE);
|
||||||
@ -1613,7 +1614,7 @@ static int do_pick_commit(enum todo_command command, struct commit *commit,
|
|||||||
struct replay_opts *opts, int final_fixup)
|
struct replay_opts *opts, int final_fixup)
|
||||||
{
|
{
|
||||||
unsigned int flags = opts->edit ? EDIT_MSG : 0;
|
unsigned int flags = opts->edit ? EDIT_MSG : 0;
|
||||||
const char *msg_file = opts->edit ? NULL : git_path_merge_msg();
|
const char *msg_file = opts->edit ? NULL : git_path_merge_msg(the_repository);
|
||||||
struct object_id head;
|
struct object_id head;
|
||||||
struct commit *base, *next, *parent;
|
struct commit *base, *next, *parent;
|
||||||
const char *base_label, *next_label;
|
const char *base_label, *next_label;
|
||||||
@ -1755,12 +1756,12 @@ static int do_pick_commit(enum todo_command command, struct commit *commit,
|
|||||||
flags |= CLEANUP_MSG;
|
flags |= CLEANUP_MSG;
|
||||||
msg_file = rebase_path_fixup_msg();
|
msg_file = rebase_path_fixup_msg();
|
||||||
} else {
|
} else {
|
||||||
const char *dest = git_path_squash_msg();
|
const char *dest = git_path_squash_msg(the_repository);
|
||||||
unlink(dest);
|
unlink(dest);
|
||||||
if (copy_file(dest, rebase_path_squash_msg(), 0666))
|
if (copy_file(dest, rebase_path_squash_msg(), 0666))
|
||||||
return error(_("could not rename '%s' to '%s'"),
|
return error(_("could not rename '%s' to '%s'"),
|
||||||
rebase_path_squash_msg(), dest);
|
rebase_path_squash_msg(), dest);
|
||||||
unlink(git_path_merge_msg());
|
unlink(git_path_merge_msg(the_repository));
|
||||||
msg_file = dest;
|
msg_file = dest;
|
||||||
flags |= EDIT_MSG;
|
flags |= EDIT_MSG;
|
||||||
}
|
}
|
||||||
@ -1778,13 +1779,13 @@ static int do_pick_commit(enum todo_command command, struct commit *commit,
|
|||||||
goto leave;
|
goto leave;
|
||||||
|
|
||||||
res |= write_message(msgbuf.buf, msgbuf.len,
|
res |= write_message(msgbuf.buf, msgbuf.len,
|
||||||
git_path_merge_msg(), 0);
|
git_path_merge_msg(the_repository), 0);
|
||||||
} else {
|
} else {
|
||||||
struct commit_list *common = NULL;
|
struct commit_list *common = NULL;
|
||||||
struct commit_list *remotes = NULL;
|
struct commit_list *remotes = NULL;
|
||||||
|
|
||||||
res = write_message(msgbuf.buf, msgbuf.len,
|
res = write_message(msgbuf.buf, msgbuf.len,
|
||||||
git_path_merge_msg(), 0);
|
git_path_merge_msg(the_repository), 0);
|
||||||
|
|
||||||
commit_list_insert(base, &common);
|
commit_list_insert(base, &common);
|
||||||
commit_list_insert(next, &remotes);
|
commit_list_insert(next, &remotes);
|
||||||
@ -2394,8 +2395,8 @@ static int rollback_single_pick(void)
|
|||||||
{
|
{
|
||||||
struct object_id head_oid;
|
struct object_id head_oid;
|
||||||
|
|
||||||
if (!file_exists(git_path_cherry_pick_head()) &&
|
if (!file_exists(git_path_cherry_pick_head(the_repository)) &&
|
||||||
!file_exists(git_path_revert_head()))
|
!file_exists(git_path_revert_head(the_repository)))
|
||||||
return error(_("no cherry-pick or revert in progress"));
|
return error(_("no cherry-pick or revert in progress"));
|
||||||
if (read_ref_full("HEAD", 0, &head_oid, NULL))
|
if (read_ref_full("HEAD", 0, &head_oid, NULL))
|
||||||
return error(_("cannot resolve HEAD"));
|
return error(_("cannot resolve HEAD"));
|
||||||
@ -2620,10 +2621,11 @@ static int error_failed_squash(struct commit *commit,
|
|||||||
if (copy_file(rebase_path_message(), rebase_path_squash_msg(), 0666))
|
if (copy_file(rebase_path_message(), rebase_path_squash_msg(), 0666))
|
||||||
return error(_("could not copy '%s' to '%s'"),
|
return error(_("could not copy '%s' to '%s'"),
|
||||||
rebase_path_squash_msg(), rebase_path_message());
|
rebase_path_squash_msg(), rebase_path_message());
|
||||||
unlink(git_path_merge_msg());
|
unlink(git_path_merge_msg(the_repository));
|
||||||
if (copy_file(git_path_merge_msg(), rebase_path_message(), 0666))
|
if (copy_file(git_path_merge_msg(the_repository), rebase_path_message(), 0666))
|
||||||
return error(_("could not copy '%s' to '%s'"),
|
return error(_("could not copy '%s' to '%s'"),
|
||||||
rebase_path_message(), git_path_merge_msg());
|
rebase_path_message(),
|
||||||
|
git_path_merge_msg(the_repository));
|
||||||
return error_with_patch(commit, subject, subject_len, opts, 1, 0);
|
return error_with_patch(commit, subject, subject_len, opts, 1, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2913,11 +2915,11 @@ static int do_merge(struct commit *commit, const char *arg, int arg_len,
|
|||||||
write_author_script(message);
|
write_author_script(message);
|
||||||
find_commit_subject(message, &body);
|
find_commit_subject(message, &body);
|
||||||
len = strlen(body);
|
len = strlen(body);
|
||||||
ret = write_message(body, len, git_path_merge_msg(), 0);
|
ret = write_message(body, len, git_path_merge_msg(the_repository), 0);
|
||||||
unuse_commit_buffer(commit, message);
|
unuse_commit_buffer(commit, message);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
error_errno(_("could not write '%s'"),
|
error_errno(_("could not write '%s'"),
|
||||||
git_path_merge_msg());
|
git_path_merge_msg(the_repository));
|
||||||
goto leave_merge;
|
goto leave_merge;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -2938,11 +2940,11 @@ static int do_merge(struct commit *commit, const char *arg, int arg_len,
|
|||||||
len = buf.len;
|
len = buf.len;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = write_message(p, len, git_path_merge_msg(), 0);
|
ret = write_message(p, len, git_path_merge_msg(the_repository), 0);
|
||||||
strbuf_release(&buf);
|
strbuf_release(&buf);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
error_errno(_("could not write '%s'"),
|
error_errno(_("could not write '%s'"),
|
||||||
git_path_merge_msg());
|
git_path_merge_msg(the_repository));
|
||||||
goto leave_merge;
|
goto leave_merge;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2979,8 +2981,8 @@ static int do_merge(struct commit *commit, const char *arg, int arg_len,
|
|||||||
}
|
}
|
||||||
|
|
||||||
write_message(oid_to_hex(&merge_commit->object.oid), GIT_SHA1_HEXSZ,
|
write_message(oid_to_hex(&merge_commit->object.oid), GIT_SHA1_HEXSZ,
|
||||||
git_path_merge_head(), 0);
|
git_path_merge_head(the_repository), 0);
|
||||||
write_message("no-ff", 5, git_path_merge_mode(), 0);
|
write_message("no-ff", 5, git_path_merge_mode(the_repository), 0);
|
||||||
|
|
||||||
bases = get_merge_bases(head_commit, merge_commit);
|
bases = get_merge_bases(head_commit, merge_commit);
|
||||||
if (bases && !oidcmp(&merge_commit->object.oid,
|
if (bases && !oidcmp(&merge_commit->object.oid,
|
||||||
@ -3034,7 +3036,7 @@ static int do_merge(struct commit *commit, const char *arg, int arg_len,
|
|||||||
* value (a negative one would indicate that the `merge`
|
* value (a negative one would indicate that the `merge`
|
||||||
* command needs to be rescheduled).
|
* command needs to be rescheduled).
|
||||||
*/
|
*/
|
||||||
ret = !!run_git_commit(git_path_merge_msg(), opts,
|
ret = !!run_git_commit(git_path_merge_msg(the_repository), opts,
|
||||||
run_commit_flags);
|
run_commit_flags);
|
||||||
|
|
||||||
leave_merge:
|
leave_merge:
|
||||||
@ -3401,8 +3403,8 @@ static int continue_single_pick(void)
|
|||||||
{
|
{
|
||||||
const char *argv[] = { "commit", NULL };
|
const char *argv[] = { "commit", NULL };
|
||||||
|
|
||||||
if (!file_exists(git_path_cherry_pick_head()) &&
|
if (!file_exists(git_path_cherry_pick_head(the_repository)) &&
|
||||||
!file_exists(git_path_revert_head()))
|
!file_exists(git_path_revert_head(the_repository)))
|
||||||
return error(_("no cherry-pick or revert in progress"));
|
return error(_("no cherry-pick or revert in progress"));
|
||||||
return run_command_v_opt(argv, RUN_GIT_CMD);
|
return run_command_v_opt(argv, RUN_GIT_CMD);
|
||||||
}
|
}
|
||||||
@ -3505,7 +3507,7 @@ static int commit_staged_changes(struct replay_opts *opts,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (is_clean) {
|
if (is_clean) {
|
||||||
const char *cherry_pick_head = git_path_cherry_pick_head();
|
const char *cherry_pick_head = git_path_cherry_pick_head(the_repository);
|
||||||
|
|
||||||
if (file_exists(cherry_pick_head) && unlink(cherry_pick_head))
|
if (file_exists(cherry_pick_head) && unlink(cherry_pick_head))
|
||||||
return error(_("could not remove CHERRY_PICK_HEAD"));
|
return error(_("could not remove CHERRY_PICK_HEAD"));
|
||||||
@ -3555,8 +3557,8 @@ int sequencer_continue(struct replay_opts *opts)
|
|||||||
|
|
||||||
if (!is_rebase_i(opts)) {
|
if (!is_rebase_i(opts)) {
|
||||||
/* Verify that the conflict has been resolved */
|
/* Verify that the conflict has been resolved */
|
||||||
if (file_exists(git_path_cherry_pick_head()) ||
|
if (file_exists(git_path_cherry_pick_head(the_repository)) ||
|
||||||
file_exists(git_path_revert_head())) {
|
file_exists(git_path_revert_head(the_repository))) {
|
||||||
res = continue_single_pick();
|
res = continue_single_pick();
|
||||||
if (res)
|
if (res)
|
||||||
goto release_todo_list;
|
goto release_todo_list;
|
||||||
|
74
shallow.c
74
shallow.c
@ -1,6 +1,8 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
|
#include "repository.h"
|
||||||
#include "tempfile.h"
|
#include "tempfile.h"
|
||||||
#include "lockfile.h"
|
#include "lockfile.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "pkt-line.h"
|
#include "pkt-line.h"
|
||||||
@ -13,22 +15,19 @@
|
|||||||
#include "revision.h"
|
#include "revision.h"
|
||||||
#include "list-objects.h"
|
#include "list-objects.h"
|
||||||
#include "commit-slab.h"
|
#include "commit-slab.h"
|
||||||
|
#include "repository.h"
|
||||||
|
|
||||||
static int is_shallow = -1;
|
void set_alternate_shallow_file(struct repository *r, const char *path, int override)
|
||||||
static struct stat_validity shallow_stat;
|
|
||||||
static char *alternate_shallow_file;
|
|
||||||
|
|
||||||
void set_alternate_shallow_file(const char *path, int override)
|
|
||||||
{
|
{
|
||||||
if (is_shallow != -1)
|
if (r->parsed_objects->is_shallow != -1)
|
||||||
BUG("is_repository_shallow must not be called before set_alternate_shallow_file");
|
BUG("is_repository_shallow must not be called before set_alternate_shallow_file");
|
||||||
if (alternate_shallow_file && !override)
|
if (r->parsed_objects->alternate_shallow_file && !override)
|
||||||
return;
|
return;
|
||||||
free(alternate_shallow_file);
|
free(r->parsed_objects->alternate_shallow_file);
|
||||||
alternate_shallow_file = xstrdup_or_null(path);
|
r->parsed_objects->alternate_shallow_file = xstrdup_or_null(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
int register_shallow(const struct object_id *oid)
|
int register_shallow(struct repository *r, const struct object_id *oid)
|
||||||
{
|
{
|
||||||
struct commit_graft *graft =
|
struct commit_graft *graft =
|
||||||
xmalloc(sizeof(struct commit_graft));
|
xmalloc(sizeof(struct commit_graft));
|
||||||
@ -38,41 +37,41 @@ int register_shallow(const struct object_id *oid)
|
|||||||
graft->nr_parent = -1;
|
graft->nr_parent = -1;
|
||||||
if (commit && commit->object.parsed)
|
if (commit && commit->object.parsed)
|
||||||
commit->parents = NULL;
|
commit->parents = NULL;
|
||||||
return register_commit_graft(graft, 0);
|
return register_commit_graft(r, graft, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int is_repository_shallow(void)
|
int is_repository_shallow(struct repository *r)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
const char *path = alternate_shallow_file;
|
const char *path = r->parsed_objects->alternate_shallow_file;
|
||||||
|
|
||||||
if (is_shallow >= 0)
|
if (r->parsed_objects->is_shallow >= 0)
|
||||||
return is_shallow;
|
return r->parsed_objects->is_shallow;
|
||||||
|
|
||||||
if (!path)
|
if (!path)
|
||||||
path = git_path_shallow();
|
path = git_path_shallow(r);
|
||||||
/*
|
/*
|
||||||
* fetch-pack sets '--shallow-file ""' as an indicator that no
|
* fetch-pack sets '--shallow-file ""' as an indicator that no
|
||||||
* shallow file should be used. We could just open it and it
|
* shallow file should be used. We could just open it and it
|
||||||
* will likely fail. But let's do an explicit check instead.
|
* will likely fail. But let's do an explicit check instead.
|
||||||
*/
|
*/
|
||||||
if (!*path || (fp = fopen(path, "r")) == NULL) {
|
if (!*path || (fp = fopen(path, "r")) == NULL) {
|
||||||
stat_validity_clear(&shallow_stat);
|
stat_validity_clear(r->parsed_objects->shallow_stat);
|
||||||
is_shallow = 0;
|
r->parsed_objects->is_shallow = 0;
|
||||||
return is_shallow;
|
return r->parsed_objects->is_shallow;
|
||||||
}
|
}
|
||||||
stat_validity_update(&shallow_stat, fileno(fp));
|
stat_validity_update(r->parsed_objects->shallow_stat, fileno(fp));
|
||||||
is_shallow = 1;
|
r->parsed_objects->is_shallow = 1;
|
||||||
|
|
||||||
while (fgets(buf, sizeof(buf), fp)) {
|
while (fgets(buf, sizeof(buf), fp)) {
|
||||||
struct object_id oid;
|
struct object_id oid;
|
||||||
if (get_oid_hex(buf, &oid))
|
if (get_oid_hex(buf, &oid))
|
||||||
die("bad shallow line: %s", buf);
|
die("bad shallow line: %s", buf);
|
||||||
register_shallow(&oid);
|
register_shallow(r, &oid);
|
||||||
}
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
return is_shallow;
|
return r->parsed_objects->is_shallow;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -116,8 +115,8 @@ struct commit_list *get_shallow_commits(struct object_array *heads, int depth,
|
|||||||
parse_commit_or_die(commit);
|
parse_commit_or_die(commit);
|
||||||
cur_depth++;
|
cur_depth++;
|
||||||
if ((depth != INFINITE_DEPTH && cur_depth >= depth) ||
|
if ((depth != INFINITE_DEPTH && cur_depth >= depth) ||
|
||||||
(is_repository_shallow() && !commit->parents &&
|
(is_repository_shallow(the_repository) && !commit->parents &&
|
||||||
(graft = lookup_commit_graft(&commit->object.oid)) != NULL &&
|
(graft = lookup_commit_graft(the_repository, &commit->object.oid)) != NULL &&
|
||||||
graft->nr_parent < 0)) {
|
graft->nr_parent < 0)) {
|
||||||
commit_list_insert(commit, &result);
|
commit_list_insert(commit, &result);
|
||||||
commit->object.flags |= shallow_flag;
|
commit->object.flags |= shallow_flag;
|
||||||
@ -181,7 +180,7 @@ struct commit_list *get_shallow_commits_by_rev_list(int ac, const char **av,
|
|||||||
*/
|
*/
|
||||||
clear_object_flags(both_flags);
|
clear_object_flags(both_flags);
|
||||||
|
|
||||||
is_repository_shallow(); /* make sure shallows are read */
|
is_repository_shallow(the_repository); /* make sure shallows are read */
|
||||||
|
|
||||||
init_revisions(&revs, NULL);
|
init_revisions(&revs, NULL);
|
||||||
save_commit_buffer = 0;
|
save_commit_buffer = 0;
|
||||||
@ -234,12 +233,12 @@ struct commit_list *get_shallow_commits_by_rev_list(int ac, const char **av,
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void check_shallow_file_for_update(void)
|
static void check_shallow_file_for_update(struct repository *r)
|
||||||
{
|
{
|
||||||
if (is_shallow == -1)
|
if (r->parsed_objects->is_shallow == -1)
|
||||||
BUG("shallow must be initialized by now");
|
BUG("shallow must be initialized by now");
|
||||||
|
|
||||||
if (!stat_validity_check(&shallow_stat, git_path_shallow()))
|
if (!stat_validity_check(r->parsed_objects->shallow_stat, git_path_shallow(the_repository)))
|
||||||
die("shallow file has changed since we read it");
|
die("shallow file has changed since we read it");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -334,9 +333,10 @@ void setup_alternate_shallow(struct lock_file *shallow_lock,
|
|||||||
struct strbuf sb = STRBUF_INIT;
|
struct strbuf sb = STRBUF_INIT;
|
||||||
int fd;
|
int fd;
|
||||||
|
|
||||||
fd = hold_lock_file_for_update(shallow_lock, git_path_shallow(),
|
fd = hold_lock_file_for_update(shallow_lock,
|
||||||
|
git_path_shallow(the_repository),
|
||||||
LOCK_DIE_ON_ERROR);
|
LOCK_DIE_ON_ERROR);
|
||||||
check_shallow_file_for_update();
|
check_shallow_file_for_update(the_repository);
|
||||||
if (write_shallow_commits(&sb, 0, extra)) {
|
if (write_shallow_commits(&sb, 0, extra)) {
|
||||||
if (write_in_full(fd, sb.buf, sb.len) < 0)
|
if (write_in_full(fd, sb.buf, sb.len) < 0)
|
||||||
die_errno("failed to write to %s",
|
die_errno("failed to write to %s",
|
||||||
@ -361,7 +361,7 @@ static int advertise_shallow_grafts_cb(const struct commit_graft *graft, void *c
|
|||||||
|
|
||||||
void advertise_shallow_grafts(int fd)
|
void advertise_shallow_grafts(int fd)
|
||||||
{
|
{
|
||||||
if (!is_repository_shallow())
|
if (!is_repository_shallow(the_repository))
|
||||||
return;
|
return;
|
||||||
for_each_commit_graft(advertise_shallow_grafts_cb, &fd);
|
for_each_commit_graft(advertise_shallow_grafts_cb, &fd);
|
||||||
}
|
}
|
||||||
@ -381,16 +381,17 @@ void prune_shallow(int show_only)
|
|||||||
strbuf_release(&sb);
|
strbuf_release(&sb);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
fd = hold_lock_file_for_update(&shallow_lock, git_path_shallow(),
|
fd = hold_lock_file_for_update(&shallow_lock,
|
||||||
|
git_path_shallow(the_repository),
|
||||||
LOCK_DIE_ON_ERROR);
|
LOCK_DIE_ON_ERROR);
|
||||||
check_shallow_file_for_update();
|
check_shallow_file_for_update(the_repository);
|
||||||
if (write_shallow_commits_1(&sb, 0, NULL, SEEN_ONLY)) {
|
if (write_shallow_commits_1(&sb, 0, NULL, SEEN_ONLY)) {
|
||||||
if (write_in_full(fd, sb.buf, sb.len) < 0)
|
if (write_in_full(fd, sb.buf, sb.len) < 0)
|
||||||
die_errno("failed to write to %s",
|
die_errno("failed to write to %s",
|
||||||
get_lock_file_path(&shallow_lock));
|
get_lock_file_path(&shallow_lock));
|
||||||
commit_lock_file(&shallow_lock);
|
commit_lock_file(&shallow_lock);
|
||||||
} else {
|
} else {
|
||||||
unlink(git_path_shallow());
|
unlink(git_path_shallow(the_repository));
|
||||||
rollback_lock_file(&shallow_lock);
|
rollback_lock_file(&shallow_lock);
|
||||||
}
|
}
|
||||||
strbuf_release(&sb);
|
strbuf_release(&sb);
|
||||||
@ -415,7 +416,8 @@ void prepare_shallow_info(struct shallow_info *info, struct oid_array *sa)
|
|||||||
for (i = 0; i < sa->nr; i++) {
|
for (i = 0; i < sa->nr; i++) {
|
||||||
if (has_object_file(sa->oid + i)) {
|
if (has_object_file(sa->oid + i)) {
|
||||||
struct commit_graft *graft;
|
struct commit_graft *graft;
|
||||||
graft = lookup_commit_graft(&sa->oid[i]);
|
graft = lookup_commit_graft(the_repository,
|
||||||
|
&sa->oid[i]);
|
||||||
if (graft && graft->nr_parent < 0)
|
if (graft && graft->nr_parent < 0)
|
||||||
continue;
|
continue;
|
||||||
info->ours[info->nr_ours++] = i;
|
info->ours[info->nr_ours++] = i;
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#include "submodule-config.h"
|
#include "submodule-config.h"
|
||||||
#include "submodule.h"
|
#include "submodule.h"
|
||||||
#include "strbuf.h"
|
#include "strbuf.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "parse-options.h"
|
#include "parse-options.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
1
tag.c
1
tag.c
@ -1,5 +1,6 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
#include "unpack-trees.h"
|
#include "unpack-trees.h"
|
||||||
#include "dir.h"
|
#include "dir.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "pathspec.h"
|
#include "pathspec.h"
|
||||||
|
|
||||||
|
1
tree.c
1
tree.c
@ -2,6 +2,7 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "cache-tree.h"
|
#include "cache-tree.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "blob.h"
|
#include "blob.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
#include "submodule.h"
|
#include "submodule.h"
|
||||||
#include "submodule-config.h"
|
#include "submodule-config.h"
|
||||||
#include "fsmonitor.h"
|
#include "fsmonitor.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "fetch-object.h"
|
#include "fetch-object.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
#include "refs.h"
|
#include "refs.h"
|
||||||
#include "pkt-line.h"
|
#include "pkt-line.h"
|
||||||
#include "sideband.h"
|
#include "sideband.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
@ -658,7 +659,7 @@ static void send_shallow(struct commit_list *result)
|
|||||||
if (!(object->flags & (CLIENT_SHALLOW|NOT_SHALLOW))) {
|
if (!(object->flags & (CLIENT_SHALLOW|NOT_SHALLOW))) {
|
||||||
packet_write_fmt(1, "shallow %s",
|
packet_write_fmt(1, "shallow %s",
|
||||||
oid_to_hex(&object->oid));
|
oid_to_hex(&object->oid));
|
||||||
register_shallow(&object->oid);
|
register_shallow(the_repository, &object->oid);
|
||||||
shallow_nr++;
|
shallow_nr++;
|
||||||
}
|
}
|
||||||
result = result->next;
|
result = result->next;
|
||||||
@ -695,14 +696,14 @@ static void send_unshallow(const struct object_array *shallows)
|
|||||||
add_object_array(object, NULL, &extra_edge_obj);
|
add_object_array(object, NULL, &extra_edge_obj);
|
||||||
}
|
}
|
||||||
/* make sure commit traversal conforms to client */
|
/* make sure commit traversal conforms to client */
|
||||||
register_shallow(&object->oid);
|
register_shallow(the_repository, &object->oid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void deepen(int depth, int deepen_relative,
|
static void deepen(int depth, int deepen_relative,
|
||||||
struct object_array *shallows)
|
struct object_array *shallows)
|
||||||
{
|
{
|
||||||
if (depth == INFINITE_DEPTH && !is_repository_shallow()) {
|
if (depth == INFINITE_DEPTH && !is_repository_shallow(the_repository)) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < shallows->nr; i++) {
|
for (i = 0; i < shallows->nr; i++) {
|
||||||
@ -782,7 +783,8 @@ static int send_shallow_list(int depth, int deepen_rev_list,
|
|||||||
if (shallows->nr > 0) {
|
if (shallows->nr > 0) {
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < shallows->nr; i++)
|
for (i = 0; i < shallows->nr; i++)
|
||||||
register_shallow(&shallows->objects[i].item->oid);
|
register_shallow(the_repository,
|
||||||
|
&shallows->objects[i].item->oid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1356,14 +1358,15 @@ static void send_shallow_info(struct upload_pack_data *data)
|
|||||||
{
|
{
|
||||||
/* No shallow info needs to be sent */
|
/* No shallow info needs to be sent */
|
||||||
if (!data->depth && !data->deepen_rev_list && !data->shallows.nr &&
|
if (!data->depth && !data->deepen_rev_list && !data->shallows.nr &&
|
||||||
!is_repository_shallow())
|
!is_repository_shallow(the_repository))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
packet_write_fmt(1, "shallow-info\n");
|
packet_write_fmt(1, "shallow-info\n");
|
||||||
|
|
||||||
if (!send_shallow_list(data->depth, data->deepen_rev_list,
|
if (!send_shallow_list(data->depth, data->deepen_rev_list,
|
||||||
data->deepen_since, &data->deepen_not,
|
data->deepen_since, &data->deepen_not,
|
||||||
&data->shallows) && is_repository_shallow())
|
&data->shallows) &&
|
||||||
|
is_repository_shallow(the_repository))
|
||||||
deepen(INFINITE_DEPTH, data->deepen_relative, &data->shallows);
|
deepen(INFINITE_DEPTH, data->deepen_relative, &data->shallows);
|
||||||
|
|
||||||
packet_delim(1);
|
packet_delim(1);
|
||||||
|
1
walker.c
1
walker.c
@ -1,5 +1,6 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "walker.h"
|
#include "walker.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "commit.h"
|
#include "commit.h"
|
||||||
#include "tree.h"
|
#include "tree.h"
|
||||||
#include "tree-walk.h"
|
#include "tree-walk.h"
|
||||||
|
@ -1317,7 +1317,7 @@ static void show_rebase_in_progress(struct wt_status *s,
|
|||||||
status_printf_ln(s, color,
|
status_printf_ln(s, color,
|
||||||
_(" (use \"git rebase --abort\" to check out the original branch)"));
|
_(" (use \"git rebase --abort\" to check out the original branch)"));
|
||||||
}
|
}
|
||||||
} else if (state->rebase_in_progress || !stat(git_path_merge_msg(), &st)) {
|
} else if (state->rebase_in_progress || !stat(git_path_merge_msg(the_repository), &st)) {
|
||||||
print_rebase_state(s, state, color);
|
print_rebase_state(s, state, color);
|
||||||
if (s->hints)
|
if (s->hints)
|
||||||
status_printf_ln(s, color,
|
status_printf_ln(s, color,
|
||||||
@ -1552,17 +1552,17 @@ void wt_status_get_state(struct wt_status_state *state,
|
|||||||
struct stat st;
|
struct stat st;
|
||||||
struct object_id oid;
|
struct object_id oid;
|
||||||
|
|
||||||
if (!stat(git_path_merge_head(), &st)) {
|
if (!stat(git_path_merge_head(the_repository), &st)) {
|
||||||
state->merge_in_progress = 1;
|
state->merge_in_progress = 1;
|
||||||
} else if (wt_status_check_rebase(NULL, state)) {
|
} else if (wt_status_check_rebase(NULL, state)) {
|
||||||
; /* all set */
|
; /* all set */
|
||||||
} else if (!stat(git_path_cherry_pick_head(), &st) &&
|
} else if (!stat(git_path_cherry_pick_head(the_repository), &st) &&
|
||||||
!get_oid("CHERRY_PICK_HEAD", &oid)) {
|
!get_oid("CHERRY_PICK_HEAD", &oid)) {
|
||||||
state->cherry_pick_in_progress = 1;
|
state->cherry_pick_in_progress = 1;
|
||||||
oidcpy(&state->cherry_pick_head_oid, &oid);
|
oidcpy(&state->cherry_pick_head_oid, &oid);
|
||||||
}
|
}
|
||||||
wt_status_check_bisect(NULL, state);
|
wt_status_check_bisect(NULL, state);
|
||||||
if (!stat(git_path_revert_head(), &st) &&
|
if (!stat(git_path_revert_head(the_repository), &st) &&
|
||||||
!get_oid("REVERT_HEAD", &oid)) {
|
!get_oid("REVERT_HEAD", &oid)) {
|
||||||
state->revert_in_progress = 1;
|
state->revert_in_progress = 1;
|
||||||
oidcpy(&state->revert_head_oid, &oid);
|
oidcpy(&state->revert_head_oid, &oid);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "object-store.h"
|
||||||
#include "xdiff-interface.h"
|
#include "xdiff-interface.h"
|
||||||
#include "xdiff/xtypes.h"
|
#include "xdiff/xtypes.h"
|
||||||
#include "xdiff/xdiffi.h"
|
#include "xdiff/xdiffi.h"
|
||||||
|
Loading…
Reference in New Issue
Block a user