summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornulltoken <emeric.fermas@gmail.com>2012-04-10 14:03:47 +0200
committerVicent Martí <tanoku@gmail.com>2012-04-11 12:40:21 +0200
commitb78fb64d2f5c1b9e2e834e05e042271147c8d188 (patch)
tree807091971c8ca681cb4e78c6c0ca4bc326bf1797
parentdcfdb958e2033aa59beb624da4263ce031fbb21e (diff)
downloadlibgit2-b78fb64d2f5c1b9e2e834e05e042271147c8d188.tar.gz
repository: make git_repository_set_workdir() prettify the path it is being passed
-rw-r--r--src/repository.c9
-rw-r--r--tests-clar/repo/setters.c34
2 files changed, 40 insertions, 3 deletions
diff --git a/src/repository.c b/src/repository.c
index 4e0f9d491..ce313280e 100644
--- a/src/repository.c
+++ b/src/repository.c
@@ -871,13 +871,16 @@ const char *git_repository_workdir(git_repository *repo)
int git_repository_set_workdir(git_repository *repo, const char *workdir)
{
+ git_buf path = GIT_BUF_INIT;
+
assert(repo && workdir);
- free(repo->workdir);
+ if (git_path_prettify_dir(&path, workdir, NULL) < 0)
+ return -1;
- repo->workdir = git__strdup(workdir);
- GITERR_CHECK_ALLOC(repo->workdir);
+ free(repo->workdir);
+ repo->workdir = git_buf_detach(&path);
repo->is_bare = 0;
return 0;
}
diff --git a/tests-clar/repo/setters.c b/tests-clar/repo/setters.c
new file mode 100644
index 000000000..7a65a404b
--- /dev/null
+++ b/tests-clar/repo/setters.c
@@ -0,0 +1,34 @@
+#include "clar_libgit2.h"
+#include "buffer.h"
+
+static git_repository *repo;
+
+void test_repo_setters__initialize(void)
+{
+ cl_fixture_sandbox("testrepo.git");
+ cl_git_pass(git_repository_open(&repo, "testrepo.git"));
+}
+
+void test_repo_setters__cleanup(void)
+{
+ git_repository_free(repo);
+ cl_fixture_cleanup("testrepo.git");
+}
+
+void test_repo_setters__setting_a_workdir_turns_a_bare_repository_into_a_standard_one(void)
+{
+ cl_assert(git_repository_is_bare(repo) == 1);
+
+ cl_assert(git_repository_workdir(repo) == NULL);
+ cl_git_pass(git_repository_set_workdir(repo, "./new_workdir"));
+
+ cl_assert(git_repository_workdir(repo) != NULL);
+ cl_assert(git_repository_is_bare(repo) == 0);
+}
+
+void test_repo_setters__setting_a_workdir_prettifies_its_path(void)
+{
+ cl_git_pass(git_repository_set_workdir(repo, "./new_workdir"));
+
+ cl_assert(git__suffixcmp(git_repository_workdir(repo), "/") == 0);
+}