diff options
author | Carlos Martín Nieto <carlos@cmartin.tk> | 2012-02-20 19:42:27 +0100 |
---|---|---|
committer | Carlos Martín Nieto <carlos@cmartin.tk> | 2012-02-20 19:48:41 +0100 |
commit | f0f3a18af66cd1d09b407748e6db0ab3707778bf (patch) | |
tree | 28d4caef9c691ea682b456a4f55da74c011ce51f /src/remote.c | |
parent | 89e5ed98dcdcb00de8a2758c6f7616ac7ab78837 (diff) | |
download | libgit2-f0f3a18af66cd1d09b407748e6db0ab3707778bf.tar.gz |
Move git_remote_load() to git_buf
Diffstat (limited to 'src/remote.c')
-rw-r--r-- | src/remote.c | 38 |
1 files changed, 16 insertions, 22 deletions
diff --git a/src/remote.c b/src/remote.c index d4caf0259..993037edf 100644 --- a/src/remote.c +++ b/src/remote.c @@ -96,9 +96,9 @@ int git_remote_new(git_remote **out, git_repository *repo, const char *url, cons int git_remote_load(git_remote **out, git_repository *repo, const char *name) { git_remote *remote; - char *buf = NULL; + git_buf buf = GIT_BUF_INIT; const char *val; - int ret, error, buf_len; + int error; git_config *config; assert(out && repo && name); @@ -123,21 +123,13 @@ int git_remote_load(git_remote **out, git_repository *repo, const char *name) goto cleanup; } - /* "fetch" is the longest var name we're interested in */ - buf_len = strlen("remote.") + strlen(".fetch") + strlen(name) + 1; - buf = git__malloc(buf_len); - if (buf == NULL) { + git_buf_printf(&buf, "remote.%s.url", name); + if (git_buf_oom(&buf)) { error = GIT_ENOMEM; goto cleanup; } - ret = p_snprintf(buf, buf_len, "%s.%s.%s", "remote", name, "url"); - if (ret < 0) { - error = git__throw(GIT_EOSERR, "Failed to build config var name"); - goto cleanup; - } - - error = git_config_get_string(config, buf, &val); + error = git_config_get_string(config, git_buf_cstr(&buf), &val); if (error < GIT_SUCCESS) { error = git__rethrow(error, "Remote's url doesn't exist"); goto cleanup; @@ -150,25 +142,27 @@ int git_remote_load(git_remote **out, git_repository *repo, const char *name) goto cleanup; } - ret = p_snprintf(buf, buf_len, "%s.%s.%s", "remote", name, "fetch"); - if (ret < 0) { - error = git__throw(GIT_EOSERR, "Failed to build config var name"); + git_buf_clear(&buf); + git_buf_printf(&buf, "remote.%s.fetch", name); + if (git_buf_oom(&buf)) { + error = GIT_ENOMEM; goto cleanup; } - error = parse_remote_refspec(config, &remote->fetch, buf); + error = parse_remote_refspec(config, &remote->fetch, git_buf_cstr(&buf)); if (error < GIT_SUCCESS) { error = git__rethrow(error, "Failed to get fetch refspec"); goto cleanup; } - ret = p_snprintf(buf, buf_len, "%s.%s.%s", "remote", name, "push"); - if (ret < 0) { - error = git__throw(GIT_EOSERR, "Failed to build config var name"); + git_buf_clear(&buf); + git_buf_printf(&buf, "remote.%s.push", name); + if (git_buf_oom(&buf)) { + error = GIT_ENOMEM; goto cleanup; } - error = parse_remote_refspec(config, &remote->push, buf); + error = parse_remote_refspec(config, &remote->push, git_buf_cstr(&buf)); /* Not finding push is fine */ if (error == GIT_ENOTFOUND) error = GIT_SUCCESS; @@ -179,7 +173,7 @@ int git_remote_load(git_remote **out, git_repository *repo, const char *name) *out = remote; cleanup: - git__free(buf); + git_buf_free(&buf); if (error < GIT_SUCCESS) git_remote_free(remote); |