diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2018-01-12 22:06:16 +0100 |
---|---|---|
committer | Lubomir I. Ivanov <neolit123@gmail.com> | 2018-01-17 21:45:48 +0200 |
commit | 2d24dceafa3b8b41d44df6438cb5f52e5de2d4da (patch) | |
tree | e7e9d37395dff02660d9aa5e3d2b13a74ca8d2dd | |
parent | daede13571cd528b3cb054484a626d32326d3178 (diff) | |
download | subsurface-2d24dceafa3b8b41d44df6438cb5f52e5de2d4da.tar.gz |
Use format_string() in core/git_access.c
Since this helper-function exists, we might just use it. A subtle
reuse of a buffer (string of second use was known to be shorter than
string of first use) was replaced by a separate allocation.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r-- | core/git-access.c | 20 |
1 files changed, 7 insertions, 13 deletions
diff --git a/core/git-access.c b/core/git-access.c index 8a0b916e5..27cfe7831 100644 --- a/core/git-access.c +++ b/core/git-access.c @@ -676,7 +676,6 @@ static git_repository *create_and_push_remote(const char *localdir, const char * { git_repository *repo; git_config *conf; - int len; char *variable_name, *merge_head; if (verbose) @@ -694,18 +693,15 @@ static git_repository *create_and_push_remote(const char *localdir, const char * /* create a config so we can set the remote tracking branch */ git_repository_config(&conf, repo); - len = sizeof("branch..remote") + strlen(branch); - variable_name = malloc(len); - snprintf(variable_name, len, "branch.%s.remote", branch); + variable_name = format_string("branch.%s.remote", branch); git_config_set_string(conf, variable_name, "origin"); - /* we know this is shorter than the previous one, so we reuse the variable*/ - snprintf(variable_name, len, "branch.%s.merge", branch); - len = sizeof("refs/heads/") + strlen(branch); - merge_head = malloc(len); - snprintf(merge_head, len, "refs/heads/%s", branch); - git_config_set_string(conf, variable_name, merge_head); 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); + free(variable_name); /* finally create an empty commit and push it to the remote */ if (do_git_save(repo, branch, remote, false, true)) @@ -745,10 +741,8 @@ static git_repository *create_local_repo(const char *localdir, const char *remot msg = giterr_last()->message; fprintf(stderr, "error message was %s\n", msg); } - int len = sizeof("reference 'refs/remotes/origin/' not found") + strlen(branch); - char *pattern = malloc(len); + char *pattern = format_string("reference 'refs/remotes/origin/%s' not found", branch); // it seems that we sometimes get 'Reference' and sometimes 'reference' - snprintf(pattern, len, "reference 'refs/remotes/origin/%s' not found", branch); if (strstr(remote, prefs.cloud_git_url) && includes_string_caseinsensitive(msg, pattern)) { /* we're trying to open the remote branch that corresponds * to our cloud storage and the branch doesn't exist. |