checkout-index: allow checking out from higher stages.
The new option, --stage=<n>, lets you copy out from an unmerged, higher stage. This is to help the new merge world order during a nontrivial merge. Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
parent
9754563ca9
commit
3bd348aeea
@ -9,7 +9,7 @@ git-checkout-index - Copy files from the index to the working directory
|
|||||||
SYNOPSIS
|
SYNOPSIS
|
||||||
--------
|
--------
|
||||||
'git-checkout-index' [-u] [-q] [-a] [-f] [-n] [--prefix=<string>]
|
'git-checkout-index' [-u] [-q] [-a] [-f] [-n] [--prefix=<string>]
|
||||||
[--] <file>...
|
[--stage=<number>] [--] <file>...
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
-----------
|
-----------
|
||||||
@ -40,6 +40,10 @@ OPTIONS
|
|||||||
When creating files, prepend <string> (usually a directory
|
When creating files, prepend <string> (usually a directory
|
||||||
including a trailing /)
|
including a trailing /)
|
||||||
|
|
||||||
|
--stage=<number>::
|
||||||
|
Instead of checking out unmerged entries, copy out the
|
||||||
|
files from named stage. <number> must be between 1 and 3.
|
||||||
|
|
||||||
--::
|
--::
|
||||||
Do not interpret any more arguments as options.
|
Do not interpret any more arguments as options.
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
|
|
||||||
static const char *prefix;
|
static const char *prefix;
|
||||||
static int prefix_length;
|
static int prefix_length;
|
||||||
|
static int checkout_stage; /* default to checkout stage0 */
|
||||||
|
|
||||||
static struct checkout state = {
|
static struct checkout state = {
|
||||||
.base_dir = "",
|
.base_dir = "",
|
||||||
@ -48,20 +49,36 @@ static struct checkout state = {
|
|||||||
|
|
||||||
static int checkout_file(const char *name)
|
static int checkout_file(const char *name)
|
||||||
{
|
{
|
||||||
int pos = cache_name_pos(name, strlen(name));
|
int namelen = strlen(name);
|
||||||
if (pos < 0) {
|
int pos = cache_name_pos(name, namelen);
|
||||||
if (!state.quiet) {
|
int has_same_name = 0;
|
||||||
pos = -pos - 1;
|
|
||||||
fprintf(stderr,
|
if (pos < 0)
|
||||||
"git-checkout-index: %s is %s.\n",
|
pos = -pos - 1;
|
||||||
name,
|
|
||||||
(pos < active_nr &&
|
while (pos < active_nr) {
|
||||||
!strcmp(active_cache[pos]->name, name)) ?
|
struct cache_entry *ce = active_cache[pos];
|
||||||
"unmerged" : "not in the cache");
|
if (ce_namelen(ce) != namelen &&
|
||||||
}
|
memcmp(ce->name, name, namelen))
|
||||||
return -1;
|
break;
|
||||||
|
has_same_name = 1;
|
||||||
|
if (checkout_stage == ce_stage(ce))
|
||||||
|
return checkout_entry(ce, &state);
|
||||||
|
pos++;
|
||||||
}
|
}
|
||||||
return checkout_entry(active_cache[pos], &state);
|
|
||||||
|
if (!state.quiet) {
|
||||||
|
fprintf(stderr, "git-checkout-index: %s ", name);
|
||||||
|
if (!has_same_name)
|
||||||
|
fprintf(stderr, "is not in the cache");
|
||||||
|
else if (checkout_stage)
|
||||||
|
fprintf(stderr, "does not exist at stage %d",
|
||||||
|
checkout_stage);
|
||||||
|
else
|
||||||
|
fprintf(stderr, "is unmerged");
|
||||||
|
fputc('\n', stderr);
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int checkout_all(void)
|
static int checkout_all(void)
|
||||||
@ -70,11 +87,11 @@ static int checkout_all(void)
|
|||||||
|
|
||||||
for (i = 0; i < active_nr ; i++) {
|
for (i = 0; i < active_nr ; i++) {
|
||||||
struct cache_entry *ce = active_cache[i];
|
struct cache_entry *ce = active_cache[i];
|
||||||
if (ce_stage(ce))
|
if (ce_stage(ce) != checkout_stage)
|
||||||
continue;
|
continue;
|
||||||
if (prefix && *prefix &&
|
if (prefix && *prefix &&
|
||||||
( ce_namelen(ce) <= prefix_length ||
|
(ce_namelen(ce) <= prefix_length ||
|
||||||
memcmp(prefix, ce->name, prefix_length) ))
|
memcmp(prefix, ce->name, prefix_length)))
|
||||||
continue;
|
continue;
|
||||||
if (checkout_entry(ce, &state) < 0)
|
if (checkout_entry(ce, &state) < 0)
|
||||||
errs++;
|
errs++;
|
||||||
@ -88,7 +105,7 @@ static int checkout_all(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static const char checkout_cache_usage[] =
|
static const char checkout_cache_usage[] =
|
||||||
"git-checkout-index [-u] [-q] [-a] [-f] [-n] [--prefix=<string>] [--] <file>...";
|
"git-checkout-index [-u] [-q] [-a] [-f] [-n] [--stage=[123]] [--prefix=<string>] [--] <file>...";
|
||||||
|
|
||||||
static struct cache_file cache_file;
|
static struct cache_file cache_file;
|
||||||
|
|
||||||
@ -138,11 +155,19 @@ int main(int argc, char **argv)
|
|||||||
die("cannot open index.lock file.");
|
die("cannot open index.lock file.");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!memcmp(arg, "--prefix=", 9)) {
|
if (!strncmp(arg, "--prefix=", 9)) {
|
||||||
state.base_dir = arg+9;
|
state.base_dir = arg+9;
|
||||||
state.base_dir_len = strlen(state.base_dir);
|
state.base_dir_len = strlen(state.base_dir);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (!strncmp(arg, "--stage=", 8)) {
|
||||||
|
int ch = arg[8];
|
||||||
|
if ('1' <= ch && ch <= '3')
|
||||||
|
checkout_stage = arg[8] - '0';
|
||||||
|
else
|
||||||
|
die("stage should be between 1 and 3");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (arg[0] == '-')
|
if (arg[0] == '-')
|
||||||
usage(checkout_cache_usage);
|
usage(checkout_cache_usage);
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user