summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--ui-refs.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/ui-refs.c b/ui-refs.c
index d61ee7c..c35e694 100644
--- a/ui-refs.c
+++ b/ui-refs.c
@@ -96,97 +96,97 @@ static void print_tag_downloads(const struct cgit_repo *repo, const char *ref)
96 96
97 basename = cgit_repobasename(repo->url); 97 basename = cgit_repobasename(repo->url);
98 if (prefixcmp(ref, basename) != 0) { 98 if (prefixcmp(ref, basename) != 0) {
99 if ((ref[0] == 'v' || ref[0] == 'V') && isdigit(ref[1])) 99 if ((ref[0] == 'v' || ref[0] == 'V') && isdigit(ref[1]))
100 ref++; 100 ref++;
101 if (isdigit(ref[0])) 101 if (isdigit(ref[0]))
102 ref = xstrdup(fmt("%s-%s", basename, ref)); 102 ref = xstrdup(fmt("%s-%s", basename, ref));
103 } 103 }
104 104
105 for (f = cgit_snapshot_formats; f->suffix; f++) { 105 for (f = cgit_snapshot_formats; f->suffix; f++) {
106 if (!(repo->snapshots & f->bit)) 106 if (!(repo->snapshots & f->bit))
107 continue; 107 continue;
108 filename = fmt("%s%s", ref, f->suffix); 108 filename = fmt("%s%s", ref, f->suffix);
109 cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename); 109 cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename);
110 html("  "); 110 html("  ");
111 } 111 }
112} 112}
113static int print_tag(struct refinfo *ref) 113static int print_tag(struct refinfo *ref)
114{ 114{
115 struct tag *tag; 115 struct tag *tag;
116 struct taginfo *info; 116 struct taginfo *info;
117 char *name = (char *)ref->refname; 117 char *name = (char *)ref->refname;
118 118
119 if (ref->object->type == OBJ_TAG) { 119 if (ref->object->type == OBJ_TAG) {
120 tag = (struct tag *)ref->object; 120 tag = (struct tag *)ref->object;
121 info = ref->tag; 121 info = ref->tag;
122 if (!tag || !info) 122 if (!tag || !info)
123 return 1; 123 return 1;
124 html("<tr><td>"); 124 html("<tr><td>");
125 cgit_tag_link(name, NULL, NULL, ctx.qry.head, name); 125 cgit_tag_link(name, NULL, NULL, ctx.qry.head, name);
126 html("</td><td>"); 126 html("</td><td>");
127 if (ctx.repo->snapshots && (tag->tagged->type == OBJ_COMMIT)) 127 if (ctx.repo->snapshots && (tag->tagged->type == OBJ_COMMIT))
128 print_tag_downloads(ctx.repo, name); 128 print_tag_downloads(ctx.repo, name);
129 else 129 else
130 cgit_object_link(tag->tagged); 130 cgit_object_link(tag->tagged);
131 html("</td><td>"); 131 html("</td><td>");
132 if (info->tagger) 132 if (info->tagger)
133 html(info->tagger); 133 html(info->tagger);
134 html("</td><td colspan='2'>"); 134 html("</td><td colspan='2'>");
135 if (info->tagger_date > 0) 135 if (info->tagger_date > 0)
136 cgit_print_age(info->tagger_date, -1, NULL); 136 cgit_print_age(info->tagger_date, -1, NULL);
137 html("</td></tr>\n"); 137 html("</td></tr>\n");
138 } else { 138 } else {
139 if (!header) 139 if (!header)
140 print_tag_header(); 140 print_tag_header();
141 html("<tr><td>"); 141 html("<tr><td>");
142 html_txt(name); 142 html_txt(name);
143 html("</td><td>"); 143 html("</td><td>");
144 if (ctx.repo->snapshots && (tag->tagged->type == OBJ_COMMIT)) 144 if (ctx.repo->snapshots && (ref->object->type == OBJ_COMMIT))
145 print_tag_downloads(ctx.repo, name); 145 print_tag_downloads(ctx.repo, name);
146 else 146 else
147 cgit_object_link(ref->object); 147 cgit_object_link(ref->object);
148 html("</td></tr>\n"); 148 html("</td></tr>\n");
149 } 149 }
150 return 0; 150 return 0;
151} 151}
152 152
153static void print_refs_link(char *path) 153static void print_refs_link(char *path)
154{ 154{
155 html("<tr class='nohover'><td colspan='4'>"); 155 html("<tr class='nohover'><td colspan='4'>");
156 cgit_refs_link("[...]", NULL, NULL, ctx.qry.head, NULL, path); 156 cgit_refs_link("[...]", NULL, NULL, ctx.qry.head, NULL, path);
157 html("</td></tr>"); 157 html("</td></tr>");
158} 158}
159 159
160void cgit_print_branches(int maxcount) 160void cgit_print_branches(int maxcount)
161{ 161{
162 struct reflist list; 162 struct reflist list;
163 int i; 163 int i;
164 164
165 html("<tr class='nohover'><th class='left'>Branch</th>" 165 html("<tr class='nohover'><th class='left'>Branch</th>"
166 "<th class='left'>Commit message</th>" 166 "<th class='left'>Commit message</th>"
167 "<th class='left'>Author</th>" 167 "<th class='left'>Author</th>"
168 "<th class='left' colspan='2'>Age</th></tr>\n"); 168 "<th class='left' colspan='2'>Age</th></tr>\n");
169 169
170 list.refs = NULL; 170 list.refs = NULL;
171 list.alloc = list.count = 0; 171 list.alloc = list.count = 0;
172 for_each_branch_ref(cgit_refs_cb, &list); 172 for_each_branch_ref(cgit_refs_cb, &list);
173 173
174 if (maxcount == 0 || maxcount > list.count) 174 if (maxcount == 0 || maxcount > list.count)
175 maxcount = list.count; 175 maxcount = list.count;
176 176
177 if (maxcount < list.count) { 177 if (maxcount < list.count) {
178 qsort(list.refs, list.count, sizeof(*list.refs), cmp_branch_age); 178 qsort(list.refs, list.count, sizeof(*list.refs), cmp_branch_age);
179 qsort(list.refs, maxcount, sizeof(*list.refs), cmp_ref_name); 179 qsort(list.refs, maxcount, sizeof(*list.refs), cmp_ref_name);
180 } 180 }
181 181
182 for(i=0; i<maxcount; i++) 182 for(i=0; i<maxcount; i++)
183 print_branch(list.refs[i]); 183 print_branch(list.refs[i]);
184 184
185 if (maxcount < list.count) 185 if (maxcount < list.count)
186 print_refs_link("heads"); 186 print_refs_link("heads");
187} 187}
188 188
189void cgit_print_tags(int maxcount) 189void cgit_print_tags(int maxcount)
190{ 190{
191 struct reflist list; 191 struct reflist list;
192 int i; 192 int i;