diff options
| -rw-r--r-- | ui-summary.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/ui-summary.c b/ui-summary.c index 3410e1a..b99ea98 100644 --- a/ui-summary.c +++ b/ui-summary.c | |||
| @@ -130,6 +130,7 @@ static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1, | |||
| 130 | struct taginfo *info; | 130 | struct taginfo *info; |
| 131 | struct object *obj; | 131 | struct object *obj; |
| 132 | char buf[256], *url; | 132 | char buf[256], *url; |
| 133 | unsigned char fileid[20]; | ||
| 133 | 134 | ||
| 134 | if (prefixcmp(refname, "refs/archives")) | 135 | if (prefixcmp(refname, "refs/archives")) |
| 135 | return 0; | 136 | return 0; |
| @@ -141,9 +142,11 @@ static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1, | |||
| 141 | tag = lookup_tag(sha1); | 142 | tag = lookup_tag(sha1); |
| 142 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) | 143 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) |
| 143 | return 0; | 144 | return 0; |
| 144 | hashcpy(sha1, tag->tagged->sha1); | 145 | hashcpy(fileid, tag->tagged->sha1); |
| 145 | } else if (obj->type != OBJ_BLOB) { | 146 | } else if (obj->type != OBJ_BLOB) { |
| 146 | return 0; | 147 | return 0; |
| 148 | } else { | ||
| 149 | hashcpy(fileid, sha1); | ||
| 147 | } | 150 | } |
| 148 | if (!header) { | 151 | if (!header) { |
| 149 | html("<table>"); | 152 | html("<table>"); |
| @@ -152,7 +155,7 @@ static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1, | |||
| 152 | } | 155 | } |
| 153 | html("<tr><td>"); | 156 | html("<tr><td>"); |
| 154 | url = cgit_pageurl(cgit_query_repo, "blob", | 157 | url = cgit_pageurl(cgit_query_repo, "blob", |
| 155 | fmt("id=%s&path=%s", sha1_to_hex(sha1), | 158 | fmt("id=%s&path=%s", sha1_to_hex(fileid), |
| 156 | buf)); | 159 | buf)); |
| 157 | html_link_open(url, NULL, NULL); | 160 | html_link_open(url, NULL, NULL); |
| 158 | html_txt(buf); | 161 | html_txt(buf); |
