Unverified Commit 81ea9957 by Patrick Steinhardt Committed by GitHub

Merge pull request #4630 from tiennou/fix/worktree-from-bare

Worktrees can be made from bare repositories
parents a5723236 a82082d0
...@@ -268,11 +268,15 @@ static int load_config_data(git_repository *repo, const git_config *config) ...@@ -268,11 +268,15 @@ static int load_config_data(git_repository *repo, const git_config *config)
{ {
int is_bare; int is_bare;
int err = git_config_get_bool(&is_bare, config, "core.bare");
if (err < 0 && err != GIT_ENOTFOUND)
return err;
/* Try to figure out if it's bare, default to non-bare if it's not set */ /* Try to figure out if it's bare, default to non-bare if it's not set */
if (git_config_get_bool(&is_bare, config, "core.bare") < 0) if (err != GIT_ENOTFOUND)
repo->is_bare = 0; repo->is_bare = is_bare && !repo->is_worktree;
else else
repo->is_bare = is_bare; repo->is_bare = 0;
return 0; return 0;
} }
......
...@@ -139,7 +139,7 @@ static int open_worktree_dir(git_worktree **out, const char *parent, const char ...@@ -139,7 +139,7 @@ static int open_worktree_dir(git_worktree **out, const char *parent, const char
if ((wt->name = git__strdup(name)) == NULL if ((wt->name = git__strdup(name)) == NULL
|| (wt->commondir_path = git_worktree__read_link(dir, "commondir")) == NULL || (wt->commondir_path = git_worktree__read_link(dir, "commondir")) == NULL
|| (wt->gitlink_path = git_worktree__read_link(dir, "gitdir")) == NULL || (wt->gitlink_path = git_worktree__read_link(dir, "gitdir")) == NULL
|| (wt->parent_path = git__strdup(parent)) == NULL || (parent && (wt->parent_path = git__strdup(parent)) == NULL)
|| (wt->worktree_path = git_path_dirname(wt->gitlink_path)) == NULL) { || (wt->worktree_path = git_path_dirname(wt->gitlink_path)) == NULL) {
error = -1; error = -1;
goto out; goto out;
......
...@@ -228,6 +228,26 @@ void test_worktree_worktree__init(void) ...@@ -228,6 +228,26 @@ void test_worktree_worktree__init(void)
git_repository_free(repo); git_repository_free(repo);
} }
void test_worktree_worktree__add_from_bare(void)
{
git_worktree *wt;
git_repository *repo, *wtrepo;
repo = cl_git_sandbox_init("short_tag.git");
cl_assert_equal_i(1, git_repository_is_bare(repo));
cl_assert_equal_i(0, git_repository_is_worktree(repo));
cl_git_pass(git_worktree_add(&wt, repo, "worktree-frombare", "worktree-frombare", NULL));
cl_git_pass(git_repository_open(&wtrepo, "worktree-frombare"));
cl_assert_equal_i(0, git_repository_is_bare(wtrepo));
cl_assert_equal_i(1, git_repository_is_worktree(wtrepo));
git_worktree_free(wt);
git_repository_free(repo);
git_repository_free(wtrepo);
}
void test_worktree_worktree__add_locked(void) void test_worktree_worktree__add_locked(void)
{ {
git_worktree *wt; git_worktree *wt;
......
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