Commit ca481fc4f12cec56b71bd50ae72e3f088b69021f

Ramsay Jones 2009-06-04T16:46:54

Add the git_move_file() function Signed-off-by: Ramsay Jones <ramsay@ramsay1.demon.co.uk> Signed-off-by: Andreas Ericsson <ae@op5.se>

diff --git a/src/fileops.c b/src/fileops.c
index 581dc35..3d35c19 100644
--- a/src/fileops.c
+++ b/src/fileops.c
@@ -105,6 +105,19 @@ void gitfo_free_buf(gitfo_buf *obj)
 	obj->data = NULL;
 }
 
+int gitfo_move_file(char *from, char *to)
+{
+	if (!link(from, to)) {
+		gitfo_unlink(from);
+		return GIT_SUCCESS;
+	}
+
+	if (!rename(from, to))
+		return GIT_SUCCESS;
+
+	return git_os_error();
+}
+
 int gitfo_map_ro(git_map *out, git_file fd, off_t begin, size_t len)
 {
 	if (git__mmap(out, len, GIT_PROT_READ, GIT_MAP_SHARED, fd, begin) < 0)
diff --git a/src/fileops.h b/src/fileops.h
index 5684642..1753969 100644
--- a/src/fileops.h
+++ b/src/fileops.h
@@ -69,6 +69,7 @@ extern off_t gitfo_size(git_file fd);
 
 extern int gitfo_read_file(gitfo_buf *obj, const char *path);
 extern void gitfo_free_buf(gitfo_buf *obj);
+extern int gitfo_move_file(char *from, char *to);
 
 #define gitfo_unlink(p) unlink(p)
 #define gitfo_rmdir(p) rmdir(p)