diff options
author | Jeff King <peff@peff.net> | 2008-06-25 01:41:34 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2008-06-25 11:44:15 -0700 |
commit | 2beebd22f4af8788eaf19d811de03191ae6f7c42 (patch) | |
tree | 2bd7780907fee1af1ef5e6607b8e3dc090cbb62d /t | |
parent | 4ace4fc584f48d5b8df957c4462cf5c7c58ab100 (diff) | |
download | git-2beebd22f4af8788eaf19d811de03191ae6f7c42.tar.gz git-2beebd22f4af8788eaf19d811de03191ae6f7c42.tar.xz |
clone: create intermediate directories of destination repo
The shell version used to use "mkdir -p" to create the repo
path, but the C version just calls "mkdir". Let's replicate
the old behavior. We have to create the git and worktree
leading dirs separately; while most of the time, the
worktree dir contains the git dir (as .git), the user can
override this using GIT_WORK_TREE.
We can reuse safe_create_leading_directories, but we need to
make a copy of our const buffer to do so. Since
merge-recursive uses the same pattern, we can factor this
out into a global function. This has two other cleanup
advantages for merge-recursive:
1. mkdir_p wasn't a very good name. "mkdir -p foo/bar" actually
creates bar, but this function just creates the leading
directories.
2. mkdir_p took a mode argument, but it was completely
ignored.
Acked-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't')
-rwxr-xr-x | t/t5601-clone.sh | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/t/t5601-clone.sh b/t/t5601-clone.sh index 593d1a387..b642fb260 100755 --- a/t/t5601-clone.sh +++ b/t/t5601-clone.sh @@ -30,4 +30,26 @@ test_expect_success 'clone checks out files' ' ' +test_expect_success 'clone respects GIT_WORK_TREE' ' + + GIT_WORK_TREE=worktree git clone src bare && + test -f bare/config && + test -f worktree/file + +' + +test_expect_success 'clone creates intermediate directories' ' + + git clone src long/path/to/dst && + test -f long/path/to/dst/file + +' + +test_expect_success 'clone creates intermediate directories for bare repo' ' + + git clone --bare src long/path/to/bare/dst && + test -f long/path/to/bare/dst/config + +' + test_done |