* git clone regression
@ 2007-08-15 12:28 Junio C Hamano
2007-08-15 16:25 ` [PATCH] Fix initialization of a bare repository Johannes Schindelin
0 siblings, 1 reply; 8+ messages in thread
From: Junio C Hamano @ 2007-08-15 12:28 UTC (permalink / raw)
To: git
It appears that with 1.5.3-rc5
$ git clone --bare $origin_url target.git
does not set "core.bare = true" in target.git/config. We used
to, at least with 1.5.2.2. I am strongly suspecting that this
is another fallout from the worktree series.
^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH] Fix initialization of a bare repository
2007-08-15 12:28 git clone regression Junio C Hamano
@ 2007-08-15 16:25 ` Johannes Schindelin
2007-08-15 19:09 ` Junio C Hamano
2007-08-15 20:41 ` Junio C Hamano
0 siblings, 2 replies; 8+ messages in thread
From: Johannes Schindelin @ 2007-08-15 16:25 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
The recent work-tree cleanup broke it; core.bare was set to false
erroneously when calling "git --bare init". Coincidentally, this
fixes "git clone --bare", too.
Noticed by Junio Hamano.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
---
On Wed, 15 Aug 2007, Junio C Hamano wrote:
> It appears that with 1.5.3-rc5
>
> $ git clone --bare $origin_url target.git
>
> does not set "core.bare = true" in target.git/config. We used
> to, at least with 1.5.2.2. I am strongly suspecting that this
> is another fallout from the worktree series.
Sorry. Yes, this is another fallout.
Maybe this is not enough, though. Maybe we need to check if the
GIT_DIR=. too, since 7efeb8f0 would set the work tree to ".", too.
But maybe this would merit a separate fix in set_work_tree(), like
if (!strcmp(getenv(GIT_DIR_ENVIRONMENT), ".")) {
inside_work_tree = 0;
return NULL;
}
Hmm?
builtin-init-db.c | 13 ++++++++-----
git.c | 1 +
2 files changed, 9 insertions(+), 5 deletions(-)
diff --git a/builtin-init-db.c b/builtin-init-db.c
index 75fb227..2e45a7e 100644
--- a/builtin-init-db.c
+++ b/builtin-init-db.c
@@ -302,11 +302,14 @@ int cmd_init_db(int argc, const char **argv, const char *prefix)
usage(init_db_usage);
}
- git_work_tree_cfg = xcalloc(PATH_MAX, 1);
- if (!getcwd(git_work_tree_cfg, PATH_MAX))
- die ("Cannot access current working directory.");
- if (access(get_git_work_tree(), X_OK))
- die ("Cannot access work tree '%s'", get_git_work_tree());
+ if (!is_bare_repository_cfg) {
+ git_work_tree_cfg = xcalloc(PATH_MAX, 1);
+ if (!getcwd(git_work_tree_cfg, PATH_MAX))
+ die ("Cannot access current working directory.");
+ if (access(get_git_work_tree(), X_OK))
+ die ("Cannot access work tree '%s'",
+ get_git_work_tree());
+ }
/*
* Set up the default .git directory contents
diff --git a/git.c b/git.c
index 1bf2744..f0062a0 100644
--- a/git.c
+++ b/git.c
@@ -100,6 +100,7 @@ static int handle_options(const char*** argv, int* argc, int* envchanged)
} else if (!strcmp(cmd, "--bare")) {
static char git_dir[PATH_MAX+1];
setenv(GIT_DIR_ENVIRONMENT, getcwd(git_dir, sizeof(git_dir)), 1);
+ is_bare_repository_cfg = 1;
} else if (!strcmp(cmd, "-2") ||
!strcmp(cmd, "--redirect-stderr")) {
if (dup2(1, 2) < 0)
--
1.5.1.rc1.4887.ga4a43-dirty
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] Fix initialization of a bare repository
2007-08-15 16:25 ` [PATCH] Fix initialization of a bare repository Johannes Schindelin
@ 2007-08-15 19:09 ` Junio C Hamano
2007-08-15 19:26 ` Junio C Hamano
2007-08-15 20:41 ` Junio C Hamano
1 sibling, 1 reply; 8+ messages in thread
From: Junio C Hamano @ 2007-08-15 19:09 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git
Johannes Schindelin <Johannes.Schindelin@gmx.de> writes:
> Maybe this is not enough, though. Maybe we need to check if the
> GIT_DIR=. too, since 7efeb8f0 would set the work tree to ".", too.
>
> But maybe this would merit a separate fix in set_work_tree(), like
>
> if (!strcmp(getenv(GIT_DIR_ENVIRONMENT), ".")) {
> inside_work_tree = 0;
> return NULL;
> }
>
> Hmm?
I do not know. If you treat "." differently from a pathname
that is the same as what $(pwd) would give you, you will confuse
even more users.
Currently we have:
- char *git_work_tree_cfg: the location of the work tree when
$GIT_WORK_TREE nor --work-tree option is in use. Contrary to
the name of the variable, it does not necessarily come from
core.worktree. This comes from core.worktree if set,
otherwise derived from the location of the repository
(i.e. unless $GIT_DIR is set, above "/.git" of the found
repository, otherwise ".").
- char *work_tree: the location of the work tree, which comes
from $GIT_WORK_TREE (or --work-tree option) if set, otherwise
git_work_tree_cfg above.
- int inside_work_tree: is $(cwd) inside of the work tree (if
we have one)?
- int is_bare_repository_cfg: are we treating this repository
as bare? Contrary to the name of the variable, it does not
necessarily come from core.bare (get_git_work_tree()
overwrites the value found in core.bare to false in if we
have a work_tree).
- int is_bare_repository(): are we treating this repository
as bare? This is the function the callers usually use.
I think tying the presense of work_tree and repository bareness
as is_bare_repository() does is almost always right for the
normal callers. One valid use of GIT_WORK_TREE is to put a work
tree to a repository otherwise declared as a bare one.
But obviously init-db is rather a special case with a chicken
and egg problem. What it wants to know is not if we are
currently treating the repository as a bare one, but if we would
want to mark its core.bare with "this should be normally treated
as bare". Your patch treats this special case as such without
affecting the normal codepath, which I think is a sane thing to
do.
Thanks for a quick fix.
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Fix initialization of a bare repository
2007-08-15 19:09 ` Junio C Hamano
@ 2007-08-15 19:26 ` Junio C Hamano
0 siblings, 0 replies; 8+ messages in thread
From: Junio C Hamano @ 2007-08-15 19:26 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git
Junio C Hamano <gitster@pobox.com> writes:
> Thanks for a quick fix.
Gaah. I spoke way too early. This breaks even more things than
it fixes. Even something as simple as "git add ." does not work
anymore.
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Fix initialization of a bare repository
2007-08-15 16:25 ` [PATCH] Fix initialization of a bare repository Johannes Schindelin
2007-08-15 19:09 ` Junio C Hamano
@ 2007-08-15 20:41 ` Junio C Hamano
2007-08-17 22:20 ` Johannes Schindelin
2007-08-27 7:58 ` [PATCH/RFH] " Junio C Hamano
1 sibling, 2 replies; 8+ messages in thread
From: Junio C Hamano @ 2007-08-15 20:41 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git
Wait a minute.
Let's step back a bit and think what we want to happen here.
* No GIT_DIR, no --bare. Having GIT_WORK_TREE is an error.
$ mkdir foo && cd foo && git init
We want to say "not bare" and create foo/.git/config and friends.
* No GIT_DIR, with --bare. Having GIT_WORK_TREE is an error.
$ mkdir foo && cd foo && git --bare init
We want to say "is bare" and create foo/config, foo/HEAD and
friends.
* With GIT_DIR but no GIT_WORK_TREE, with or without --bare.
$ mkdir foo.git && GIT_DIR=foo.git git init
$ mkdir foo.git && GIT_DIR=foo.git git --bare init
We want to say "is bare" and create foo.git/config and friends.
* With GIT_DIR and GIT_WORK_TREE. Having --bare is an error.
$ mkdir foo.git foo.work
$ GIT_DIR=foo.git GIT_WORK_TREE=foo.work git init
We want to say "not bare", create foo.git/config and friends,
and record core.worktree = /full/path/to/foo.work
Is the above list reasonable?
---
t/t0001-init.sh | 111 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 111 insertions(+), 0 deletions(-)
create mode 100755 t/t0001-init.sh
diff --git a/t/t0001-init.sh b/t/t0001-init.sh
new file mode 100755
index 0000000..9fb2b59
--- /dev/null
+++ b/t/t0001-init.sh
@@ -0,0 +1,111 @@
+#!/bin/sh
+
+test_description='git init'
+
+. ./test-lib.sh
+
+check_config () {
+ if test -d "$1" && test -f "$1/config" && test -d "$1/refs"
+ then
+ : happy
+ else
+ echo "expected a directory $1, a file $1/config and $1/refs"
+ return 1
+ fi
+ bare=$(GIT_CONFIG="$1/config" git config --bool core.bare)
+ worktree=$(GIT_CONFIG="$1/config" git config core.worktree) ||
+ worktree=unset
+
+ test "$bare" = "$2" && test "$worktree" = "$3" || {
+ echo "expected bare=$2 worktree=$3"
+ echo " got bare=$bare worktree=$worktree"
+ return 1
+ }
+}
+
+test_expect_success 'plain' '
+ (
+ unset GIT_DIR GIT_WORK_TREE &&
+ mkdir plain &&
+ cd plain &&
+ git init
+ ) &&
+ check_config plain/.git false unset
+'
+
+test_expect_success 'plain with GIT_WORK_TREE' '
+ if (
+ unset GIT_DIR &&
+ mkdir plain-wt &&
+ cd plain-wt &&
+ GIT_WORK_TREE=$(pwd) git init
+ )
+ then
+ echo Should have failed -- GIT_WORK_TREE should not be used
+ false
+ fi
+'
+
+test_expect_success 'plain bare' '
+ (
+ unset GIT_DIR GIT_WORK_TREE &&
+ mkdir plain-bare &&
+ cd plain-bare &&
+ git --bare init
+ ) &&
+ check_config plain-bare true unset
+'
+
+test_expect_success 'plain bare with GIT_WORK_TREE' '
+ if (
+ unset GIT_DIR &&
+ mkdir plain-bare &&
+ cd plain-bare &&
+ GIT_WORK_TREE=$(pwd) git --bare init
+ )
+ then
+ echo Should have failed -- GIT_WORK_TREE should not be used
+ false
+ fi
+'
+
+test_expect_success 'GIT_DIR bare (1)' '
+
+ (
+ mkdir git-dir-bare-1.git &&
+ GIT_DIR=git-dir-bare-1.git git init
+ ) &&
+ check_config git-dir-bare-1.git true unset
+'
+
+test_expect_success 'GIT_DIR bare (2)' '
+
+ (
+ mkdir git-dir-bare-2.git &&
+ GIT_DIR=git-dir-bare-2.git git --bare init
+ ) &&
+ check_config git-dir-bare-2.git true unset
+'
+
+test_expect_success 'GIT_DIR & GIT_WORK_TREE (1)' '
+
+ (
+ mkdir git-dir-wt-1.git &&
+ GIT_WORK_TREE=$(pwd) GIT_DIR=git-dir-wt-1.git git init
+ ) &&
+ check_config git-dir-wt-1.git false "$(pwd)"
+'
+
+test_expect_success 'GIT_DIR & GIT_WORK_TREE (2)' '
+
+ if (
+ mkdir git-dir-wt-2.git &&
+ GIT_WORK_TREE=$(pwd) GIT_DIR=git-dir-wt-2.git git --bare init
+ )
+ then
+ echo Should have failed -- --bare should not be used
+ false
+ fi
+'
+
+test_done
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] Fix initialization of a bare repository
2007-08-15 20:41 ` Junio C Hamano
@ 2007-08-17 22:20 ` Johannes Schindelin
2007-08-27 7:58 ` [PATCH/RFH] " Junio C Hamano
1 sibling, 0 replies; 8+ messages in thread
From: Johannes Schindelin @ 2007-08-17 22:20 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
Hi,
On Wed, 15 Aug 2007, Junio C Hamano wrote:
> Wait a minute.
>
> Let's step back a bit and think what we want to happen here.
>
> * No GIT_DIR, no --bare. Having GIT_WORK_TREE is an error.
>
> $ mkdir foo && cd foo && git init
>
> We want to say "not bare" and create foo/.git/config and friends.
>
> * No GIT_DIR, with --bare. Having GIT_WORK_TREE is an error.
>
> $ mkdir foo && cd foo && git --bare init
>
> We want to say "is bare" and create foo/config, foo/HEAD and
> friends.
>
> * With GIT_DIR but no GIT_WORK_TREE, with or without --bare.
>
> $ mkdir foo.git && GIT_DIR=foo.git git init
> $ mkdir foo.git && GIT_DIR=foo.git git --bare init
>
> We want to say "is bare" and create foo.git/config and friends.
>
> * With GIT_DIR and GIT_WORK_TREE. Having --bare is an error.
>
> $ mkdir foo.git foo.work
> $ GIT_DIR=foo.git GIT_WORK_TREE=foo.work git init
>
> We want to say "not bare", create foo.git/config and friends,
> and record core.worktree = /full/path/to/foo.work
>
> Is the above list reasonable?
Yes. I'll try to work on it the day after tomorrow.
Ciao,
Dscho
^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH/RFH] Fix initialization of a bare repository
2007-08-15 20:41 ` Junio C Hamano
2007-08-17 22:20 ` Johannes Schindelin
@ 2007-08-27 7:58 ` Junio C Hamano
2007-08-27 10:54 ` Johannes Schindelin
1 sibling, 1 reply; 8+ messages in thread
From: Junio C Hamano @ 2007-08-27 7:58 UTC (permalink / raw)
To: Johannes Schindelin; +Cc: git, Petr Baudis
Here is my attempt to fix this with a minimally intrusive patch.
* As "git --bare init" cannot tell if it was called with --bare or
just "GIT_DIR=. git init", I added an explicit assignment of
is_bare_repository_cfg on the codepath for "git --bare".
* GIT_WORK_TREE alone without GIT_DIR does not make any sense,
nor GIT_WORK_TREE with an explicit "git --bare". Catch that
mistake. It might make sense to move this check to "git.c"
side as well, but I tried to shoot for the minimum change for
now.
* Some scripts, especially from the olden days, rely on
traditional GIT_DIR behaviour in "git init". Namely, these
are some notable patterns:
(create a bare repository)
- mkdir some.git && cd some.git && GIT_DIR=. git init
- mkdir some.git && cd some.git && git --bare init
(create a non-bare repository)
- mkdir .git && GIT_DIR=.git git init
- mkdir .git && GIT_DIR=`pwd`/.git git init
This comes with a new test script and also passes the existing
test suite, but there may be cases that are still broken with
the current tip of master and this patch does not yet fix. I'd
appreciate help in straightening this mess out.
---
* The test script I sent earlier was botched in some details.
Most notably, it allowed GIT_CONFIG that is exported by the
test scaffolding to affect behaviour of git-init, and tried
to see if the resulting repository had correct config, which
was nonsense. Also "GIT_DIR bare (2)" test (removed in this
iteration) was about "GIT_DIR=somewhere git --bare init", but
"git --bare" is defined as "export GIT_DIR=`pwd`" in git.c,
which meant that the initial GIT_DIR setting was not honored.
builtin-init-db.c | 63 +++++++++++++++++++++++++++++---
git.c | 1 +
t/t0001-init.sh | 105 +++++++++++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 164 insertions(+), 5 deletions(-)
create mode 100755 t/t0001-init.sh
diff --git a/builtin-init-db.c b/builtin-init-db.c
index 0d9b1e0..ec90b66 100644
--- a/builtin-init-db.c
+++ b/builtin-init-db.c
@@ -267,6 +267,42 @@ static int create_default_files(const char *git_dir, const char *template_path)
return reinit;
}
+static void guess_repository_type(const char *git_dir)
+{
+ char cwd[PATH_MAX];
+ const char *slash;
+
+ if (0 <= is_bare_repository_cfg)
+ return;
+ if (!git_dir)
+ return;
+
+ /*
+ * "GIT_DIR=. git init" is always bare.
+ * "GIT_DIR=`pwd` git init" too.
+ */
+ if (!strcmp(".", git_dir))
+ goto force_bare;
+ if (!getcwd(cwd, sizeof(cwd)))
+ die("cannot tell cwd");
+ if (!strcmp(git_dir, cwd))
+ goto force_bare;
+ /*
+ * "GIT_DIR=something/.git is usually not.
+ */
+ slash = strrchr(git_dir, '/');
+ if (slash && !strcmp(slash, "/.git"))
+ return;
+
+ /*
+ * Otherwise it is often bare. At this point
+ * we are just guessing.
+ */
+ force_bare:
+ is_bare_repository_cfg = 1;
+ return;
+}
+
static const char init_db_usage[] =
"git-init [-q | --quiet] [--template=<template-directory>] [--shared]";
@@ -299,11 +335,28 @@ int cmd_init_db(int argc, const char **argv, const char *prefix)
usage(init_db_usage);
}
- git_work_tree_cfg = xcalloc(PATH_MAX, 1);
- if (!getcwd(git_work_tree_cfg, PATH_MAX))
- die ("Cannot access current working directory.");
- if (access(get_git_work_tree(), X_OK))
- die ("Cannot access work tree '%s'", get_git_work_tree());
+ /*
+ * GIT_WORK_TREE makes sense only in conjunction with GIT_DIR
+ * without --bare. Catch the error early.
+ */
+ git_dir = getenv(GIT_DIR_ENVIRONMENT);
+ if ((!git_dir || is_bare_repository_cfg == 1)
+ && getenv(GIT_WORK_TREE_ENVIRONMENT))
+ die("%s (or --work-tree=<directory>) not allowed without "
+ "specifying %s (or --git-dir=<directory>)",
+ GIT_WORK_TREE_ENVIRONMENT,
+ GIT_DIR_ENVIRONMENT);
+
+ guess_repository_type(git_dir);
+
+ if (is_bare_repository_cfg <= 0) {
+ git_work_tree_cfg = xcalloc(PATH_MAX, 1);
+ if (!getcwd(git_work_tree_cfg, PATH_MAX))
+ die ("Cannot access current working directory.");
+ if (access(get_git_work_tree(), X_OK))
+ die ("Cannot access work tree '%s'",
+ get_git_work_tree());
+ }
/*
* Set up the default .git directory contents
diff --git a/git.c b/git.c
index c46691e..b6e292e 100644
--- a/git.c
+++ b/git.c
@@ -93,6 +93,7 @@ static int handle_options(const char*** argv, int* argc, int* envchanged)
*envchanged = 1;
} else if (!strcmp(cmd, "--bare")) {
static char git_dir[PATH_MAX+1];
+ is_bare_repository_cfg = 1;
setenv(GIT_DIR_ENVIRONMENT, getcwd(git_dir, sizeof(git_dir)), 1);
if (envchanged)
*envchanged = 1;
diff --git a/t/t0001-init.sh b/t/t0001-init.sh
new file mode 100755
index 0000000..333abb2
--- /dev/null
+++ b/t/t0001-init.sh
@@ -0,0 +1,105 @@
+#!/bin/sh
+
+test_description='git init'
+
+. ./test-lib.sh
+
+check_config () {
+ if test -d "$1" && test -f "$1/config" && test -d "$1/refs"
+ then
+ : happy
+ else
+ echo "expected a directory $1, a file $1/config and $1/refs"
+ return 1
+ fi
+ bare=$(GIT_CONFIG="$1/config" git config --bool core.bare)
+ worktree=$(GIT_CONFIG="$1/config" git config core.worktree) ||
+ worktree=unset
+
+ test "$bare" = "$2" && test "$worktree" = "$3" || {
+ echo "expected bare=$2 worktree=$3"
+ echo " got bare=$bare worktree=$worktree"
+ return 1
+ }
+}
+
+test_expect_success 'plain' '
+ (
+ unset GIT_DIR GIT_WORK_TREE &&
+ mkdir plain &&
+ cd plain &&
+ git init
+ ) &&
+ check_config plain/.git false unset
+'
+
+test_expect_success 'plain with GIT_WORK_TREE' '
+ if (
+ unset GIT_DIR &&
+ mkdir plain-wt &&
+ cd plain-wt &&
+ GIT_WORK_TREE=$(pwd) git init
+ )
+ then
+ echo Should have failed -- GIT_WORK_TREE should not be used
+ false
+ fi
+'
+
+test_expect_success 'plain bare' '
+ (
+ unset GIT_DIR GIT_WORK_TREE GIT_CONFIG &&
+ mkdir plain-bare-1 &&
+ cd plain-bare-1 &&
+ git --bare init
+ ) &&
+ check_config plain-bare-1 true unset
+'
+
+test_expect_success 'plain bare with GIT_WORK_TREE' '
+ if (
+ unset GIT_DIR GIT_CONFIG &&
+ mkdir plain-bare-2 &&
+ cd plain-bare-2 &&
+ GIT_WORK_TREE=$(pwd) git --bare init
+ )
+ then
+ echo Should have failed -- GIT_WORK_TREE should not be used
+ false
+ fi
+'
+
+test_expect_success 'GIT_DIR bare' '
+
+ (
+ unset GIT_CONFIG &&
+ mkdir git-dir-bare.git &&
+ GIT_DIR=git-dir-bare.git git init
+ ) &&
+ check_config git-dir-bare.git true unset
+'
+
+test_expect_success 'GIT_DIR & GIT_WORK_TREE (1)' '
+
+ (
+ unset GIT_CONFIG &&
+ mkdir git-dir-wt-1.git &&
+ GIT_WORK_TREE=$(pwd) GIT_DIR=git-dir-wt-1.git git init
+ ) &&
+ check_config git-dir-wt-1.git false "$(pwd)"
+'
+
+test_expect_success 'GIT_DIR & GIT_WORK_TREE (2)' '
+
+ if (
+ unset GIT_CONFIG &&
+ mkdir git-dir-wt-2.git &&
+ GIT_WORK_TREE=$(pwd) GIT_DIR=git-dir-wt-2.git git --bare init
+ )
+ then
+ echo Should have failed -- --bare should not be used
+ false
+ fi
+'
+
+test_done
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH/RFH] Fix initialization of a bare repository
2007-08-27 7:58 ` [PATCH/RFH] " Junio C Hamano
@ 2007-08-27 10:54 ` Johannes Schindelin
0 siblings, 0 replies; 8+ messages in thread
From: Johannes Schindelin @ 2007-08-27 10:54 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git, Petr Baudis
Hi,
how about this on top (or squashed):
-- snipsnap --
builtin-init-db.c | 4 +++-
t/t0001-init.sh | 11 +++++++++++
2 files changed, 14 insertions(+), 1 deletions(-)
diff --git a/builtin-init-db.c b/builtin-init-db.c
index ec90b66..af15cb2 100644
--- a/builtin-init-db.c
+++ b/builtin-init-db.c
@@ -288,8 +288,10 @@ static void guess_repository_type(const char *git_dir)
if (!strcmp(git_dir, cwd))
goto force_bare;
/*
- * "GIT_DIR=something/.git is usually not.
+ * "GIT_DIR=.git or GIT_DIR=something/.git is usually not.
*/
+ if (!strcmp(git_dir, ".git"))
+ return;
slash = strrchr(git_dir, '/');
if (slash && !strcmp(slash, "/.git"))
return;
diff --git a/t/t0001-init.sh b/t/t0001-init.sh
index 333abb2..b14b3ec 100755
--- a/t/t0001-init.sh
+++ b/t/t0001-init.sh
@@ -79,6 +79,17 @@ test_expect_success 'GIT_DIR bare' '
check_config git-dir-bare.git true unset
'
+test_expect_success 'GIT_DIR non-bare' '
+
+ (
+ unset GIT_CONFIG &&
+ mkdir non-bare &&
+ cd non-bare &&
+ GIT_DIR=.git git init
+ ) &&
+ check_config non-bare/.git false unset
+'
+
test_expect_success 'GIT_DIR & GIT_WORK_TREE (1)' '
(
^ permalink raw reply related [flat|nested] 8+ messages in thread
end of thread, other threads:[~2007-08-27 10:52 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-08-15 12:28 git clone regression Junio C Hamano
2007-08-15 16:25 ` [PATCH] Fix initialization of a bare repository Johannes Schindelin
2007-08-15 19:09 ` Junio C Hamano
2007-08-15 19:26 ` Junio C Hamano
2007-08-15 20:41 ` Junio C Hamano
2007-08-17 22:20 ` Johannes Schindelin
2007-08-27 7:58 ` [PATCH/RFH] " Junio C Hamano
2007-08-27 10:54 ` 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).