summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/git-access.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/core/git-access.c b/core/git-access.c
index 0db4faf8e..b015524cb 100644
--- a/core/git-access.c
+++ b/core/git-access.c
@@ -703,7 +703,7 @@ static git_repository *create_and_push_remote(const char *localdir, const char *
{
git_repository *repo;
git_config *conf;
- char *variable_name, *merge_head;
+ char *variable_name, *head;
if (verbose)
fprintf(stderr, "git storage: create and push remote\n");
@@ -711,9 +711,12 @@ static git_repository *create_and_push_remote(const char *localdir, const char *
/* first make sure the directory for the local cache exists */
subsurface_mkdir(localdir);
+ head = format_string("refs/heads/%s", branch);
+
/* set up the origin to point to our remote */
git_repository_init_options init_opts = GIT_REPOSITORY_INIT_OPTIONS_INIT;
init_opts.origin_url = remote;
+ init_opts.initial_head = head;
/* now initialize the repository with */
git_repository_init_ext(&repo, localdir, &init_opts);
@@ -725,9 +728,8 @@ static git_repository *create_and_push_remote(const char *localdir, const char *
free(variable_name);
variable_name = format_string("branch.%s.merge", branch);
- merge_head = format_string("refs/heads/%s", branch);
- git_config_set_string(conf, variable_name, merge_head);
- free(merge_head);
+ git_config_set_string(conf, variable_name, head);
+ free(head);
free(variable_name);
/* finally create an empty commit and push it to the remote */