summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEdward Thomson <ethomson@microsoft.com>2015-01-08 13:45:22 -0600
committerEdward Thomson <ethomson@microsoft.com>2015-01-08 13:45:22 -0600
commita8846da7b3c98fddf1cf9af87759d4db9452a147 (patch)
tree3d176d846ae93e97b7e76a047688a9dc462985da
parent1646412d8fc9e1532a194df2515e9a5fde4da988 (diff)
downloadlibgit2-a8846da7b3c98fddf1cf9af87759d4db9452a147.tar.gz
remote: plug leak
-rw-r--r--src/remote.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/src/remote.c b/src/remote.c
index c79e58a3c..5ba7735ae 100644
--- a/src/remote.c
+++ b/src/remote.c
@@ -139,7 +139,7 @@ static int canonicalize_url(git_buf *out, const char *in)
static int create_internal(git_remote **out, git_repository *repo, const char *name, const char *url, const char *fetch)
{
git_remote *remote;
- git_config *config;
+ git_config *config = NULL;
git_buf canonical_url = GIT_BUF_INIT, fetchbuf = GIT_BUF_INIT;
int error = -1;
@@ -183,12 +183,12 @@ static int create_internal(git_remote **out, git_repository *repo, const char *n
remote->download_tags = GIT_REMOTE_DOWNLOAD_TAGS_NONE;
*out = remote;
- git_buf_free(&fetchbuf);
- git_buf_free(&canonical_url);
- return 0;
+ error = 0;
on_error:
- git_remote_free(remote);
+ if (error)
+ git_remote_free(remote);
+
git_config_free(config);
git_buf_free(&fetchbuf);
git_buf_free(&canonical_url);