diff options
author | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-06-02 09:25:44 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-06-02 09:25:44 -0700 |
commit | 3b42a63cb5845ef1c818f6b00e693c61469ee966 (patch) | |
tree | 1482fd25e51da7133271eedb25c7a87fa8be7466 | |
parent | 81f2bb1f54b20abefa9d102ea98c4ac73d81a66d (diff) | |
download | git-3b42a63cb5845ef1c818f6b00e693c61469ee966.tar.gz |
git-rev-list: split out commit limiting from main() too.
Ok, now I'm happier.
-rw-r--r-- | rev-list.c | 38 |
1 files changed, 21 insertions, 17 deletions
diff --git a/rev-list.c b/rev-list.c index 8775b6558d..56dd814c0e 100644 --- a/rev-list.c +++ b/rev-list.c @@ -84,6 +84,25 @@ static int everybody_uninteresting(struct commit_list *list) return 1; } +struct commit_list *limit_list(struct commit_list *list, struct commit *end) +{ + struct commit_list *newlist = NULL; + struct commit_list **p = &newlist; + do { + struct commit *commit = pop_most_recent_commit(&list, SEEN); + struct object *obj = &commit->object; + + if (commit == end || (obj->flags & UNINTERESTING)) { + mark_parents_uninteresting(commit); + if (everybody_uninteresting(list)) + break; + continue; + } + p = &commit_list_insert(commit, p)->next; + } while (list); + return newlist; +} + int main(int argc, char **argv) { int nr_sha; @@ -144,23 +163,8 @@ int main(int argc, char **argv) } commit_list_insert(commit, &list); - if (end) { - struct commit_list *newlist = NULL; - struct commit_list **p = &newlist; - do { - struct commit *commit = pop_most_recent_commit(&list, SEEN); - struct object *obj = &commit->object; - - if (commit == end || (obj->flags & UNINTERESTING)) { - mark_parents_uninteresting(commit); - if (everybody_uninteresting(list)) - break; - continue; - } - p = &commit_list_insert(commit, p)->next; - } while (list); - list = newlist; - } + if (end) + list = limit_list(list, end); show_commit_list(list); return 0; |