summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLibravatar Johannes Schindelin <Johannes.Schindelin@gmx.de>2007-08-01 01:29:38 +0100
committerLibravatar Junio C Hamano <gitster@pobox.com>2007-08-01 00:38:31 -0700
commitd7ac12b25d375d32372b13f74e90425ca21d5dc1 (patch)
treea79db447d85ee9a56f51851f5eafba6daf197b8a
parentAdd functions get_relative_cwd() and is_inside_dir() (diff)
downloadtgif-d7ac12b25d375d32372b13f74e90425ca21d5dc1.tar.xz
Add set_git_dir() function
With the function set_git_dir() you can reset the path that will be used for git_path(), git_dir() and friends. The responsibility to close files and throw away information from the old git_dir lies with the caller. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r--cache.h1
-rw-r--r--environment.c8
2 files changed, 9 insertions, 0 deletions
diff --git a/cache.h b/cache.h
index 98af53040d..e1f94cbade 100644
--- a/cache.h
+++ b/cache.h
@@ -214,6 +214,7 @@ extern char *get_object_directory(void);
extern char *get_refs_directory(void);
extern char *get_index_file(void);
extern char *get_graft_file(void);
+extern int set_git_dir(const char *path);
#define ALTERNATE_DB_ENVIRONMENT "GIT_ALTERNATE_OBJECT_DIRECTORIES"
diff --git a/environment.c b/environment.c
index f83fb9e448..a571fae607 100644
--- a/environment.c
+++ b/environment.c
@@ -107,3 +107,11 @@ char *get_graft_file(void)
setup_git_env();
return git_graft_file;
}
+
+int set_git_dir(const char *path)
+{
+ if (setenv(GIT_DIR_ENVIRONMENT, path, 1))
+ return error("Could not set GIT_DIR to '%s'", path);
+ setup_git_env();
+ return 0;
+}