repository: Do not double-free config

parent 4e964117
......@@ -1691,20 +1691,20 @@ int git_repository_set_bare(git_repository *repo)
if (repo->is_bare)
return 0;
if ((error = git_repository_config__weakptr(&config, repo)) < 0 ||
(error = git_config_set_bool(config, "core.bare", false)) < 0)
goto done;
if ((error = git_repository_config__weakptr(&config, repo)) < 0)
return error;
if ((error = git_config_set_bool(config, "core.bare", false)) < 0)
return error;
error = git_config__update_entry(config, "core.worktree", NULL, true, true);
if ((error = git_config__update_entry(config, "core.worktree", NULL, true, true)) < 0)
return error;
git__free(repo->workdir);
repo->workdir = NULL;
repo->is_bare = 1;
done:
git_config_free(config);
return error;
return 0;
}
int git_repository_head_tree(git_tree **tree, git_repository *repo)
......
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