* [PATCH 3/5] Clean up work-tree handling
@ 2007-07-26 6:30 Johannes Schindelin
2007-07-26 6:56 ` Shawn O. Pearce
` (2 more replies)
0 siblings, 3 replies; 10+ messages in thread
From: Johannes Schindelin @ 2007-07-26 6:30 UTC (permalink / raw)
To: git, gitster
The old version of work-tree support was an unholy mess, barely readable,
and not to the point.
For example, why do you have to provide a worktree, when it is not used?
As in "git status". Now it works.
Another riddle was: if you can have work trees inside the git dir, why
are some programs complaining that they need a work tree?
IOW when inside repo.git/work, where GIT_DIR points to repo.git
and GIT_WORK_TREE to work, and cwd is work, --is-inside-git-dir _must_
return true, because it is _in the git dir_, but scripts _must_ test
for the right thing.
In related news, there is a long standing bug fixed: when in
.git/bla/x.git/, which is a bare repository, git formerly assumed
../.. to be the appropriate git dir.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
---
Okay, this diffstat looks so good also because I refactored some
useful stuff out. So it is only half cheating.
However, from the diff you only can see how horrible the code
looked like. The new version of setup_git_directory_gently()
actually resembles the pre-work-tree version very much,
with the notable exception that it is tested for bare repo
right after testing .git/, and only after both failed, continue
to assume that we're in a subdirectory.
cache.h | 2 +
environment.c | 31 +++++--
git.c | 2 +-
setup.c | 242 +++++++++++++++++++-------------------------------------
4 files changed, 107 insertions(+), 170 deletions(-)
diff --git a/cache.h b/cache.h
index b242147..7c55a1d 100644
--- a/cache.h
+++ b/cache.h
@@ -208,12 +208,14 @@ enum object_type {
extern int is_bare_repository_cfg;
extern int is_bare_repository(void);
extern int is_inside_git_dir(void);
+extern char *git_work_tree_cfg;
extern int is_inside_work_tree(void);
extern const char *get_git_dir(void);
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 const char *get_git_work_tree(void);
#define ALTERNATE_DB_ENVIRONMENT "GIT_ALTERNATE_OBJECT_DIRECTORIES"
diff --git a/environment.c b/environment.c
index f83fb9e..fa177ac 100644
--- a/environment.c
+++ b/environment.c
@@ -35,6 +35,10 @@ int pager_in_use;
int pager_use_color = 1;
int auto_crlf = 0; /* 1: both ways, -1: only when adding git objects */
+/* This is set by setup_git_dir_gently() and/or git_default_config() */
+char *git_work_tree_cfg;
+static const char *work_tree;
+
static const char *git_dir;
static char *git_object_dir, *git_index_file, *git_refs_dir, *git_graft_file;
@@ -62,15 +66,7 @@ static void setup_git_env(void)
int is_bare_repository(void)
{
- const char *dir, *s;
- if (0 <= is_bare_repository_cfg)
- return is_bare_repository_cfg;
-
- dir = get_git_dir();
- if (!strcmp(dir, DEFAULT_GIT_DIR_ENVIRONMENT))
- return 0;
- s = strrchr(dir, '/');
- return !s || strcmp(s + 1, DEFAULT_GIT_DIR_ENVIRONMENT);
+ return !get_git_work_tree();
}
const char *get_git_dir(void)
@@ -80,6 +76,23 @@ const char *get_git_dir(void)
return git_dir;
}
+const char *get_git_work_tree(void)
+{
+ static int initialized = 0;
+ if (!initialized) {
+ work_tree = getenv(GIT_WORK_TREE_ENVIRONMENT);
+ if (!work_tree) {
+ work_tree = git_work_tree_cfg;
+ if (work_tree && !is_absolute_path(work_tree))
+ work_tree = git_path(work_tree);
+ }
+ if (work_tree && !is_absolute_path(work_tree))
+ work_tree = xstrdup(make_absolute_path(work_tree));
+ initialized = 1;
+ }
+ return work_tree;
+}
+
char *get_object_directory(void)
{
if (!git_object_dir)
diff --git a/git.c b/git.c
index a647f9c..5df10d3 100644
--- a/git.c
+++ b/git.c
@@ -75,7 +75,7 @@ static int handle_options(const char*** argv, int* argc, int* envchanged)
*envchanged = 1;
} else if (!strcmp(cmd, "--work-tree")) {
if (*argc < 2) {
- fprintf(stderr, "No directory given for --work-tree.\n" );
+ error("No directory given for --work-tree.\n");
usage(git_usage_string);
}
setenv(GIT_WORK_TREE_ENVIRONMENT, (*argv)[1], 1);
diff --git a/setup.c b/setup.c
index 7b07144..9c0f5f6 100644
--- a/setup.c
+++ b/setup.c
@@ -1,4 +1,8 @@
#include "cache.h"
+#include "dir.h"
+
+static int inside_git_dir = -1;
+static int inside_work_tree = -1;
const char *prefix_path(const char *prefix, int len, const char *path)
{
@@ -170,100 +174,41 @@ static int is_git_directory(const char *suspect)
return 1;
}
-static int inside_git_dir = -1;
-
int is_inside_git_dir(void)
{
- if (inside_git_dir >= 0)
- return inside_git_dir;
- die("BUG: is_inside_git_dir called before setup_git_directory");
+ if (inside_git_dir < 0)
+ inside_git_dir = is_inside_dir(get_git_dir());
+ return inside_git_dir;
}
-static int inside_work_tree = -1;
-
int is_inside_work_tree(void)
{
- if (inside_git_dir >= 0)
- return inside_work_tree;
- die("BUG: is_inside_work_tree called before setup_git_directory");
-}
-
-static char *gitworktree_config;
-
-static int git_setup_config(const char *var, const char *value)
-{
- if (!strcmp(var, "core.worktree")) {
- if (gitworktree_config)
- strlcpy(gitworktree_config, value, PATH_MAX);
- return 0;
- }
- return git_default_config(var, value);
+ if (inside_work_tree < 0)
+ inside_work_tree = is_inside_dir(get_git_work_tree());
+ return inside_work_tree;
}
+/*
+ * We cannot decide in this function whether we are in the work tree or
+ * not, since the config can only be read _after_ this function was called.
+ */
const char *setup_git_directory_gently(int *nongit_ok)
{
static char cwd[PATH_MAX+1];
- char worktree[PATH_MAX+1], gitdir[PATH_MAX+1];
- const char *gitdirenv, *gitworktree;
- int wt_rel_gitdir = 0;
+ const char *gitdirenv;
+ int len, offset;
+ /*
+ * If GIT_DIR is set explicitly, we're not going
+ * to do any discovery, but we still do repository
+ * validation.
+ */
gitdirenv = getenv(GIT_DIR_ENVIRONMENT);
- if (!gitdirenv) {
- int len, offset;
-
- if (!getcwd(cwd, sizeof(cwd)-1))
- die("Unable to read current working directory");
-
- offset = len = strlen(cwd);
- for (;;) {
- if (is_git_directory(".git"))
- break;
- if (offset == 0) {
- offset = -1;
- break;
- }
- chdir("..");
- while (cwd[--offset] != '/')
- ; /* do nothing */
- }
-
- if (offset >= 0) {
- inside_work_tree = 1;
- git_config(git_default_config);
- if (offset == len) {
- inside_git_dir = 0;
- return NULL;
- }
-
- cwd[len++] = '/';
- cwd[len] = '\0';
- inside_git_dir = !prefixcmp(cwd + offset + 1, ".git/");
- return cwd + offset + 1;
- }
-
- if (chdir(cwd))
- die("Cannot come back to cwd");
- if (!is_git_directory(".")) {
- if (nongit_ok) {
- *nongit_ok = 1;
- return NULL;
- }
- die("Not a git repository");
- }
- setenv(GIT_DIR_ENVIRONMENT, cwd, 1);
- gitdirenv = getenv(GIT_DIR_ENVIRONMENT);
- if (!gitdirenv)
- die("getenv after setenv failed");
- }
-
- if (PATH_MAX - 40 < strlen(gitdirenv)) {
- if (nongit_ok) {
- *nongit_ok = 1;
+ if (gitdirenv) {
+ if (PATH_MAX - 40 < strlen(gitdirenv))
+ die("'$%s' too big", GIT_DIR_ENVIRONMENT);
+ if (is_git_directory(gitdirenv))
return NULL;
- }
- die("$%s too big", GIT_DIR_ENVIRONMENT);
- }
- if (!is_git_directory(gitdirenv)) {
if (nongit_ok) {
*nongit_ok = 1;
return NULL;
@@ -273,92 +218,58 @@ const char *setup_git_directory_gently(int *nongit_ok)
if (!getcwd(cwd, sizeof(cwd)-1))
die("Unable to read current working directory");
- if (chdir(gitdirenv)) {
- if (nongit_ok) {
- *nongit_ok = 1;
- return NULL;
- }
- die("Cannot change directory to $%s '%s'",
- GIT_DIR_ENVIRONMENT, gitdirenv);
- }
- if (!getcwd(gitdir, sizeof(gitdir)-1))
- die("Unable to read current working directory");
- if (chdir(cwd))
- die("Cannot come back to cwd");
/*
- * In case there is a work tree we may change the directory,
- * therefore make GIT_DIR an absolute path.
+ * Test in the following order (relative to the cwd):
+ * - .git/
+ * - . (bare)
+ * - ../.git/
+ * - ../../.git/
+ * etc.
*/
- if (gitdirenv[0] != '/') {
- setenv(GIT_DIR_ENVIRONMENT, gitdir, 1);
- gitdirenv = getenv(GIT_DIR_ENVIRONMENT);
- if (!gitdirenv)
- die("getenv after setenv failed");
- if (PATH_MAX - 40 < strlen(gitdirenv)) {
- if (nongit_ok) {
- *nongit_ok = 1;
- return NULL;
- }
- die("$%s too big after expansion to absolute path",
- GIT_DIR_ENVIRONMENT);
- }
- }
-
- strcat(cwd, "/");
- strcat(gitdir, "/");
- inside_git_dir = !prefixcmp(cwd, gitdir);
-
- gitworktree = getenv(GIT_WORK_TREE_ENVIRONMENT);
- if (!gitworktree) {
- gitworktree_config = worktree;
- worktree[0] = '\0';
- }
- git_config(git_setup_config);
- if (!gitworktree) {
- gitworktree_config = NULL;
- if (worktree[0])
- gitworktree = worktree;
- if (gitworktree && gitworktree[0] != '/')
- wt_rel_gitdir = 1;
+ offset = len = strlen(cwd);
+ if (is_git_directory(DEFAULT_GIT_DIR_ENVIRONMENT)) {
+ inside_git_dir = 0;
+ git_work_tree_cfg = xstrdup(cwd);
+ return NULL;
}
-
- if (wt_rel_gitdir && chdir(gitdirenv))
- die("Cannot change directory to $%s '%s'",
- GIT_DIR_ENVIRONMENT, gitdirenv);
- if (gitworktree && chdir(gitworktree)) {
- if (nongit_ok) {
- if (wt_rel_gitdir && chdir(cwd))
- die("Cannot come back to cwd");
- *nongit_ok = 1;
- return NULL;
- }
- if (wt_rel_gitdir)
- die("Cannot change directory to working tree '%s'"
- " from $%s", gitworktree, GIT_DIR_ENVIRONMENT);
- else
- die("Cannot change directory to working tree '%s'",
- gitworktree);
+ if (is_git_directory(".")) {
+ setenv(GIT_DIR_ENVIRONMENT, ".", 1);
+ inside_git_dir = 1;
+ inside_work_tree = 0;
+ return NULL;
}
- if (!getcwd(worktree, sizeof(worktree)-1))
- die("Unable to read current working directory");
- strcat(worktree, "/");
- inside_work_tree = !prefixcmp(cwd, worktree);
- if (gitworktree && inside_work_tree && !prefixcmp(worktree, gitdir) &&
- strcmp(worktree, gitdir)) {
- inside_git_dir = 0;
+ chdir("..");
+ for (;;) {
+ if (is_git_directory(DEFAULT_GIT_DIR_ENVIRONMENT))
+ break;
+ chdir("..");
+ do {
+ if (!offset) {
+ if (nongit_ok) {
+ if (chdir(cwd))
+ die("Cannot come back to cwd");
+ *nongit_ok = 1;
+ return NULL;
+ }
+ die("Not a git repository");
+ }
+ } while (cwd[--offset] != '/');
}
- if (!inside_work_tree) {
- if (chdir(cwd))
- die("Cannot come back to cwd");
+ if (offset == len)
return NULL;
- }
- if (!strcmp(cwd, worktree))
- return NULL;
- return cwd+strlen(worktree);
+ /* Make "offset" point to past the '/', and add a '/' at the end */
+ offset++;
+ cwd[len++] = '/';
+ cwd[len] = 0;
+ inside_git_dir = !prefixcmp(cwd + offset,
+ DEFAULT_GIT_DIR_ENVIRONMENT "/");
+ if (!inside_git_dir)
+ git_work_tree_cfg = xstrdup(cwd);
+ return cwd + offset;
}
int git_config_perm(const char *var, const char *value)
@@ -382,11 +293,16 @@ int git_config_perm(const char *var, const char *value)
int check_repository_format_version(const char *var, const char *value)
{
- if (strcmp(var, "core.repositoryformatversion") == 0)
- repository_format_version = git_config_int(var, value);
+ if (strcmp(var, "core.repositoryformatversion") == 0)
+ repository_format_version = git_config_int(var, value);
else if (strcmp(var, "core.sharedrepository") == 0)
shared_repository = git_config_perm(var, value);
- return 0;
+ else if (strcmp(var, "core.worktree") == 0) {
+ if (git_work_tree_cfg)
+ free(git_work_tree_cfg);
+ git_work_tree_cfg = xstrdup(value);
+ }
+ return 0;
}
int check_repository_format(void)
@@ -400,7 +316,13 @@ int check_repository_format(void)
const char *setup_git_directory(void)
{
- const char *retval = setup_git_directory_gently(NULL);
+ const char *retval = setup_git_directory_gently(NULL), *work_tree;
check_repository_format();
+ work_tree = get_git_work_tree();
+ if (work_tree) {
+ static char buffer[PATH_MAX + 1];
+ char *rel = get_relative_cwd(buffer, PATH_MAX, work_tree);
+ return rel && *rel ? strcat(normalize_path(rel), "/") : NULL;
+ }
return retval;
}
--
1.5.3.rc2.42.gda8d-dirty
^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-26 6:30 [PATCH 3/5] Clean up work-tree handling Johannes Schindelin
@ 2007-07-26 6:56 ` Shawn O. Pearce
2007-07-26 7:06 ` Junio C Hamano
2007-07-26 22:09 ` Matthias Lederhofer
2 siblings, 0 replies; 10+ messages in thread
From: Shawn O. Pearce @ 2007-07-26 6:56 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git, gitster
Johannes Schindelin <Johannes.Schindelin@gmx.de> wrote:
> In related news, there is a long standing bug fixed: when in
> .git/bla/x.git/, which is a bare repository, git formerly assumed
> ../.. to be the appropriate git dir.
Heh. I spent about 10 minutes last week trying to understand why
git-new-workdir was failing horribly on one user's system.
Turns out they once managed to do:
cd /
git init
a long, long, long time ago and just didn't notice it until now. git
kept finding /.git rather than the .git it was supposed to locate,
which was a bare repository in $HOME/.storage-pool/dayjob.git.
--
Shawn.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-26 6:30 [PATCH 3/5] Clean up work-tree handling Johannes Schindelin
2007-07-26 6:56 ` Shawn O. Pearce
@ 2007-07-26 7:06 ` Junio C Hamano
2007-07-26 14:01 ` Johannes Schindelin
2007-07-26 22:09 ` Matthias Lederhofer
2 siblings, 1 reply; 10+ messages in thread
From: Junio C Hamano @ 2007-07-26 7:06 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git
This seems to break t1020 and t1500, probably among other
things.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-26 7:06 ` Junio C Hamano
@ 2007-07-26 14:01 ` Johannes Schindelin
2007-07-26 18:56 ` Junio C Hamano
0 siblings, 1 reply; 10+ messages in thread
From: Johannes Schindelin @ 2007-07-26 14:01 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
Hi,
On Thu, 26 Jul 2007, Junio C Hamano wrote:
> This seems to break t1020 and t1500, probably among other
> things.
It does, yes. I only realised that when I woke up.
Will fix. In the meantime, you guys can discuss the merits of my patch
series. Am I the only one who finds the new version much easier to read,
much like the pre-work-tree version?
Ciao,
Dscho
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-26 14:01 ` Johannes Schindelin
@ 2007-07-26 18:56 ` Junio C Hamano
0 siblings, 0 replies; 10+ messages in thread
From: Junio C Hamano @ 2007-07-26 18:56 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git
Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
> ... Am I the only one who finds the new version much easier to read,
> much like the pre-work-tree version?
Oh there is (modulo bugs to be worked on further) no question
about that. The changes to environment.c alone would convince
anybody, I would say. ;-).
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-26 6:30 [PATCH 3/5] Clean up work-tree handling Johannes Schindelin
2007-07-26 6:56 ` Shawn O. Pearce
2007-07-26 7:06 ` Junio C Hamano
@ 2007-07-26 22:09 ` Matthias Lederhofer
2007-07-26 22:31 ` Junio C Hamano
2007-07-27 10:50 ` Johannes Schindelin
2 siblings, 2 replies; 10+ messages in thread
From: Matthias Lederhofer @ 2007-07-26 22:09 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git
I try to take a closer look at your changes tomorrow evening. Here
are just two short things I saw while taking a short look at the
patch.
Johannes Schindelin <Johannes.Schindelin@gmx.de> wrote:
> +const char *get_git_work_tree(void)
> +{
> + static int initialized = 0;
> + if (!initialized) {
> + work_tree = getenv(GIT_WORK_TREE_ENVIRONMENT);
> + if (!work_tree) {
> + work_tree = git_work_tree_cfg;
> + if (work_tree && !is_absolute_path(work_tree))
> + work_tree = git_path(work_tree);
A tab is missing here.
> - fprintf(stderr, "No directory given for --work-tree.\n" );
> + error("No directory given for --work-tree.\n");
There should probably be no '\n' at the end when the 'error' function
is used. There are two other calls to fprintf(stderr, <error message>)
next to the one you changed, why did you change this one but not the
other ones?
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-26 22:09 ` Matthias Lederhofer
@ 2007-07-26 22:31 ` Junio C Hamano
2007-07-27 10:50 ` Johannes Schindelin
1 sibling, 0 replies; 10+ messages in thread
From: Junio C Hamano @ 2007-07-26 22:31 UTC (permalink / raw)
To: Matthias Lederhofer; +Cc: Johannes Schindelin, git
Matthias Lederhofer <matled@gmx.net> writes:
> I try to take a closer look at your changes tomorrow evening. Here
> are just two short things I saw while taking a short look at the
> patch.
>
> Johannes Schindelin <Johannes.Schindelin@gmx.de> wrote:
>> +const char *get_git_work_tree(void)
>> +{
>> + static int initialized = 0;
>> + if (!initialized) {
>> + work_tree = getenv(GIT_WORK_TREE_ENVIRONMENT);
>> + if (!work_tree) {
>> + work_tree = git_work_tree_cfg;
>> + if (work_tree && !is_absolute_path(work_tree))
>> + work_tree = git_path(work_tree);
>
> A tab is missing here.
I think xstrdup() is missing here, too.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-26 22:09 ` Matthias Lederhofer
2007-07-26 22:31 ` Junio C Hamano
@ 2007-07-27 10:50 ` Johannes Schindelin
2007-07-27 19:20 ` Junio C Hamano
1 sibling, 1 reply; 10+ messages in thread
From: Johannes Schindelin @ 2007-07-27 10:50 UTC (permalink / raw)
To: Matthias Lederhofer; +Cc: git
Hi,
On Fri, 27 Jul 2007, Matthias Lederhofer wrote:
> Johannes Schindelin <Johannes.Schindelin@gmx.de> wrote:
> > +const char *get_git_work_tree(void)
> > +{
> > + static int initialized = 0;
> > + if (!initialized) {
> > + work_tree = getenv(GIT_WORK_TREE_ENVIRONMENT);
> > + if (!work_tree) {
> > + work_tree = git_work_tree_cfg;
> > + if (work_tree && !is_absolute_path(work_tree))
> > + work_tree = git_path(work_tree);
>
> A tab is missing here.
Right. And as Junio pointed out, an xstrdup().
> > - fprintf(stderr, "No directory given for --work-tree.\n" );
> > + error("No directory given for --work-tree.\n");
>
> There should probably be no '\n' at the end when the 'error' function
> is used. There are two other calls to fprintf(stderr, <error message>)
> next to the one you changed, why did you change this one but not the
> other ones?
Well, that is a left over of some unrelated editing.
The patch series that I sent out was deficient in many ways, but I was
tired, and wanted to show where I am heading.
ATM I am trying to finish up this series, with quite a few changes to the
code I sent out.
But there is a fundamental question I have to ask: Is there any reason why
$ git --git-dir=/some/where/else.git bla
should pretend that the repo is bare if core.bare == 1? I mean, we are
implicitely setting the work tree to the cwd, no?
IOW I see the merits of "core.bare = false" (to prevent harm when calling
git inside the git directory), but I cannot see the merits of "core.bare =
true". Someone enlighten me?
Ciao,
Dscho
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-27 10:50 ` Johannes Schindelin
@ 2007-07-27 19:20 ` Junio C Hamano
2007-07-27 19:32 ` Johannes Schindelin
0 siblings, 1 reply; 10+ messages in thread
From: Junio C Hamano @ 2007-07-27 19:20 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: Matthias Lederhofer, git
Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
> But there is a fundamental question I have to ask: Is there any reason why
>
> $ git --git-dir=/some/where/else.git bla
>
> should pretend that the repo is bare if core.bare == 1? I mean, we are
> implicitely setting the work tree to the cwd, no?
I have two repositories at the primary k.org machine.
- /home/junio/git.git --- this is with a worktree so that I can
build and test on a FC machine (my primary development
machine at home is a Debian).
- /pub/scm/git/git.git/ --- this is a bare repository that is
mirrored out to git://git.kernel.org/ and friends.
And I usually am in the former. From time to time, I do this:
$ GIT_DIR=/pub/scm/git/git.git/ git fsck
$ GIT_DIR=/pub/scm/git/git.git/ git repack
because I am old fashioned, but I would expect these to be
equivalent to the above:
$ git --git-dir=/pub/scm/git/git.git/ fsck
$ git --git-dir=/pub/scm/git/git.git/ repack
I do not think these imply that the repository is with worktree.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH 3/5] Clean up work-tree handling
2007-07-27 19:20 ` Junio C Hamano
@ 2007-07-27 19:32 ` Johannes Schindelin
0 siblings, 0 replies; 10+ messages in thread
From: Johannes Schindelin @ 2007-07-27 19:32 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Matthias Lederhofer, git
Hi,
On Fri, 27 Jul 2007, Junio C Hamano wrote:
> Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
>
> > But there is a fundamental question I have to ask: Is there any reason why
> >
> > $ git --git-dir=/some/where/else.git bla
> >
> > should pretend that the repo is bare if core.bare == 1? I mean, we are
> > implicitely setting the work tree to the cwd, no?
>
> I have two repositories at the primary k.org machine.
>
> - /home/junio/git.git --- this is with a worktree so that I can
> build and test on a FC machine (my primary development
> machine at home is a Debian).
>
> - /pub/scm/git/git.git/ --- this is a bare repository that is
> mirrored out to git://git.kernel.org/ and friends.
>
> And I usually am in the former. From time to time, I do this:
>
> $ GIT_DIR=/pub/scm/git/git.git/ git fsck
> $ GIT_DIR=/pub/scm/git/git.git/ git repack
>
> because I am old fashioned, but I would expect these to be
> equivalent to the above:
>
> $ git --git-dir=/pub/scm/git/git.git/ fsck
> $ git --git-dir=/pub/scm/git/git.git/ repack
>
> I do not think these imply that the repository is with worktree.
But in your use cases it does not matter, since neither fsck nor repack
need a worktree.
Here is one of _my_ scenarios: I want to track a directory I have no write
access to (or better put: I should have no write access to). So I created
a bare repository, and when I add new files I use the "GIT_DIR=... git..."
mantra.
But you're right, I could just set core.worktree=... and unset core.bare.
I can change that easily enough. Other comments on the series?
Ciao,
Dscho
^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2007-07-27 19:32 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-07-26 6:30 [PATCH 3/5] Clean up work-tree handling Johannes Schindelin
2007-07-26 6:56 ` Shawn O. Pearce
2007-07-26 7:06 ` Junio C Hamano
2007-07-26 14:01 ` Johannes Schindelin
2007-07-26 18:56 ` Junio C Hamano
2007-07-26 22:09 ` Matthias Lederhofer
2007-07-26 22:31 ` Junio C Hamano
2007-07-27 10:50 ` Johannes Schindelin
2007-07-27 19:20 ` Junio C Hamano
2007-07-27 19:32 ` Johannes Schindelin
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).