X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/bf8293d3196d49d6c4a48b254a04415183ca2762..81bf4d32b377d3f2fdd7ab3ca651be99408f5c32:/ui-tag.c
diff --git a/ui-tag.c b/ui-tag.c
index 39e4cb8..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,7 +31,7 @@ static void print_tag_content(char *buf)
}
}
-void print_download_links(char *revname)
+static void print_download_links(char *revname)
{
html("
| download | ");
cgit_print_snapshot_links(ctx.qry.repo, ctx.qry.head,
@@ -40,6 +41,7 @@ void print_download_links(char *revname)
void cgit_print_tag(char *revname)
{
+ struct strbuf fullref = STRBUF_INIT;
unsigned char sha1[20];
struct object *obj;
struct tag *tag;
@@ -48,20 +50,21 @@ void cgit_print_tag(char *revname)
if (!revname)
revname = ctx.qry.head;
- if (get_sha1(fmt("refs/tags/%s", revname), sha1)) {
- cgit_print_error(fmt("Bad tag reference: %s", revname));
- return;
+ 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 | ");
@@ -99,6 +102,8 @@ void cgit_print_tag(char *revname)
if (ctx.repo->snapshots)
print_download_links(revname);
html(" | \n");
- }
- return;
+ }
+
+cleanup:
+ strbuf_release(&fullref);
}
|
|---|