summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--CHANGELOG.md2
-rw-r--r--src/branch.c6
-rw-r--r--src/filter.c3
-rw-r--r--src/refdb_fs.c2
-rw-r--r--tests/filter/file.c97
-rw-r--r--tests/refs/branches/create.c2
-rw-r--r--tests/refs/branches/move.c6
7 files changed, 110 insertions, 8 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 6f9e1f1cb..0970bfdc8 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -30,6 +30,8 @@ v0.22 + 1
* `git_config_get_string_buf()` provides a way to safely retrieve a
string from a non-snapshot configuration.
+* Reference renaming now uses the right id for the old value.
+
### API removals
### Breaking API changes
diff --git a/src/branch.c b/src/branch.c
index 06602c525..a16d3a3f9 100644
--- a/src/branch.c
+++ b/src/branch.c
@@ -82,11 +82,11 @@ int git_branch_create(
error = -1;
goto cleanup;
}
-
+
if (git_buf_joinpath(&canonical_branch_name, GIT_REFS_HEADS_DIR, branch_name) < 0)
goto cleanup;
- if (git_buf_printf(&log_message, "Branch: created from %s", git_oid_tostr_s(git_commit_id(commit))) < 0)
+ if (git_buf_printf(&log_message, "branch: Created from %s", git_oid_tostr_s(git_commit_id(commit))) < 0)
goto cleanup;
error = git_reference_create(&branch, repository,
@@ -236,7 +236,7 @@ int git_branch_move(
if ((error = git_buf_joinpath(&new_reference_name, GIT_REFS_HEADS_DIR, new_branch_name)) < 0)
goto done;
- if ((error = git_buf_printf(&log_message, "Branch: renamed %s to %s",
+ if ((error = git_buf_printf(&log_message, "branch: renamed %s to %s",
git_reference_name(branch), git_buf_cstr(&new_reference_name))) < 0)
goto done;
diff --git a/src/filter.c b/src/filter.c
index 4fbf84f6a..6d0d48015 100644
--- a/src/filter.c
+++ b/src/filter.c
@@ -874,7 +874,6 @@ void stream_list_free(git_vector *streams)
#define STREAM_BUFSIZE 10240
-/* TODO: maybe not use filter_stream as a target but create one */
int git_filter_list_stream_file(
git_filter_list *filters,
git_repository *repo,
@@ -894,7 +893,7 @@ int git_filter_list_stream_file(
(error = git_path_join_unrooted(&abspath, path, base, NULL)) < 0)
goto done;
- if ((fd = git_futils_open_ro(path)) < 0) {
+ if ((fd = git_futils_open_ro(abspath.ptr)) < 0) {
error = fd;
goto done;
}
diff --git a/src/refdb_fs.c b/src/refdb_fs.c
index 77cb1a8ce..e1a77f3ff 100644
--- a/src/refdb_fs.c
+++ b/src/refdb_fs.c
@@ -1324,7 +1324,7 @@ static int refdb_fs_backend__rename(
/* Try to rename the refog; it's ok if the old doesn't exist */
error = refdb_reflog_fs__rename(_backend, old_name, new_name);
if (((error == 0) || (error == GIT_ENOTFOUND)) &&
- ((error = reflog_append(backend, new, NULL, NULL, who, message)) < 0)) {
+ ((error = reflog_append(backend, new, git_reference_target(new), NULL, who, message)) < 0)) {
git_reference_free(new);
git_filebuf_cleanup(&file);
return error;
diff --git a/tests/filter/file.c b/tests/filter/file.c
new file mode 100644
index 000000000..865c416c5
--- /dev/null
+++ b/tests/filter/file.c
@@ -0,0 +1,97 @@
+#include "clar_libgit2.h"
+#include "git2/sys/filter.h"
+#include "crlf.h"
+#include "buffer.h"
+
+static git_repository *g_repo = NULL;
+
+void test_filter_file__initialize(void)
+{
+ git_reference *head_ref;
+ git_commit *head;
+
+ g_repo = cl_git_sandbox_init("crlf");
+
+ cl_git_mkfile("crlf/.gitattributes",
+ "*.txt text\n*.bin binary\n*.crlf text eol=crlf\n*.lf text eol=lf\n");
+
+ cl_repo_set_bool(g_repo, "core.autocrlf", true);
+
+ cl_git_pass(git_repository_head(&head_ref, g_repo));
+ cl_git_pass(git_reference_peel((git_object **)&head, head_ref, GIT_OBJ_COMMIT));
+ cl_git_pass(git_reset(g_repo, (git_object *)head, GIT_RESET_HARD, NULL));
+
+ git_commit_free(head);
+ git_reference_free(head_ref);
+}
+
+void test_filter_file__cleanup(void)
+{
+ cl_git_sandbox_cleanup();
+}
+
+void test_filter_file__apply(void)
+{
+ git_filter_list *fl;
+ git_filter *crlf;
+ git_buf buf = GIT_BUF_INIT;
+
+ cl_git_pass(git_filter_list_new(
+ &fl, g_repo, GIT_FILTER_TO_ODB, 0));
+
+ crlf = git_filter_lookup(GIT_FILTER_CRLF);
+ cl_assert(crlf != NULL);
+
+ cl_git_pass(git_filter_list_push(fl, crlf, NULL));
+
+ cl_git_pass(git_filter_list_apply_to_file(&buf, fl, g_repo, "all-crlf"));
+ cl_assert_equal_s("crlf\ncrlf\ncrlf\ncrlf\n", buf.ptr);
+
+ git_buf_free(&buf);
+ git_filter_list_free(fl);
+}
+
+struct buf_writestream {
+ git_writestream base;
+ git_buf buf;
+};
+
+int buf_writestream_write(git_writestream *s, const char *buf, size_t len)
+{
+ struct buf_writestream *stream = (struct buf_writestream *)s;
+ return git_buf_put(&stream->buf, buf, len);
+}
+
+int buf_writestream_close(git_writestream *s)
+{
+ return 0;
+}
+
+void buf_writestream_free(git_writestream *s)
+{
+ struct buf_writestream *stream = (struct buf_writestream *)s;
+ git_buf_free(&stream->buf);
+}
+
+void test_filter_file__apply_stream(void)
+{
+ git_filter_list *fl;
+ git_filter *crlf;
+ struct buf_writestream write_target = { {
+ buf_writestream_write,
+ buf_writestream_close,
+ buf_writestream_free } };
+
+ cl_git_pass(git_filter_list_new(
+ &fl, g_repo, GIT_FILTER_TO_ODB, 0));
+
+ crlf = git_filter_lookup(GIT_FILTER_CRLF);
+ cl_assert(crlf != NULL);
+
+ cl_git_pass(git_filter_list_push(fl, crlf, NULL));
+
+ cl_git_pass(git_filter_list_stream_file(fl, g_repo, "all-crlf", (git_writestream *)&write_target));
+ cl_assert_equal_s("crlf\ncrlf\ncrlf\ncrlf\n", write_target.buf.ptr);
+
+ git_filter_list_free(fl);
+}
diff --git a/tests/refs/branches/create.c b/tests/refs/branches/create.c
index dc805789f..d4cf4c29f 100644
--- a/tests/refs/branches/create.c
+++ b/tests/refs/branches/create.c
@@ -112,7 +112,7 @@ void test_refs_branches_create__default_reflog_message(void)
cl_git_pass(git_reflog_read(&log, repo, "refs/heads/" NEW_BRANCH_NAME));
entry = git_reflog_entry_byindex(log, 0);
- cl_git_pass(git_buf_printf(&buf, "Branch: created from %s", git_oid_tostr_s(git_commit_id(target))));
+ cl_git_pass(git_buf_printf(&buf, "branch: Created from %s", git_oid_tostr_s(git_commit_id(target))));
cl_assert_equal_s(git_buf_cstr(&buf), git_reflog_entry_message(entry));
cl_assert_equal_s(sig->email, git_reflog_entry_committer(entry)->email);
diff --git a/tests/refs/branches/move.c b/tests/refs/branches/move.c
index 6e335d1fa..bec39e18b 100644
--- a/tests/refs/branches/move.c
+++ b/tests/refs/branches/move.c
@@ -203,6 +203,7 @@ void test_refs_branches_move__default_reflog_message(void)
const git_reflog_entry *entry;
git_signature *sig;
git_config *cfg;
+ git_oid id;
cl_git_pass(git_repository_config(&cfg, repo));
cl_git_pass(git_config_set_string(cfg, "user.name", "Foo Bar"));
@@ -212,13 +213,16 @@ void test_refs_branches_move__default_reflog_message(void)
cl_git_pass(git_signature_default(&sig, repo));
cl_git_pass(git_reference_lookup(&branch, repo, "refs/heads/master"));
+ git_oid_cpy(&id, git_reference_target(branch));
cl_git_pass(git_branch_move(&new_branch, branch, "master2", 0));
cl_git_pass(git_reflog_read(&log, repo, git_reference_name(new_branch)));
entry = git_reflog_entry_byindex(log, 0);
- cl_assert_equal_s("Branch: renamed refs/heads/master to refs/heads/master2",
+ cl_assert_equal_s("branch: renamed refs/heads/master to refs/heads/master2",
git_reflog_entry_message(entry));
cl_assert_equal_s(sig->email, git_reflog_entry_committer(entry)->email);
+ cl_assert_equal_oid(&id, git_reflog_entry_id_old(entry));
+ cl_assert_equal_oid(&id, git_reflog_entry_id_new(entry));
git_reference_free(branch);
git_reference_free(new_branch);