Commit 2b63db4c by Ben Straub

Clone: update index to HEAD.

git_clone now produces a repo that 
`git status` reports as clean!
parent 24b0d3d5
...@@ -17,6 +17,8 @@ ...@@ -17,6 +17,8 @@
#include "git2/branch.h" #include "git2/branch.h"
#include "git2/config.h" #include "git2/config.h"
#include "git2/checkout.h" #include "git2/checkout.h"
#include "git2/commit.h"
#include "git2/tree.h"
#include "common.h" #include "common.h"
#include "remote.h" #include "remote.h"
...@@ -31,7 +33,7 @@ struct HeadInfo { ...@@ -31,7 +33,7 @@ struct HeadInfo {
git_buf branchname; git_buf branchname;
}; };
static int create_tracking_branch(git_repository *repo, git_oid *target, const char *name) static int create_tracking_branch(git_repository *repo, const git_oid *target, const char *name)
{ {
git_object *head_obj = NULL; git_object *head_obj = NULL;
git_oid branch_oid; git_oid branch_oid;
...@@ -83,19 +85,35 @@ static int reference_matches_remote_head(const char *head_name, void *payload) ...@@ -83,19 +85,35 @@ static int reference_matches_remote_head(const char *head_name, void *payload)
return 0; return 0;
} }
static int update_head_to_new_branch(git_repository *repo, git_oid *target, const char *name) static int update_head_to_new_branch(git_repository *repo, const git_oid *target, const char *name)
{ {
int retcode = GIT_ERROR; int retcode = GIT_ERROR;
if (!create_tracking_branch(repo, target, name)) { if (!create_tracking_branch(repo, target, name)) {
git_reference *head; git_reference *head;
if (!git_reference_lookup(&head, repo, GIT_HEAD_FILE)) { if (!git_reference_lookup(&head, repo, GIT_HEAD_FILE)) {
git_buf target = GIT_BUF_INIT; git_buf targetbuf = GIT_BUF_INIT;
if (!git_buf_printf(&target, "refs/heads/%s", name) && if (!git_buf_printf(&targetbuf, "refs/heads/%s", name) &&
!git_reference_set_target(head, git_buf_cstr(&target))) { !git_reference_set_target(head, git_buf_cstr(&targetbuf))) {
/* Read the tree into the index */
git_commit *commit;
if (!git_commit_lookup(&commit, repo, target)) {
git_tree *tree;
if (!git_commit_tree(&tree, commit)) {
git_index *index;
if (!git_repository_index(&index, repo)) {
if (!git_index_read_tree(index, tree)) {
git_index_write(index);
retcode = 0; retcode = 0;
} }
git_buf_free(&target); git_index_free(index);
}
git_tree_free(tree);
}
git_commit_free(commit);
}
}
git_buf_free(&targetbuf);
git_reference_free(head); git_reference_free(head);
} }
} }
...@@ -144,8 +162,7 @@ static int update_head_to_remote(git_repository *repo, git_remote *remote) ...@@ -144,8 +162,7 @@ static int update_head_to_remote(git_repository *repo, git_remote *remote)
static int setup_remotes_and_fetch(git_repository *repo, static int setup_remotes_and_fetch(git_repository *repo,
const char *origin_url, const char *origin_url,
git_indexer_stats *stats, git_indexer_stats *stats)
int update_head)
{ {
int retcode = GIT_ERROR; int retcode = GIT_ERROR;
git_remote *origin = NULL; git_remote *origin = NULL;
...@@ -162,8 +179,7 @@ static int setup_remotes_and_fetch(git_repository *repo, ...@@ -162,8 +179,7 @@ static int setup_remotes_and_fetch(git_repository *repo,
/* Create "origin/foo" branches for all remote branches */ /* Create "origin/foo" branches for all remote branches */
if (!git_remote_update_tips(origin, NULL)) { if (!git_remote_update_tips(origin, NULL)) {
/* Point HEAD to the same ref as the remote's head */ /* Point HEAD to the same ref as the remote's head */
if (!update_head) retcode = 0; if (!update_head_to_remote(repo, origin)) {
else if (!update_head_to_remote(repo, origin)) {
retcode = 0; retcode = 0;
} }
} }
...@@ -252,7 +268,7 @@ static int clone_internal(git_repository **out, ...@@ -252,7 +268,7 @@ static int clone_internal(git_repository **out,
} }
if (!(retcode = git_repository_init(&repo, path, is_bare))) { if (!(retcode = git_repository_init(&repo, path, is_bare))) {
if ((retcode = setup_remotes_and_fetch(repo, origin_url, stats, !is_bare)) < 0) { if ((retcode = setup_remotes_and_fetch(repo, origin_url, stats)) < 0) {
/* Failed to fetch; clean up */ /* Failed to fetch; clean up */
git_repository_free(repo); git_repository_free(repo);
git_futils_rmdir_r(path, GIT_DIRREMOVAL_FILES_AND_DIRS); git_futils_rmdir_r(path, GIT_DIRREMOVAL_FILES_AND_DIRS);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment