Browse Source

worktree: prepare for more checks of whether path can become worktree

Certain conditions must be met for a path to be a valid candidate as the
location of a new worktree; for instance, the path must not exist or
must be an empty directory. Although the number of conditions is small,
new conditions will soon be added so factor out the existing checks into
a separate function to avoid further bloating add_worktree().

Signed-off-by: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Eric Sunshine 6 years ago committed by Junio C Hamano
parent
commit
45059e6468
  1. 9
      builtin/worktree.c

9
builtin/worktree.c

@ -219,6 +219,12 @@ static const char *worktree_basename(const char *path, int *olen)
return name; return name;
} }


static void validate_worktree_add(const char *path, const struct add_opts *opts)
{
if (file_exists(path) && !is_empty_dir(path))
die(_("'%s' already exists"), path);
}

static int add_worktree(const char *path, const char *refname, static int add_worktree(const char *path, const char *refname,
const struct add_opts *opts) const struct add_opts *opts)
{ {
@ -233,8 +239,7 @@ static int add_worktree(const char *path, const char *refname,
struct commit *commit = NULL; struct commit *commit = NULL;
int is_branch = 0; int is_branch = 0;


if (file_exists(path) && !is_empty_dir(path)) validate_worktree_add(path, opts);
die(_("'%s' already exists"), path);


/* is 'refname' a branch or commit? */ /* is 'refname' a branch or commit? */
if (!opts->detach && !strbuf_check_branch_ref(&symref, refname) && if (!opts->detach && !strbuf_check_branch_ref(&symref, refname) &&

Loading…
Cancel
Save