提交 bdf0f375 编写于 作者: E Eric Sunshine 提交者: Junio C Hamano

checkout: drop 'checkout_opts' dependency from prepare_linked_checkout

The plan is to relocate "git checkout --to" functionality to "git
worktree add", however, worktree.c won't have access to the 'struct
checkout_opts' passed to prepare_linked_worktree(), which it consults
for the pathname of the new worktree and the argv[] of the command it
should run to populate the new worktree. Facilitate relocation of
prepare_linked_worktree() by instead having it accept the pathname and
argv[] directly, thus eliminating the final references to 'struct
checkout_opts'.
Signed-off-by: NEric Sunshine <sunshine@sunshineco.com>
Signed-off-by: NJunio C Hamano <gitster@pobox.com>
上级 338dfd0d
......@@ -854,11 +854,11 @@ static void remove_junk_on_signal(int signo)
raise(signo);
}
static int prepare_linked_checkout(const struct checkout_opts *opts)
static int prepare_linked_checkout(const char *path, const char **child_argv)
{
struct strbuf sb_git = STRBUF_INIT, sb_repo = STRBUF_INIT;
struct strbuf sb = STRBUF_INIT;
const char *path = opts->new_worktree, *name;
const char *name;
struct stat st;
struct child_process cp;
int counter = 0, len, ret;
......@@ -943,7 +943,7 @@ static int prepare_linked_checkout(const struct checkout_opts *opts)
setenv(GIT_WORK_TREE_ENVIRONMENT, path, 1);
memset(&cp, 0, sizeof(cp));
cp.git_cmd = 1;
cp.argv = opts->saved_argv;
cp.argv = child_argv;
ret = run_command(&cp);
if (!ret) {
is_junk = 0;
......@@ -1302,7 +1302,8 @@ static int checkout_branch(struct checkout_opts *opts,
if (opts->new_worktree) {
if (!new->commit)
die(_("no branch specified"));
return prepare_linked_checkout(opts);
return prepare_linked_checkout(opts->new_worktree,
opts->saved_argv);
}
if (!new->commit && opts->new_branch) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册