builtin/checkout: pass branch info down to checkout_worktree
In the future, we're going to want to use the branch info in checkout_worktree, so let's pass the whole struct branch_info down, not just the revision name. We hoist the definition of struct branch_info so it's in scope. Signed-off-by: brian m. carlson <bk2204@github.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
a56d361f66
commit
a8604766de
@ -88,6 +88,17 @@ struct checkout_opts {
|
|||||||
struct tree *source_tree;
|
struct tree *source_tree;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct branch_info {
|
||||||
|
const char *name; /* The short name used */
|
||||||
|
const char *path; /* The full name of a real branch */
|
||||||
|
struct commit *commit; /* The named commit */
|
||||||
|
/*
|
||||||
|
* if not null the branch is detached because it's already
|
||||||
|
* checked out in this checkout
|
||||||
|
*/
|
||||||
|
char *checkout;
|
||||||
|
};
|
||||||
|
|
||||||
static int post_checkout_hook(struct commit *old_commit, struct commit *new_commit,
|
static int post_checkout_hook(struct commit *old_commit, struct commit *new_commit,
|
||||||
int changed)
|
int changed)
|
||||||
{
|
{
|
||||||
@ -337,7 +348,8 @@ static void mark_ce_for_checkout_no_overlay(struct cache_entry *ce,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int checkout_worktree(const struct checkout_opts *opts)
|
static int checkout_worktree(const struct checkout_opts *opts,
|
||||||
|
const struct branch_info *info)
|
||||||
{
|
{
|
||||||
struct checkout state = CHECKOUT_INIT;
|
struct checkout state = CHECKOUT_INIT;
|
||||||
int nr_checkouts = 0, nr_unmerged = 0;
|
int nr_checkouts = 0, nr_unmerged = 0;
|
||||||
@ -396,7 +408,7 @@ static int checkout_worktree(const struct checkout_opts *opts)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int checkout_paths(const struct checkout_opts *opts,
|
static int checkout_paths(const struct checkout_opts *opts,
|
||||||
const char *revision)
|
const struct branch_info *new_branch_info)
|
||||||
{
|
{
|
||||||
int pos;
|
int pos;
|
||||||
static char *ps_matched;
|
static char *ps_matched;
|
||||||
@ -462,7 +474,7 @@ static int checkout_paths(const struct checkout_opts *opts,
|
|||||||
else
|
else
|
||||||
BUG("either flag must have been set, worktree=%d, index=%d",
|
BUG("either flag must have been set, worktree=%d, index=%d",
|
||||||
opts->checkout_worktree, opts->checkout_index);
|
opts->checkout_worktree, opts->checkout_index);
|
||||||
return run_add_interactive(revision, patch_mode, &opts->pathspec);
|
return run_add_interactive(new_branch_info->name, patch_mode, &opts->pathspec);
|
||||||
}
|
}
|
||||||
|
|
||||||
repo_hold_locked_index(the_repository, &lock_file, LOCK_DIE_ON_ERROR);
|
repo_hold_locked_index(the_repository, &lock_file, LOCK_DIE_ON_ERROR);
|
||||||
@ -523,7 +535,7 @@ static int checkout_paths(const struct checkout_opts *opts,
|
|||||||
|
|
||||||
/* Now we are committed to check them out */
|
/* Now we are committed to check them out */
|
||||||
if (opts->checkout_worktree)
|
if (opts->checkout_worktree)
|
||||||
errs |= checkout_worktree(opts);
|
errs |= checkout_worktree(opts, new_branch_info);
|
||||||
else
|
else
|
||||||
remove_marked_cache_entries(&the_index, 1);
|
remove_marked_cache_entries(&the_index, 1);
|
||||||
|
|
||||||
@ -620,17 +632,6 @@ static int reset_tree(struct tree *tree, const struct checkout_opts *o,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct branch_info {
|
|
||||||
const char *name; /* The short name used */
|
|
||||||
const char *path; /* The full name of a real branch */
|
|
||||||
struct commit *commit; /* The named commit */
|
|
||||||
/*
|
|
||||||
* if not null the branch is detached because it's already
|
|
||||||
* checked out in this checkout
|
|
||||||
*/
|
|
||||||
char *checkout;
|
|
||||||
};
|
|
||||||
|
|
||||||
static void setup_branch_path(struct branch_info *branch)
|
static void setup_branch_path(struct branch_info *branch)
|
||||||
{
|
{
|
||||||
struct strbuf buf = STRBUF_INIT;
|
struct strbuf buf = STRBUF_INIT;
|
||||||
@ -1710,7 +1711,7 @@ static int checkout_main(int argc, const char **argv, const char *prefix,
|
|||||||
|
|
||||||
UNLEAK(opts);
|
UNLEAK(opts);
|
||||||
if (opts->patch_mode || opts->pathspec.nr)
|
if (opts->patch_mode || opts->pathspec.nr)
|
||||||
return checkout_paths(opts, new_branch_info.name);
|
return checkout_paths(opts, &new_branch_info);
|
||||||
else
|
else
|
||||||
return checkout_branch(opts, &new_branch_info);
|
return checkout_branch(opts, &new_branch_info);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user