]> git.cameronkatri.com Git - cgit.git/blobdiff - ui-tag.c
tests: add tests for xz compressed snapshots
[cgit.git] / ui-tag.c
index b011198489f603baf4e92be5960085c3f1b0c3bc..846d5b141f4380b4d1ff0b612566136cf0633645 100644 (file)
--- a/ui-tag.c
+++ b/ui-tag.c
@@ -34,36 +34,36 @@ static void print_tag_content(char *buf)
 static void print_download_links(char *revname)
 {
        html("<tr><th>download</th><td class='sha1'>");
-       cgit_print_snapshot_links(ctx.qry.repo, ctx.qry.head,
-                                 revname, ctx.repo->snapshots);
+       cgit_print_snapshot_links(ctx.repo, revname, "<br/>");
        html("</td></tr>");
 }
 
 void cgit_print_tag(char *revname)
 {
        struct strbuf fullref = STRBUF_INIT;
-       unsigned char sha1[20];
+       struct object_id oid;
        struct object *obj;
-       struct tag *tag;
-       struct taginfo *info;
 
        if (!revname)
                revname = ctx.qry.head;
 
        strbuf_addf(&fullref, "refs/tags/%s", revname);
-       if (get_sha1(fullref.buf, sha1)) {
+       if (get_oid(fullref.buf, &oid)) {
                cgit_print_error_page(404, "Not found",
                        "Bad tag reference: %s", revname);
                goto cleanup;
        }
-       obj = parse_object(sha1);
+       obj = parse_object(the_repository, &oid);
        if (!obj) {
                cgit_print_error_page(500, "Internal server error",
-                       "Bad object id: %s", sha1_to_hex(sha1));
+                       "Bad object id: %s", oid_to_hex(&oid));
                goto cleanup;
        }
        if (obj->type == OBJ_TAG) {
-               tag = lookup_tag(sha1);
+               struct tag *tag;
+               struct taginfo *info;
+
+               tag = lookup_tag(the_repository, &oid);
                if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) {
                        cgit_print_error_page(500, "Internal server error",
                                "Bad tag object: %s", revname);
@@ -71,13 +71,13 @@ void cgit_print_tag(char *revname)
                }
                cgit_print_layout_start();
                html("<table class='commit-info'>\n");
-               htmlf("<tr><td>tag name</td><td>");
+               html("<tr><td>tag name</td><td>");
                html_txt(revname);
-               htmlf(" (%s)</td></tr>\n", sha1_to_hex(sha1));
+               htmlf(" (%s)</td></tr>\n", oid_to_hex(&oid));
                if (info->tagger_date > 0) {
                        html("<tr><td>tag date</td><td>");
                        html_txt(show_date(info->tagger_date, info->tagger_tz,
-                                               cgit_date_mode(FMT_LONGDATE)));
+                                               cgit_date_mode(DATE_ISO8601)));
                        html("</td></tr>\n");
                }
                if (info->tagger) {
@@ -99,13 +99,14 @@ void cgit_print_tag(char *revname)
                html("</table>\n");
                print_tag_content(info->msg);
                cgit_print_layout_end();
+               cgit_free_taginfo(info);
        } else {
                cgit_print_layout_start();
                html("<table class='commit-info'>\n");
-               htmlf("<tr><td>tag name</td><td>");
+               html("<tr><td>tag name</td><td>");
                html_txt(revname);
                html("</td></tr>\n");
-               html("<tr><td>Tagged object</td><td class='sha1'>");
+               html("<tr><td>tagged object</td><td class='sha1'>");
                cgit_object_link(obj);
                html("</td></tr>\n");
                if (ctx.repo->snapshots)