X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/0f0ab148c6d444316af10e6b4c7a60630fed45d3..81bf4d32b377d3f2fdd7ab3ca651be99408f5c32:/ui-tag.c
diff --git a/ui-tag.c b/ui-tag.c
index b4db32e..aea7958 100644
--- a/ui-tag.c
+++ b/ui-tag.c
@@ -7,6 +7,7 @@
*/
#include "cgit.h"
+#include "ui-tag.h"
#include "html.h"
#include "ui-shared.h"
@@ -30,46 +31,79 @@ static void print_tag_content(char *buf)
}
}
+static void print_download_links(char *revname)
+{
+ html("
| download | ");
+ cgit_print_snapshot_links(ctx.qry.repo, ctx.qry.head,
+ revname, ctx.repo->snapshots);
+ html(" |
");
+}
+
void cgit_print_tag(char *revname)
{
+ struct strbuf fullref = STRBUF_INIT;
unsigned char sha1[20];
struct object *obj;
struct tag *tag;
struct taginfo *info;
- if (get_sha1(revname, sha1)) {
- cgit_print_error(fmt("Bad tag reference: %s", revname));
- return;
+ if (!revname)
+ revname = ctx.qry.head;
+
+ strbuf_addf(&fullref, "refs/tags/%s", revname);
+ if (get_sha1(fullref.buf, sha1)) {
+ cgit_print_error("Bad tag reference: %s", revname);
+ goto cleanup;
}
obj = parse_object(sha1);
if (!obj) {
- cgit_print_error(fmt("Bad object id: %s", sha1_to_hex(sha1)));
- return;
+ cgit_print_error("Bad object id: %s", sha1_to_hex(sha1));
+ goto cleanup;
}
if (obj->type == OBJ_TAG) {
tag = lookup_tag(sha1);
if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) {
- cgit_print_error(fmt("Bad tag object: %s", revname));
- return;
+ cgit_print_error("Bad tag object: %s", revname);
+ goto cleanup;
}
html("\n");
- htmlf("| Tag name | %s (%s) |
\n",
- revname, sha1_to_hex(sha1));
+ htmlf("| tag name | ");
+ html_txt(revname);
+ htmlf(" (%s) |
\n", sha1_to_hex(sha1));
if (info->tagger_date > 0) {
- html("| Tag date | ");
+ html(" |
| tag date | ");
cgit_print_date(info->tagger_date, FMT_LONGDATE, ctx.cfg.local_time);
html(" |
\n");
}
if (info->tagger) {
- html("| Tagged by | ");
+ html(" |
| tagged by | ");
html_txt(info->tagger);
+ if (info->tagger_email && !ctx.cfg.noplainemail) {
+ html(" ");
+ html_txt(info->tagger_email);
+ }
html(" |
\n");
}
- html("| Tagged object | ");
+ html(" |
| tagged object | ");
cgit_object_link(tag->tagged);
html(" |
\n");
+ if (ctx.repo->snapshots)
+ print_download_links(revname);
html("
\n");
print_tag_content(info->msg);
+ } else {
+ html("\n");
+ htmlf("| tag name | ");
+ html_txt(revname);
+ html(" |
\n");
+ html("| Tagged object | ");
+ cgit_object_link(obj);
+ html(" |
\n");
+ if (ctx.repo->snapshots)
+ print_download_links(revname);
+ html("
\n");
}
- return;
+
+cleanup:
+ strbuf_release(&fullref);
}