-rw-r--r-- | ui-shared.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/ui-shared.c b/ui-shared.c index 07d5dd4..6cb7edb 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
@@ -715,59 +715,64 @@ void cgit_print_pageheader(struct cgit_context *ctx) | |||
715 | html("<select name='qt'>\n"); | 715 | html("<select name='qt'>\n"); |
716 | html_option("grep", "log msg", ctx->qry.grep); | 716 | html_option("grep", "log msg", ctx->qry.grep); |
717 | html_option("author", "author", ctx->qry.grep); | 717 | html_option("author", "author", ctx->qry.grep); |
718 | html_option("committer", "committer", ctx->qry.grep); | 718 | html_option("committer", "committer", ctx->qry.grep); |
719 | html("</select>\n"); | 719 | html("</select>\n"); |
720 | html("<input class='txt' type='text' size='10' name='q' value='"); | 720 | html("<input class='txt' type='text' size='10' name='q' value='"); |
721 | html_attr(ctx->qry.search); | 721 | html_attr(ctx->qry.search); |
722 | html("'/>\n"); | 722 | html("'/>\n"); |
723 | html("<input type='submit' value='search'/>\n"); | 723 | html("<input type='submit' value='search'/>\n"); |
724 | html("</form>\n"); | 724 | html("</form>\n"); |
725 | } else { | 725 | } else { |
726 | site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); | 726 | site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); |
727 | if (ctx->cfg.root_readme) | 727 | if (ctx->cfg.root_readme) |
728 | site_link("about", "about", NULL, hc(cmd, "about"), | 728 | site_link("about", "about", NULL, hc(cmd, "about"), |
729 | NULL, 0); | 729 | NULL, 0); |
730 | html("</td><td class='form'>"); | 730 | html("</td><td class='form'>"); |
731 | html("<form method='get' action='"); | 731 | html("<form method='get' action='"); |
732 | html_attr(cgit_rooturl()); | 732 | html_attr(cgit_rooturl()); |
733 | html("'>\n"); | 733 | html("'>\n"); |
734 | html("<input type='text' name='q' size='10' value='"); | 734 | html("<input type='text' name='q' size='10' value='"); |
735 | html_attr(ctx->qry.search); | 735 | html_attr(ctx->qry.search); |
736 | html("'/>\n"); | 736 | html("'/>\n"); |
737 | html("<input type='submit' value='search'/>\n"); | 737 | html("<input type='submit' value='search'/>\n"); |
738 | html("</form>"); | 738 | html("</form>"); |
739 | } | 739 | } |
740 | html("</td></tr></table>\n"); | 740 | html("</td></tr></table>\n"); |
741 | html("<div class='content'>"); | 741 | html("<div class='content'>"); |
742 | } | 742 | } |
743 | 743 | ||
744 | void cgit_print_filemode(unsigned short mode) | 744 | void cgit_print_filemode(unsigned short mode) |
745 | { | 745 | { |
746 | if (S_ISDIR(mode)) | 746 | if (S_ISDIR(mode)) |
747 | html("d"); | 747 | html("d"); |
748 | else if (S_ISLNK(mode)) | 748 | else if (S_ISLNK(mode)) |
749 | html("l"); | 749 | html("l"); |
750 | else if (S_ISGITLINK(mode)) | 750 | else if (S_ISGITLINK(mode)) |
751 | html("m"); | 751 | html("m"); |
752 | else | 752 | else |
753 | html("-"); | 753 | html("-"); |
754 | html_fileperm(mode >> 6); | 754 | html_fileperm(mode >> 6); |
755 | html_fileperm(mode >> 3); | 755 | html_fileperm(mode >> 3); |
756 | html_fileperm(mode); | 756 | html_fileperm(mode); |
757 | } | 757 | } |
758 | 758 | ||
759 | void cgit_print_snapshot_links(const char *repo, const char *head, | 759 | void cgit_print_snapshot_links(const char *repo, const char *head, |
760 | const char *hex, int snapshots) | 760 | const char *hex, int snapshots) |
761 | { | 761 | { |
762 | const struct cgit_snapshot_format* f; | 762 | const struct cgit_snapshot_format* f; |
763 | char *prefix; | ||
763 | char *filename; | 764 | char *filename; |
765 | unsigned char sha1[20]; | ||
764 | 766 | ||
767 | if (get_sha1(fmt("refs/tags/%s", hex), sha1) == 0 && | ||
768 | (hex[0] == 'v' || hex[0] == 'V') && isdigit(hex[1])) | ||
769 | hex++; | ||
770 | prefix = xstrdup(fmt("%s-%s", cgit_repobasename(repo), hex)); | ||
765 | for (f = cgit_snapshot_formats; f->suffix; f++) { | 771 | for (f = cgit_snapshot_formats; f->suffix; f++) { |
766 | if (!(snapshots & f->bit)) | 772 | if (!(snapshots & f->bit)) |
767 | continue; | 773 | continue; |
768 | filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, | 774 | filename = fmt("%s%s", prefix, f->suffix); |
769 | f->suffix); | ||
770 | cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename); | 775 | cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename); |
771 | html("<br/>"); | 776 | html("<br/>"); |
772 | } | 777 | } |
773 | } | 778 | } |