commit 145ca42a7aa702ad5d38fd066763f0189ce434af from: Omar Polo via: Thomas Adam date: Mon Jan 09 19:54:05 2023 UTC gotwebd: templateify gotweb_render_tag ok tracey@ commit - 617497a67c0b438c75afefd4fd599a8f88c32bcd commit + 145ca42a7aa702ad5d38fd066763f0189ce434af blob - 0b1abd81d62518e120ff27f91b622b4d30edf168 blob + 3eaf1d89d2b4e560c15602dad237a0831eee97a6 --- gotwebd/gotweb.c +++ gotwebd/gotweb.c @@ -97,7 +97,6 @@ static const struct got_error *gotweb_get_clone_url(ch static const struct got_error *gotweb_render_blame(struct request *); static const struct got_error *gotweb_render_diff(struct request *); static const struct got_error *gotweb_render_summary(struct request *); -static const struct got_error *gotweb_render_tag(struct request *); static const struct got_error *gotweb_render_tags(struct request *); static const struct got_error *gotweb_render_branches(struct request *); @@ -292,11 +291,18 @@ render: } break; case TAG: - error = gotweb_render_tag(c); + error = got_get_repo_tags(c, 1); if (error) { log_warnx("%s: %s", __func__, error->msg); + goto err; + } + if (c->t->tag_count == 0) { + error = got_error_msg(GOT_ERR_BAD_OBJ_ID, + "bad commit id"); goto err; } + if (gotweb_render_tag(c->tp) == -1) + goto done; break; case TAGS: error = gotweb_render_tags(c); @@ -1258,77 +1264,6 @@ done: } static const struct got_error * -gotweb_render_tag(struct request *c) -{ - const struct got_error *error = NULL; - struct repo_tag *rt = NULL; - struct transport *t = c->t; - char *tagname = NULL, *age = NULL, *author = NULL, *msg = NULL; - - error = got_get_repo_tags(c, 1); - if (error) - goto done; - - if (t->tag_count == 0) { - error = got_error_set_errno(GOT_ERR_BAD_OBJ_ID, - "bad commit id"); - goto done; - } - - rt = TAILQ_LAST(&t->repo_tags, repo_tags_head); - - error = gotweb_get_time_str(&age, rt->tagger_time, TM_LONG); - if (error) - goto done; - error = gotweb_escape_html(&author, rt->tagger); - if (error) - goto done; - error = gotweb_escape_html(&msg, rt->commit_msg); - if (error) - goto done; - - tagname = rt->tag_name; - if (strncmp(tagname, "refs/", 5) == 0) - tagname += 5; - error = gotweb_escape_html(&tagname, tagname); - if (error) - goto done; - - fcgi_printf(c, "
\n" - "
Tag
\n" - "
\n" /* #tags_title_wrapper */ - "
\n" - "
\n" - "
\n" - "
Commit:
\n" - "
%s" - " (%s)
\n" - "
Tagger:
\n" - "
%s
\n" - "
Date:
\n" - "
%s
\n" - "
Message:
\n" - "
%s
\n" - "
\n" /* #tag_header */ - "
\n" - "
\n%s
" - "
" /* #tag_header_wrapper */ - "
", /* #tags_content */ - rt->commit_id, - tagname, - author, - age, - msg, - rt->tag_commit); - -done: - free(age); - free(author); - free(msg); - return error; -} - -static const struct got_error * gotweb_render_tags(struct request *c) { const struct got_error *error = NULL; blob - 9b3c0f6a5f288391333fc845d5c6aaa3a7dbc34d blob + 755f5c9adf4cbde8f4f6dba9abcbf57369f646c8 --- gotwebd/gotwebd.h +++ gotwebd/gotwebd.h @@ -472,6 +472,7 @@ int gotweb_render_commits(struct template *); int gotweb_render_blob(struct template *, struct got_blob_object *); int gotweb_render_tree(struct template *); int gotweb_render_tags_tmpl(struct template *); +int gotweb_render_tag(struct template *); int gotweb_render_rss(struct template *); /* parse.y */ blob - ae744ae1953c7666bc7ab0d79a6bf1846a89e58f blob + e5723df827b9f5d7295e67c93df21beb45cb23ba --- gotwebd/pages.tmpl +++ gotwebd/pages.tmpl @@ -648,7 +648,50 @@ gotweb_render_age(struct template *tp, time_t time, in
{{ end }} + +{{ define gotweb_render_tag(struct template *tp) }} +{! + struct request *c = tp->tp_arg; + struct transport *t = c->t; + struct repo_tag *rt; + const char *tag_name; + rt = TAILQ_LAST(&t->repo_tags, repo_tags_head); + tag_name = rt->tag_name; + + if (strncmp(tag_name, "refs/", 5) == 0) + tag_name += 5; +!} +
+
Tag
+
+
+
+
+
Commit:
+
+ {{ rt->commit_id }} + {{ " " }} + ({{ tag_name }}) +
+
Tagger:
+
{{ rt->tagger }}
+
Date:
+
+ {{ render gotweb_render_age(tp, rt->tagger_time, TM_LONG)}} +
+
Message:
+
{{ rt->commit_msg }}
+
+
+
+ {{ "\n" }} + {{ rt->tag_commit }} +
+
+
+{{ end }} + {{ define gotweb_render_rss(struct template *tp) }} {! struct request *c = tp->tp_arg;