Commit 0d95f6ec by Vicent Marti

Merge pull request #2169 from libgit2/valgrind

Plug leaks
parents c81e4adf ae32c54e
...@@ -66,16 +66,22 @@ int git_branch_create( ...@@ -66,16 +66,22 @@ int git_branch_create(
assert(branch_name && commit && ref_out); assert(branch_name && commit && ref_out);
assert(git_object_owner((const git_object *)commit) == repository); assert(git_object_owner((const git_object *)commit) == repository);
if (git_branch_lookup(&branch, repository, branch_name, GIT_BRANCH_LOCAL) == 0) {
if ((is_head = git_branch_is_head(branch)) < 0) { if (force && git_branch_lookup(&branch, repository, branch_name, GIT_BRANCH_LOCAL) == 0) {
error = is_head; error = git_branch_is_head(branch);
git_reference_free(branch);
branch = NULL;
if (error < 0)
goto cleanup; goto cleanup;
}
is_head = error;
} }
if (is_head && force) { if (is_head && force) {
giterr_set(GITERR_REFERENCE, "Cannot force update branch '%s' as it is " giterr_set(GITERR_REFERENCE, "Cannot force update branch '%s' as it is "
"the current HEAD of the repository.", git_reference_name(branch)); "the current HEAD of the repository.", branch_name);
error = -1;
goto cleanup; goto cleanup;
} }
......
...@@ -455,18 +455,17 @@ int git_commit_nth_gen_ancestor( ...@@ -455,18 +455,17 @@ int git_commit_nth_gen_ancestor(
assert(ancestor && commit); assert(ancestor && commit);
current = (git_commit *)commit; if (git_object_dup((git_object **) &current, (git_object *) commit) < 0)
return -1;
if (n == 0) if (n == 0) {
return git_commit_lookup( *ancestor = current;
ancestor, return 0;
commit->object.repo, }
git_object_id((const git_object *)commit));
while (n--) { while (n--) {
error = git_commit_parent(&parent, (git_commit *)current, 0); error = git_commit_parent(&parent, current, 0);
if (current != commit)
git_commit_free(current); git_commit_free(current);
if (error < 0) if (error < 0)
......
...@@ -1343,7 +1343,10 @@ static int refdb_reflog_fs__ensure_log(git_refdb_backend *_backend, const char * ...@@ -1343,7 +1343,10 @@ static int refdb_reflog_fs__ensure_log(git_refdb_backend *_backend, const char *
if ((error = retrieve_reflog_path(&path, repo, name)) < 0) if ((error = retrieve_reflog_path(&path, repo, name)) < 0)
return error; return error;
return create_new_reflog_file(git_buf_cstr(&path)); error = create_new_reflog_file(git_buf_cstr(&path));
git_buf_free(&path);
return error;
} }
static int has_reflog(git_repository *repo, const char *name) static int has_reflog(git_repository *repo, const char *name)
......
...@@ -167,6 +167,7 @@ cleanup: ...@@ -167,6 +167,7 @@ cleanup:
git_object_free(commit); git_object_free(commit);
git_index_free(index); git_index_free(index);
git_tree_free(tree); git_tree_free(tree);
git_buf_free(&log_message_buf);
return error; return error;
} }
...@@ -194,6 +194,9 @@ static int local_connect( ...@@ -194,6 +194,9 @@ static int local_connect(
GIT_UNUSED(cred_acquire_cb); GIT_UNUSED(cred_acquire_cb);
GIT_UNUSED(cred_acquire_payload); GIT_UNUSED(cred_acquire_payload);
if (t->connected)
return 0;
t->url = git__strdup(url); t->url = git__strdup(url);
GITERR_CHECK_ALLOC(t->url); GITERR_CHECK_ALLOC(t->url);
t->direction = direction; t->direction = direction;
......
...@@ -53,11 +53,13 @@ void test_clone_empty__can_clone_an_empty_local_repo_barely(void) ...@@ -53,11 +53,13 @@ void test_clone_empty__can_clone_an_empty_local_repo_barely(void)
cl_git_pass(git_branch_upstream_name(&buf, g_repo_cloned, local_name)); cl_git_pass(git_branch_upstream_name(&buf, g_repo_cloned, local_name));
cl_assert_equal_s(expected_tracked_branch_name, buf.ptr); cl_assert_equal_s(expected_tracked_branch_name, buf.ptr);
git_buf_free(&buf);
/* ...and the name of the remote... */ /* ...and the name of the remote... */
cl_git_pass(git_branch_remote_name(&buf, g_repo_cloned, expected_tracked_branch_name)); cl_git_pass(git_branch_remote_name(&buf, g_repo_cloned, expected_tracked_branch_name));
cl_assert_equal_s(expected_remote_name, buf.ptr); cl_assert_equal_s(expected_remote_name, buf.ptr);
git_buf_free(&buf);
/* ...even when the remote HEAD is unborn as well */ /* ...even when the remote HEAD is unborn as well */
cl_assert_equal_i(GIT_ENOTFOUND, git_reference_lookup(&ref, g_repo_cloned, cl_assert_equal_i(GIT_ENOTFOUND, git_reference_lookup(&ref, g_repo_cloned,
......
...@@ -18,6 +18,11 @@ void test_odb_backend_nobackend__initialize(void) ...@@ -18,6 +18,11 @@ void test_odb_backend_nobackend__initialize(void)
git_repository_set_config(_repo, config); git_repository_set_config(_repo, config);
git_repository_set_odb(_repo, odb); git_repository_set_odb(_repo, odb);
git_repository_set_refdb(_repo, refdb); git_repository_set_refdb(_repo, refdb);
/* The set increases the refcount and we don't want them anymore */
git_config_free(config);
git_odb_free(odb);
git_refdb_free(refdb);
} }
void test_odb_backend_nobackend__cleanup(void) void test_odb_backend_nobackend__cleanup(void)
......
...@@ -212,12 +212,16 @@ void test_reset_hard__reflog_is_correct(void) ...@@ -212,12 +212,16 @@ void test_reset_hard__reflog_is_correct(void)
reflog_check(repo, "HEAD", 3, "emeric.fermas@gmail.com", exp_msg); reflog_check(repo, "HEAD", 3, "emeric.fermas@gmail.com", exp_msg);
reflog_check(repo, "refs/heads/master", 3, "emeric.fermas@gmail.com", exp_msg); reflog_check(repo, "refs/heads/master", 3, "emeric.fermas@gmail.com", exp_msg);
git_object_free(target);
/* Moved branch, expect default message */ /* Moved branch, expect default message */
cl_git_pass(git_revparse_single(&target, repo, "HEAD~^{commit}")); cl_git_pass(git_revparse_single(&target, repo, "HEAD~^{commit}"));
cl_git_pass(git_reset(repo, target, GIT_RESET_HARD, NULL, NULL)); cl_git_pass(git_reset(repo, target, GIT_RESET_HARD, NULL, NULL));
reflog_check(repo, "HEAD", 3, "emeric.fermas@gmail.com", exp_msg); reflog_check(repo, "HEAD", 3, "emeric.fermas@gmail.com", exp_msg);
reflog_check(repo, "refs/heads/master", 4, NULL, "reset: moving"); reflog_check(repo, "refs/heads/master", 4, NULL, "reset: moving");
git_object_free(target);
/* Moved branch, expect custom message */ /* Moved branch, expect custom message */
cl_git_pass(git_revparse_single(&target, repo, "HEAD~^{commit}")); cl_git_pass(git_revparse_single(&target, repo, "HEAD~^{commit}"));
cl_git_pass(git_reset(repo, target, GIT_RESET_HARD, NULL, "message1")); cl_git_pass(git_reset(repo, target, GIT_RESET_HARD, NULL, "message1"));
......
...@@ -61,12 +61,18 @@ void test_reset_mixed__reflog_is_correct(void) ...@@ -61,12 +61,18 @@ void test_reset_mixed__reflog_is_correct(void)
reflog_check(repo, "HEAD", 9, "yoram.harmelin@gmail.com", exp_msg); reflog_check(repo, "HEAD", 9, "yoram.harmelin@gmail.com", exp_msg);
reflog_check(repo, "refs/heads/master", 9, "yoram.harmelin@gmail.com", exp_msg); reflog_check(repo, "refs/heads/master", 9, "yoram.harmelin@gmail.com", exp_msg);
git_object_free(target);
target = NULL;
/* Moved branch, expect default message */ /* Moved branch, expect default message */
cl_git_pass(git_revparse_single(&target, repo, "HEAD~^{commit}")); cl_git_pass(git_revparse_single(&target, repo, "HEAD~^{commit}"));
cl_git_pass(git_reset(repo, target, GIT_RESET_MIXED, NULL, NULL)); cl_git_pass(git_reset(repo, target, GIT_RESET_MIXED, NULL, NULL));
reflog_check(repo, "HEAD", 9, "yoram.harmelin@gmail.com", exp_msg); reflog_check(repo, "HEAD", 9, "yoram.harmelin@gmail.com", exp_msg);
reflog_check(repo, "refs/heads/master", 10, NULL, "reset: moving"); reflog_check(repo, "refs/heads/master", 10, NULL, "reset: moving");
git_object_free(target);
target = NULL;
/* Moved branch, expect custom message */ /* Moved branch, expect custom message */
cl_git_pass(git_revparse_single(&target, repo, "HEAD~^{commit}")); cl_git_pass(git_revparse_single(&target, repo, "HEAD~^{commit}"));
cl_git_pass(git_reset(repo, target, GIT_RESET_MIXED, NULL, "message1")); cl_git_pass(git_reset(repo, target, GIT_RESET_MIXED, NULL, "message1"));
......
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