summaryrefslogtreecommitdiff
path: root/ui-summary.c
diff options
context:
space:
mode:
authorLars Hjemli <hjemli@gmail.com>2007-10-28 15:36:18 +0100
committerLars Hjemli <hjemli@gmail.com>2007-10-28 15:38:19 +0100
commitcbcdbcf2bff23113fe81df8f11fe7843b8ed637e (patch)
tree1c434e9005aa946daa8f7aa49a9c9f3656349068 /ui-summary.c
parent68ca032dbe7379f78775fb03ef34a9ad2abc409f (diff)
downloadcgit-cbcdbcf2bff23113fe81df8f11fe7843b8ed637e.tar.gz
cgit-cbcdbcf2bff23113fe81df8f11fe7843b8ed637e.tar.bz2
cgit-cbcdbcf2bff23113fe81df8f11fe7843b8ed637e.zip
Make print_branch() handle refs not pointing at commits
The master branch of stable/linux-2.6.20 currently references a tag object, which makes print_branch() die with a segfault. This teaches print_branch() to handle such cases more gracefully. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to '')
-rw-r--r--ui-summary.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/ui-summary.c b/ui-summary.c
index 04a466a..ba90510 100644
--- a/ui-summary.c
+++ b/ui-summary.c
@@ -58,11 +58,17 @@ static int print_branch(struct refinfo *ref)
html("<tr><td>");
cgit_log_link(name, NULL, NULL, name, NULL, NULL, 0);
html("</td><td>");
- cgit_print_age(info->commit->date, -1, NULL);
- html("</td><td>");
- html_txt(info->author);
- html("</td><td>");
- cgit_commit_link(info->subject, NULL, NULL, name, NULL);
+
+ if (ref->object->type == OBJ_COMMIT) {
+ cgit_print_age(info->commit->date, -1, NULL);
+ html("</td><td>");
+ html_txt(info->author);
+ html("</td><td>");
+ cgit_commit_link(info->subject, NULL, NULL, name, NULL);
+ } else {
+ html("</td><td></td><td>");
+ cgit_object_link(ref->object);
+ }
html("</td></tr>\n");
return 0;
}