зеркало из https://github.com/microsoft/git.git
Merge branch 'js/merge-base' into next
* js/merge-base: Teach rev-parse the ... syntax.
This commit is contained in:
Коммит
3b1d06a50c
|
@ -164,6 +164,51 @@ static int show_file(const char *arg)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int try_difference(char *arg)
|
||||||
|
{
|
||||||
|
char *dotdot;
|
||||||
|
unsigned char sha1[20];
|
||||||
|
unsigned char end[20];
|
||||||
|
const char *next;
|
||||||
|
const char *this;
|
||||||
|
int symmetric;
|
||||||
|
|
||||||
|
if (!(dotdot = strstr(arg, "..")))
|
||||||
|
return 0;
|
||||||
|
next = dotdot + 2;
|
||||||
|
this = arg;
|
||||||
|
symmetric = (*next == '.');
|
||||||
|
|
||||||
|
*dotdot = 0;
|
||||||
|
next += symmetric;
|
||||||
|
|
||||||
|
if (!*next)
|
||||||
|
next = "HEAD";
|
||||||
|
if (dotdot == arg)
|
||||||
|
this = "HEAD";
|
||||||
|
if (!get_sha1(this, sha1) && !get_sha1(next, end)) {
|
||||||
|
show_rev(NORMAL, end, next);
|
||||||
|
show_rev(symmetric ? NORMAL : REVERSED, sha1, this);
|
||||||
|
if (symmetric) {
|
||||||
|
struct commit_list *exclude;
|
||||||
|
struct commit *a, *b;
|
||||||
|
a = lookup_commit_reference(sha1);
|
||||||
|
b = lookup_commit_reference(end);
|
||||||
|
exclude = get_merge_bases(a, b, 1);
|
||||||
|
while (exclude) {
|
||||||
|
struct commit_list *n = exclude->next;
|
||||||
|
show_rev(REVERSED,
|
||||||
|
exclude->item->object.sha1,NULL);
|
||||||
|
free(exclude);
|
||||||
|
exclude = n;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
*dotdot = '.';
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int cmd_rev_parse(int argc, const char **argv, char **envp)
|
int cmd_rev_parse(int argc, const char **argv, char **envp)
|
||||||
{
|
{
|
||||||
int i, as_is = 0, verify = 0;
|
int i, as_is = 0, verify = 0;
|
||||||
|
@ -174,7 +219,6 @@ int cmd_rev_parse(int argc, const char **argv, char **envp)
|
||||||
|
|
||||||
for (i = 1; i < argc; i++) {
|
for (i = 1; i < argc; i++) {
|
||||||
const char *arg = argv[i];
|
const char *arg = argv[i];
|
||||||
char *dotdot;
|
|
||||||
|
|
||||||
if (as_is) {
|
if (as_is) {
|
||||||
if (show_file(arg) && as_is < 2)
|
if (show_file(arg) && as_is < 2)
|
||||||
|
@ -326,23 +370,8 @@ int cmd_rev_parse(int argc, const char **argv, char **envp)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Not a flag argument */
|
/* Not a flag argument */
|
||||||
dotdot = strstr(arg, "..");
|
if (try_difference(arg))
|
||||||
if (dotdot) {
|
continue;
|
||||||
unsigned char end[20];
|
|
||||||
const char *next = dotdot + 2;
|
|
||||||
const char *this = arg;
|
|
||||||
*dotdot = 0;
|
|
||||||
if (!*next)
|
|
||||||
next = "HEAD";
|
|
||||||
if (dotdot == arg)
|
|
||||||
this = "HEAD";
|
|
||||||
if (!get_sha1(this, sha1) && !get_sha1(next, end)) {
|
|
||||||
show_rev(NORMAL, end, next);
|
|
||||||
show_rev(REVERSED, sha1, this);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
*dotdot = '.';
|
|
||||||
}
|
|
||||||
if (!get_sha1(arg, sha1)) {
|
if (!get_sha1(arg, sha1)) {
|
||||||
show_rev(NORMAL, sha1, arg);
|
show_rev(NORMAL, sha1, arg);
|
||||||
continue;
|
continue;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче