X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/502d71072a813e6fadb2e59fb47c2782b542674a..f6310fec783d2721ef61815a0eec525d6a904452:/ui-summary.c diff --git a/ui-summary.c b/ui-summary.c index c684628..05170cc 100644 --- a/ui-summary.c +++ b/ui-summary.c @@ -10,6 +10,28 @@ static int header; +static int cmp_age(int age1, int age2) +{ + if (age1 != 0 && age2 != 0) + return age2 - age1; + + if (age1 == 0 && age2 == 0) + return 0; + + if (age1 == 0) + return +1; + + return -1; +} + +static int cmp_tag_age(const void *a, const void *b) +{ + struct refinfo *r1 = *(struct refinfo **)a; + struct refinfo *r2 = *(struct refinfo **)b; + + return cmp_age(r1->tag->tagger_date, r2->tag->tagger_date); +} + static void cgit_print_branch(struct refinfo *ref) { struct commit *commit; @@ -145,7 +167,7 @@ static void cgit_print_branches() cgit_print_branch(list.refs[i]); } -static void cgit_print_tags() +static void cgit_print_tags(int maxcount) { struct reflist list; int i; @@ -156,8 +178,13 @@ static void cgit_print_tags() for_each_tag_ref(cgit_refs_cb, &list); if (list.count == 0) return; + qsort(list.refs, list.count, sizeof(*list.refs), cmp_tag_age); + if (!maxcount) + maxcount = list.count; + else if (maxcount > list.count) + maxcount = list.count; print_tag_header(); - for(i=0; i "); cgit_print_branches(); html(" "); - cgit_print_tags(); + cgit_print_tags(cgit_summary_tags); html(""); }