diff options
author | Junio C Hamano <junkio@cox.net> | 2005-08-04 02:31:15 -0700 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2005-08-05 01:25:31 -0700 |
commit | 1215879cdcc508e30415e45ca2c8022f4f3976d6 (patch) | |
tree | c07a13115325cde0f6e51a469118b88b700834ac | |
parent | 9938af6a85dd08436ad373fc07a1ddba8dcfa170 (diff) | |
download | git-1215879cdcc508e30415e45ca2c8022f4f3976d6.tar.gz git-1215879cdcc508e30415e45ca2c8022f4f3976d6.tar.xz |
Teach rev-list since..til notation.
The King Penguin says:
Now, for extra bonus points, maybe you should make "git-rev-list" also
understand the "rev..rev" format (which you can't do with just the
get_sha1() interface, since it expands into more).
The faithful servant makes it so.
Signed-off-by: Junio C Hamano <junkio@cox.net>
-rw-r--r-- | rev-list.c | 38 |
1 files changed, 30 insertions, 8 deletions
diff --git a/rev-list.c b/rev-list.c index 83a604ae9..fae30a2b6 100644 --- a/rev-list.c +++ b/rev-list.c @@ -457,6 +457,15 @@ static struct commit *get_commit_reference(const char *name, unsigned int flags) die("%s is unknown object", name); } +static void handle_one_commit(struct commit *com, struct commit_list **lst) +{ + if (!com || com->object.flags & SEEN) + return; + com->object.flags |= SEEN; + commit_list_insert(com, lst); +} + + int main(int argc, char **argv) { struct commit_list *list = NULL; @@ -465,6 +474,7 @@ int main(int argc, char **argv) for (i = 1 ; i < argc; i++) { int flags; char *arg = argv[i]; + char *dotdot; struct commit *commit; if (!strncmp(arg, "--max-count=", 12)) { @@ -523,21 +533,33 @@ int main(int argc, char **argv) continue; } + if (show_breaks && !merge_order) + usage(rev_list_usage); + flags = 0; + dotdot = strstr(arg, ".."); + if (dotdot) { + char *next = dotdot + 2; + struct commit *exclude = NULL; + struct commit *include = NULL; + *dotdot = 0; + exclude = get_commit_reference(arg, UNINTERESTING); + include = get_commit_reference(next, 0); + if (exclude && include) { + limited = 1; + handle_one_commit(exclude, &list); + handle_one_commit(include, &list); + continue; + } + *next = '.'; + } if (*arg == '^') { flags = UNINTERESTING; arg++; limited = 1; } - if (show_breaks && !merge_order) - usage(rev_list_usage); commit = get_commit_reference(arg, flags); - if (!commit) - continue; - if (commit->object.flags & SEEN) - continue; - commit->object.flags |= SEEN; - commit_list_insert(commit, &list); + handle_one_commit(commit, &list); } if (!merge_order) { |