-rw-r--r-- | ui-summary.c | 52 |
1 files changed, 33 insertions, 19 deletions
diff --git a/ui-summary.c b/ui-summary.c index 5518d01..ff3ed4d 100644 --- a/ui-summary.c +++ b/ui-summary.c | |||
@@ -38,66 +38,80 @@ static int cgit_print_branch_cb(const char *refname, const unsigned char *sha1, | |||
38 | html("</td></tr>\n"); | 38 | html("</td></tr>\n"); |
39 | cgit_free_commitinfo(info); | 39 | cgit_free_commitinfo(info); |
40 | } else { | 40 | } else { |
41 | html("<tr><td>"); | 41 | html("<tr><td>"); |
42 | html_txt(buf); | 42 | html_txt(buf); |
43 | html("</td><td colspan='3'>"); | 43 | html("</td><td colspan='3'>"); |
44 | htmlf("*** bad ref %s ***", sha1_to_hex(sha1)); | 44 | htmlf("*** bad ref %s ***", sha1_to_hex(sha1)); |
45 | html("</td></tr>\n"); | 45 | html("</td></tr>\n"); |
46 | } | 46 | } |
47 | return 0; | 47 | return 0; |
48 | } | 48 | } |
49 | 49 | ||
50 | |||
51 | static void cgit_print_object_ref(struct object *obj) | ||
52 | { | ||
53 | char *page, *url; | ||
54 | |||
55 | if (obj->type == OBJ_COMMIT) | ||
56 | page = "commit"; | ||
57 | else if (obj->type == OBJ_TREE) | ||
58 | page = "tree"; | ||
59 | else | ||
60 | page = "view"; | ||
61 | |||
62 | url = cgit_pageurl(cgit_query_repo, page, | ||
63 | fmt("id=%s", sha1_to_hex(obj->sha1))); | ||
64 | html_link_open(url, NULL, NULL); | ||
65 | htmlf("%s %s", type_names[obj->type], | ||
66 | sha1_to_hex(obj->sha1)); | ||
67 | html_link_close(); | ||
68 | } | ||
69 | |||
50 | static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1, | 70 | static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1, |
51 | int flags, void *cb_data) | 71 | int flags, void *cb_data) |
52 | { | 72 | { |
53 | struct tag *tag; | 73 | struct tag *tag; |
54 | struct taginfo *info; | 74 | struct taginfo *info; |
55 | char buf[256], *page, *url; | 75 | struct object *obj; |
56 | 76 | char buf[256], *url; | |
77 | |||
57 | strncpy(buf, refname, sizeof(buf)); | 78 | strncpy(buf, refname, sizeof(buf)); |
58 | tag = lookup_tag(sha1); | 79 | obj = parse_object(sha1); |
59 | if (tag && !parse_tag(tag) && (info = cgit_parse_tag(tag))){ | 80 | if (!obj) |
81 | return 1; | ||
82 | if (obj->type == OBJ_TAG) { | ||
83 | tag = lookup_tag(sha1); | ||
84 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) | ||
85 | return 2; | ||
60 | html("<tr><td>"); | 86 | html("<tr><td>"); |
61 | url = cgit_pageurl(cgit_query_repo, "view", | 87 | url = cgit_pageurl(cgit_query_repo, "view", |
62 | fmt("id=%s", sha1_to_hex(sha1))); | 88 | fmt("id=%s", sha1_to_hex(sha1))); |
63 | html_link_open(url, NULL, NULL); | 89 | html_link_open(url, NULL, NULL); |
64 | html_txt(buf); | 90 | html_txt(buf); |
65 | html_link_close(); | 91 | html_link_close(); |
66 | html("</td><td>"); | 92 | html("</td><td>"); |
67 | if (info->tagger_date > 0) | 93 | if (info->tagger_date > 0) |
68 | cgit_print_date(info->tagger_date); | 94 | cgit_print_date(info->tagger_date); |
69 | html("</td><td>"); | 95 | html("</td><td>"); |
70 | if (info->tagger) | 96 | if (info->tagger) |
71 | html(info->tagger); | 97 | html(info->tagger); |
72 | html("</td><td>"); | 98 | html("</td><td>"); |
73 | if (tag->tagged->type == OBJ_COMMIT) | 99 | cgit_print_object_ref(tag->tagged); |
74 | page = "commit"; | ||
75 | else if (tag->tagged->type == OBJ_TREE) | ||
76 | page = "tree"; | ||
77 | else | ||
78 | page = "view"; | ||
79 | |||
80 | url = cgit_pageurl(cgit_query_repo, page, | ||
81 | fmt("id=%s", sha1_to_hex(tag->tagged->sha1))); | ||
82 | html_link_open(url, NULL, NULL); | ||
83 | htmlf("%s %s", type_names[tag->tagged->type], | ||
84 | sha1_to_hex(tag->tagged->sha1)); | ||
85 | html_link_close(); | ||
86 | html("</td></tr>\n"); | 100 | html("</td></tr>\n"); |
87 | } else { | 101 | } else { |
88 | html("<tr><td>"); | 102 | html("<tr><td>"); |
89 | html_txt(buf); | 103 | html_txt(buf); |
90 | html("</td><td colspan='3'>"); | 104 | html("</td><td colspan='2'/><td>"); |
91 | htmlf("*** bad ref %s ***", sha1_to_hex(sha1)); | 105 | cgit_print_object_ref(obj); |
92 | html("</td></tr>\n"); | 106 | html("</td></tr>\n"); |
93 | } | 107 | } |
94 | return 0; | 108 | return 0; |
95 | } | 109 | } |
96 | 110 | ||
97 | static void cgit_print_branches() | 111 | static void cgit_print_branches() |
98 | { | 112 | { |
99 | html("<tr class='nohover'><th class='left'>Branch</th>" | 113 | html("<tr class='nohover'><th class='left'>Branch</th>" |
100 | "<th class='left'>Updated</th>" | 114 | "<th class='left'>Updated</th>" |
101 | "<th class='left'>Author</th>" | 115 | "<th class='left'>Author</th>" |
102 | "<th class='left'>Head commit</th></tr>\n"); | 116 | "<th class='left'>Head commit</th></tr>\n"); |
103 | for_each_branch_ref(cgit_print_branch_cb, NULL); | 117 | for_each_branch_ref(cgit_print_branch_cb, NULL); |