diff options
| author | Jeff King <peff@peff.net> | 2008-06-25 01:41:34 -0400 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-06-24 23:23:21 -0700 | 
| commit | 8e21d63b02f1b26f7695ca515e51e4622a995af2 (patch) | |
| tree | 18b2bb7cb8242bf68ce9ffe798f1fe03f2e46802 /builtin-clone.c | |
| parent | f98f8cbac01e0d5dbb30660d7ea70af6a1439dfd (diff) | |
| download | git-8e21d63b02f1b26f7695ca515e51e4622a995af2.tar.gz | |
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 'builtin-clone.c')
| -rw-r--r-- | builtin-clone.c | 5 | 
1 files changed, 5 insertions, 0 deletions
| diff --git a/builtin-clone.c b/builtin-clone.c index 7190952071..b2dfe1ab5c 100644 --- a/builtin-clone.c +++ b/builtin-clone.c @@ -400,6 +400,9 @@ int cmd_clone(int argc, const char **argv, const char *prefix)  	if (!option_bare) {  		junk_work_tree = work_tree; +		if (safe_create_leading_directories_const(work_tree) < 0) +			die("could not create leading directories of '%s'", +					work_tree);  		if (mkdir(work_tree, 0755))  			die("could not create work tree dir '%s'.", work_tree);  		set_git_work_tree(work_tree); @@ -410,6 +413,8 @@ int cmd_clone(int argc, const char **argv, const char *prefix)  	setenv(CONFIG_ENVIRONMENT, xstrdup(mkpath("%s/config", git_dir)), 1); +	if (safe_create_leading_directories_const(git_dir) < 0) +		die("could not create leading directories of '%s'", git_dir);  	set_git_dir(make_absolute_path(git_dir));  	fprintf(stderr, "Initialize %s\n", git_dir); | 
