Browse Source

Merge branch 'jc/skip-count'

* jc/skip-count:
  revision: --skip=<n>
maint
Junio C Hamano 18 years ago
parent
commit
d4ada4876d
  1. 5
      Documentation/git-rev-list.txt
  2. 46
      revision.c
  3. 1
      revision.h
  4. 51
      t/t6005-rev-list-count.sh

5
Documentation/git-rev-list.txt

@ -10,6 +10,7 @@ SYNOPSIS @@ -10,6 +10,7 @@ SYNOPSIS
--------
[verse]
'git-rev-list' [ \--max-count=number ]
[ \--skip=number ]
[ \--max-age=timestamp ]
[ \--min-age=timestamp ]
[ \--sparse ]
@ -139,6 +140,10 @@ limiting may be applied. @@ -139,6 +140,10 @@ limiting may be applied.

Limit the number of commits output.

--skip='number'::

Skip 'number' commits before starting to show the commit output.

--since='date', --after='date'::

Show commits more recent than a specific date.

46
revision.c

@ -526,6 +526,7 @@ void init_revisions(struct rev_info *revs, const char *prefix) @@ -526,6 +526,7 @@ void init_revisions(struct rev_info *revs, const char *prefix)
revs->prefix = prefix;
revs->max_age = -1;
revs->min_age = -1;
revs->skip_count = -1;
revs->max_count = -1;

revs->prune_fn = NULL;
@ -762,6 +763,10 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch @@ -762,6 +763,10 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch
revs->max_count = atoi(arg + 12);
continue;
}
if (!strncmp(arg, "--skip=", 7)) {
revs->skip_count = atoi(arg + 7);
continue;
}
/* accept -<digit>, like traditional "head" */
if ((*arg == '-') && isdigit(arg[1])) {
revs->max_count = atoi(arg + 1);
@ -1129,23 +1134,11 @@ static int commit_match(struct commit *commit, struct rev_info *opt) @@ -1129,23 +1134,11 @@ static int commit_match(struct commit *commit, struct rev_info *opt)
commit->buffer, strlen(commit->buffer));
}

struct commit *get_revision(struct rev_info *revs)
static struct commit *get_revision_1(struct rev_info *revs)
{
struct commit_list *list = revs->commits;

if (!list)
if (!revs->commits)
return NULL;

/* Check the max_count ... */
switch (revs->max_count) {
case -1:
break;
case 0:
return NULL;
default:
revs->max_count--;
}

do {
struct commit_list *entry = revs->commits;
struct commit *commit = entry->item;
@ -1212,3 +1205,28 @@ struct commit *get_revision(struct rev_info *revs) @@ -1212,3 +1205,28 @@ struct commit *get_revision(struct rev_info *revs)
} while (revs->commits);
return NULL;
}

struct commit *get_revision(struct rev_info *revs)
{
struct commit *c = NULL;

if (0 < revs->skip_count) {
while ((c = get_revision_1(revs)) != NULL) {
if (revs->skip_count-- <= 0)
break;
}
}

/* Check the max_count ... */
switch (revs->max_count) {
case -1:
break;
case 0:
return NULL;
default:
revs->max_count--;
}
if (c)
return c;
return get_revision_1(revs);
}

1
revision.h

@ -77,6 +77,7 @@ struct rev_info { @@ -77,6 +77,7 @@ struct rev_info {
struct grep_opt *grep_filter;

/* special limits */
int skip_count;
int max_count;
unsigned long max_age;
unsigned long min_age;

51
t/t6005-rev-list-count.sh

@ -0,0 +1,51 @@ @@ -0,0 +1,51 @@
#!/bin/sh

test_description='git-rev-list --max-count and --skip test'

. ./test-lib.sh

test_expect_success 'setup' '
for n in 1 2 3 4 5 ; do \
echo $n > a ; \
git add a ; \
git commit -m "$n" ; \
done
'

test_expect_success 'no options' '
test $(git-rev-list HEAD | wc -l) = 5
'

test_expect_success '--max-count' '
test $(git-rev-list HEAD --max-count=0 | wc -l) = 0 &&
test $(git-rev-list HEAD --max-count=3 | wc -l) = 3 &&
test $(git-rev-list HEAD --max-count=5 | wc -l) = 5 &&
test $(git-rev-list HEAD --max-count=10 | wc -l) = 5
'

test_expect_success '--max-count all forms' '
test $(git-rev-list HEAD --max-count=1 | wc -l) = 1 &&
test $(git-rev-list HEAD -1 | wc -l) = 1 &&
test $(git-rev-list HEAD -n1 | wc -l) = 1 &&
test $(git-rev-list HEAD -n 1 | wc -l) = 1
'

test_expect_success '--skip' '
test $(git-rev-list HEAD --skip=0 | wc -l) = 5 &&
test $(git-rev-list HEAD --skip=3 | wc -l) = 2 &&
test $(git-rev-list HEAD --skip=5 | wc -l) = 0 &&
test $(git-rev-list HEAD --skip=10 | wc -l) = 0
'

test_expect_success '--skip --max-count' '
test $(git-rev-list HEAD --skip=0 --max-count=0 | wc -l) = 0 &&
test $(git-rev-list HEAD --skip=0 --max-count=10 | wc -l) = 5 &&
test $(git-rev-list HEAD --skip=3 --max-count=0 | wc -l) = 0 &&
test $(git-rev-list HEAD --skip=3 --max-count=1 | wc -l) = 1 &&
test $(git-rev-list HEAD --skip=3 --max-count=2 | wc -l) = 2 &&
test $(git-rev-list HEAD --skip=3 --max-count=10 | wc -l) = 2 &&
test $(git-rev-list HEAD --skip=5 --max-count=10 | wc -l) = 0 &&
test $(git-rev-list HEAD --skip=10 --max-count=10 | wc -l) = 0
'

test_done
Loading…
Cancel
Save