summaryrefslogtreecommitdiffabout
path: root/ui-shared.c
authorLars Hjemli <hjemli@gmail.com>2010-06-19 12:32:37 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2010-06-19 12:32:37 (UTC)
commita579fb02561c98a146c9e707d098d2b10aa02015 (patch) (unidiff)
treee1911ad2d4fb342945474f8fa34fa5bd5e73cab0 /ui-shared.c
parent47187b33be1c3de43fbed6f350ab05bc978aacd0 (diff)
downloadcgit-a579fb02561c98a146c9e707d098d2b10aa02015.zip
cgit-a579fb02561c98a146c9e707d098d2b10aa02015.tar.gz
cgit-a579fb02561c98a146c9e707d098d2b10aa02015.tar.bz2
ui-log.c: allow commit range as search expression
Inspired-by: Johan Herland <johan@herland.net> Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'ui-shared.c') (more/less context) (ignore whitespace changes)
-rw-r--r--ui-shared.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/ui-shared.c b/ui-shared.c
index 8827fff..0f65474 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -549,252 +549,253 @@ void cgit_print_docend()
549 if (ctx.cfg.embedded) { 549 if (ctx.cfg.embedded) {
550 html("</div> <!-- id=cgit -->\n"); 550 html("</div> <!-- id=cgit -->\n");
551 if (ctx.cfg.footer) 551 if (ctx.cfg.footer)
552 html_include(ctx.cfg.footer); 552 html_include(ctx.cfg.footer);
553 return; 553 return;
554 } 554 }
555 if (ctx.cfg.footer) 555 if (ctx.cfg.footer)
556 html_include(ctx.cfg.footer); 556 html_include(ctx.cfg.footer);
557 else { 557 else {
558 htmlf("<div class='footer'>generated by cgit %s at ", 558 htmlf("<div class='footer'>generated by cgit %s at ",
559 cgit_version); 559 cgit_version);
560 cgit_print_date(time(NULL), FMT_LONGDATE, ctx.cfg.local_time); 560 cgit_print_date(time(NULL), FMT_LONGDATE, ctx.cfg.local_time);
561 html("</div>\n"); 561 html("</div>\n");
562 } 562 }
563 html("</div> <!-- id=cgit -->\n"); 563 html("</div> <!-- id=cgit -->\n");
564 html("</body>\n</html>\n"); 564 html("</body>\n</html>\n");
565} 565}
566 566
567int print_branch_option(const char *refname, const unsigned char *sha1, 567int print_branch_option(const char *refname, const unsigned char *sha1,
568 int flags, void *cb_data) 568 int flags, void *cb_data)
569{ 569{
570 char *name = (char *)refname; 570 char *name = (char *)refname;
571 html_option(name, name, ctx.qry.head); 571 html_option(name, name, ctx.qry.head);
572 return 0; 572 return 0;
573} 573}
574 574
575int print_archive_ref(const char *refname, const unsigned char *sha1, 575int print_archive_ref(const char *refname, const unsigned char *sha1,
576 int flags, void *cb_data) 576 int flags, void *cb_data)
577{ 577{
578 struct tag *tag; 578 struct tag *tag;
579 struct taginfo *info; 579 struct taginfo *info;
580 struct object *obj; 580 struct object *obj;
581 char buf[256], *url; 581 char buf[256], *url;
582 unsigned char fileid[20]; 582 unsigned char fileid[20];
583 int *header = (int *)cb_data; 583 int *header = (int *)cb_data;
584 584
585 if (prefixcmp(refname, "refs/archives")) 585 if (prefixcmp(refname, "refs/archives"))
586 return 0; 586 return 0;
587 strncpy(buf, refname+14, sizeof(buf)); 587 strncpy(buf, refname+14, sizeof(buf));
588 obj = parse_object(sha1); 588 obj = parse_object(sha1);
589 if (!obj) 589 if (!obj)
590 return 1; 590 return 1;
591 if (obj->type == OBJ_TAG) { 591 if (obj->type == OBJ_TAG) {
592 tag = lookup_tag(sha1); 592 tag = lookup_tag(sha1);
593 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 593 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
594 return 0; 594 return 0;
595 hashcpy(fileid, tag->tagged->sha1); 595 hashcpy(fileid, tag->tagged->sha1);
596 } else if (obj->type != OBJ_BLOB) { 596 } else if (obj->type != OBJ_BLOB) {
597 return 0; 597 return 0;
598 } else { 598 } else {
599 hashcpy(fileid, sha1); 599 hashcpy(fileid, sha1);
600 } 600 }
601 if (!*header) { 601 if (!*header) {
602 html("<h1>download</h1>\n"); 602 html("<h1>download</h1>\n");
603 *header = 1; 603 *header = 1;
604 } 604 }
605 url = cgit_pageurl(ctx.qry.repo, "blob", 605 url = cgit_pageurl(ctx.qry.repo, "blob",
606 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid), 606 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid),
607 buf)); 607 buf));
608 html_link_open(url, NULL, "menu"); 608 html_link_open(url, NULL, "menu");
609 html_txt(strlpart(buf, 20)); 609 html_txt(strlpart(buf, 20));
610 html_link_close(); 610 html_link_close();
611 return 0; 611 return 0;
612} 612}
613 613
614void cgit_add_hidden_formfields(int incl_head, int incl_search, char *page) 614void cgit_add_hidden_formfields(int incl_head, int incl_search, char *page)
615{ 615{
616 char *url; 616 char *url;
617 617
618 if (!ctx.cfg.virtual_root) { 618 if (!ctx.cfg.virtual_root) {
619 url = fmt("%s/%s", ctx.qry.repo, page); 619 url = fmt("%s/%s", ctx.qry.repo, page);
620 if (ctx.qry.path) 620 if (ctx.qry.path)
621 url = fmt("%s/%s", url, ctx.qry.path); 621 url = fmt("%s/%s", url, ctx.qry.path);
622 html_hidden("url", url); 622 html_hidden("url", url);
623 } 623 }
624 624
625 if (incl_head && ctx.qry.head && ctx.repo->defbranch && 625 if (incl_head && ctx.qry.head && ctx.repo->defbranch &&
626 strcmp(ctx.qry.head, ctx.repo->defbranch)) 626 strcmp(ctx.qry.head, ctx.repo->defbranch))
627 html_hidden("h", ctx.qry.head); 627 html_hidden("h", ctx.qry.head);
628 628
629 if (ctx.qry.sha1) 629 if (ctx.qry.sha1)
630 html_hidden("id", ctx.qry.sha1); 630 html_hidden("id", ctx.qry.sha1);
631 if (ctx.qry.sha2) 631 if (ctx.qry.sha2)
632 html_hidden("id2", ctx.qry.sha2); 632 html_hidden("id2", ctx.qry.sha2);
633 if (ctx.qry.showmsg) 633 if (ctx.qry.showmsg)
634 html_hidden("showmsg", "1"); 634 html_hidden("showmsg", "1");
635 635
636 if (incl_search) { 636 if (incl_search) {
637 if (ctx.qry.grep) 637 if (ctx.qry.grep)
638 html_hidden("qt", ctx.qry.grep); 638 html_hidden("qt", ctx.qry.grep);
639 if (ctx.qry.search) 639 if (ctx.qry.search)
640 html_hidden("q", ctx.qry.search); 640 html_hidden("q", ctx.qry.search);
641 } 641 }
642} 642}
643 643
644const char *fallback_cmd = "repolist"; 644const char *fallback_cmd = "repolist";
645 645
646char *hc(struct cgit_cmd *cmd, const char *page) 646char *hc(struct cgit_cmd *cmd, const char *page)
647{ 647{
648 return (strcmp(cmd ? cmd->name : fallback_cmd, page) ? NULL : "active"); 648 return (strcmp(cmd ? cmd->name : fallback_cmd, page) ? NULL : "active");
649} 649}
650 650
651static void print_header(struct cgit_context *ctx) 651static void print_header(struct cgit_context *ctx)
652{ 652{
653 html("<table id='header'>\n"); 653 html("<table id='header'>\n");
654 html("<tr>\n"); 654 html("<tr>\n");
655 655
656 if (ctx->cfg.logo && ctx->cfg.logo[0] != 0) { 656 if (ctx->cfg.logo && ctx->cfg.logo[0] != 0) {
657 html("<td class='logo' rowspan='2'><a href='"); 657 html("<td class='logo' rowspan='2'><a href='");
658 if (ctx->cfg.logo_link) 658 if (ctx->cfg.logo_link)
659 html_attr(ctx->cfg.logo_link); 659 html_attr(ctx->cfg.logo_link);
660 else 660 else
661 html_attr(cgit_rooturl()); 661 html_attr(cgit_rooturl());
662 html("'><img src='"); 662 html("'><img src='");
663 html_attr(ctx->cfg.logo); 663 html_attr(ctx->cfg.logo);
664 html("' alt='cgit logo'/></a></td>\n"); 664 html("' alt='cgit logo'/></a></td>\n");
665 } 665 }
666 666
667 html("<td class='main'>"); 667 html("<td class='main'>");
668 if (ctx->repo) { 668 if (ctx->repo) {
669 cgit_index_link("index", NULL, NULL, NULL, 0); 669 cgit_index_link("index", NULL, NULL, NULL, 0);
670 html(" : "); 670 html(" : ");
671 cgit_summary_link(ctx->repo->name, ctx->repo->name, NULL, NULL); 671 cgit_summary_link(ctx->repo->name, ctx->repo->name, NULL, NULL);
672 html("</td><td class='form'>"); 672 html("</td><td class='form'>");
673 html("<form method='get' action=''>\n"); 673 html("<form method='get' action=''>\n");
674 cgit_add_hidden_formfields(0, 1, ctx->qry.page); 674 cgit_add_hidden_formfields(0, 1, ctx->qry.page);
675 html("<select name='h' onchange='this.form.submit();'>\n"); 675 html("<select name='h' onchange='this.form.submit();'>\n");
676 for_each_branch_ref(print_branch_option, ctx->qry.head); 676 for_each_branch_ref(print_branch_option, ctx->qry.head);
677 html("</select> "); 677 html("</select> ");
678 html("<input type='submit' name='' value='switch'/>"); 678 html("<input type='submit' name='' value='switch'/>");
679 html("</form>"); 679 html("</form>");
680 } else 680 } else
681 html_txt(ctx->cfg.root_title); 681 html_txt(ctx->cfg.root_title);
682 html("</td></tr>\n"); 682 html("</td></tr>\n");
683 683
684 html("<tr><td class='sub'>"); 684 html("<tr><td class='sub'>");
685 if (ctx->repo) { 685 if (ctx->repo) {
686 html_txt(ctx->repo->desc); 686 html_txt(ctx->repo->desc);
687 html("</td><td class='sub right'>"); 687 html("</td><td class='sub right'>");
688 html_txt(ctx->repo->owner); 688 html_txt(ctx->repo->owner);
689 } else { 689 } else {
690 if (ctx->cfg.root_desc) 690 if (ctx->cfg.root_desc)
691 html_txt(ctx->cfg.root_desc); 691 html_txt(ctx->cfg.root_desc);
692 else if (ctx->cfg.index_info) 692 else if (ctx->cfg.index_info)
693 html_include(ctx->cfg.index_info); 693 html_include(ctx->cfg.index_info);
694 } 694 }
695 html("</td></tr></table>\n"); 695 html("</td></tr></table>\n");
696} 696}
697 697
698void cgit_print_pageheader(struct cgit_context *ctx) 698void cgit_print_pageheader(struct cgit_context *ctx)
699{ 699{
700 struct cgit_cmd *cmd = cgit_get_cmd(ctx); 700 struct cgit_cmd *cmd = cgit_get_cmd(ctx);
701 701
702 if (!cmd && ctx->repo) 702 if (!cmd && ctx->repo)
703 fallback_cmd = "summary"; 703 fallback_cmd = "summary";
704 704
705 html("<div id='cgit'>"); 705 html("<div id='cgit'>");
706 if (!ctx->cfg.noheader) 706 if (!ctx->cfg.noheader)
707 print_header(ctx); 707 print_header(ctx);
708 708
709 html("<table class='tabs'><tr><td>\n"); 709 html("<table class='tabs'><tr><td>\n");
710 if (ctx->repo) { 710 if (ctx->repo) {
711 cgit_summary_link("summary", NULL, hc(cmd, "summary"), 711 cgit_summary_link("summary", NULL, hc(cmd, "summary"),
712 ctx->qry.head); 712 ctx->qry.head);
713 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, 713 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head,
714 ctx->qry.sha1, NULL); 714 ctx->qry.sha1, NULL);
715 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, 715 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head,
716 NULL, NULL, 0, NULL, NULL, ctx->qry.showmsg); 716 NULL, NULL, 0, NULL, NULL, ctx->qry.showmsg);
717 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, 717 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head,
718 ctx->qry.sha1, NULL); 718 ctx->qry.sha1, NULL);
719 cgit_commit_link("commit", NULL, hc(cmd, "commit"), 719 cgit_commit_link("commit", NULL, hc(cmd, "commit"),
720 ctx->qry.head, ctx->qry.sha1, 0); 720 ctx->qry.head, ctx->qry.sha1, 0);
721 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, 721 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head,
722 ctx->qry.sha1, ctx->qry.sha2, NULL, 0); 722 ctx->qry.sha1, ctx->qry.sha2, NULL, 0);
723 if (ctx->repo->max_stats) 723 if (ctx->repo->max_stats)
724 cgit_stats_link("stats", NULL, hc(cmd, "stats"), 724 cgit_stats_link("stats", NULL, hc(cmd, "stats"),
725 ctx->qry.head, NULL); 725 ctx->qry.head, NULL);
726 if (ctx->repo->readme) 726 if (ctx->repo->readme)
727 reporevlink("about", "about", NULL, 727 reporevlink("about", "about", NULL,
728 hc(cmd, "about"), ctx->qry.head, NULL, 728 hc(cmd, "about"), ctx->qry.head, NULL,
729 NULL); 729 NULL);
730 html("</td><td class='form'>"); 730 html("</td><td class='form'>");
731 html("<form class='right' method='get' action='"); 731 html("<form class='right' method='get' action='");
732 if (ctx->cfg.virtual_root) 732 if (ctx->cfg.virtual_root)
733 html_url_path(cgit_fileurl(ctx->qry.repo, "log", 733 html_url_path(cgit_fileurl(ctx->qry.repo, "log",
734 ctx->qry.path, NULL)); 734 ctx->qry.path, NULL));
735 html("'>\n"); 735 html("'>\n");
736 cgit_add_hidden_formfields(1, 0, "log"); 736 cgit_add_hidden_formfields(1, 0, "log");
737 html("<select name='qt'>\n"); 737 html("<select name='qt'>\n");
738 html_option("grep", "log msg", ctx->qry.grep); 738 html_option("grep", "log msg", ctx->qry.grep);
739 html_option("author", "author", ctx->qry.grep); 739 html_option("author", "author", ctx->qry.grep);
740 html_option("committer", "committer", ctx->qry.grep); 740 html_option("committer", "committer", ctx->qry.grep);
741 html_option("range", "range", ctx->qry.grep);
741 html("</select>\n"); 742 html("</select>\n");
742 html("<input class='txt' type='text' size='10' name='q' value='"); 743 html("<input class='txt' type='text' size='10' name='q' value='");
743 html_attr(ctx->qry.search); 744 html_attr(ctx->qry.search);
744 html("'/>\n"); 745 html("'/>\n");
745 html("<input type='submit' value='search'/>\n"); 746 html("<input type='submit' value='search'/>\n");
746 html("</form>\n"); 747 html("</form>\n");
747 } else { 748 } else {
748 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); 749 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0);
749 if (ctx->cfg.root_readme) 750 if (ctx->cfg.root_readme)
750 site_link("about", "about", NULL, hc(cmd, "about"), 751 site_link("about", "about", NULL, hc(cmd, "about"),
751 NULL, 0); 752 NULL, 0);
752 html("</td><td class='form'>"); 753 html("</td><td class='form'>");
753 html("<form method='get' action='"); 754 html("<form method='get' action='");
754 html_attr(cgit_rooturl()); 755 html_attr(cgit_rooturl());
755 html("'>\n"); 756 html("'>\n");
756 html("<input type='text' name='q' size='10' value='"); 757 html("<input type='text' name='q' size='10' value='");
757 html_attr(ctx->qry.search); 758 html_attr(ctx->qry.search);
758 html("'/>\n"); 759 html("'/>\n");
759 html("<input type='submit' value='search'/>\n"); 760 html("<input type='submit' value='search'/>\n");
760 html("</form>"); 761 html("</form>");
761 } 762 }
762 html("</td></tr></table>\n"); 763 html("</td></tr></table>\n");
763 html("<div class='content'>"); 764 html("<div class='content'>");
764} 765}
765 766
766void cgit_print_filemode(unsigned short mode) 767void cgit_print_filemode(unsigned short mode)
767{ 768{
768 if (S_ISDIR(mode)) 769 if (S_ISDIR(mode))
769 html("d"); 770 html("d");
770 else if (S_ISLNK(mode)) 771 else if (S_ISLNK(mode))
771 html("l"); 772 html("l");
772 else if (S_ISGITLINK(mode)) 773 else if (S_ISGITLINK(mode))
773 html("m"); 774 html("m");
774 else 775 else
775 html("-"); 776 html("-");
776 html_fileperm(mode >> 6); 777 html_fileperm(mode >> 6);
777 html_fileperm(mode >> 3); 778 html_fileperm(mode >> 3);
778 html_fileperm(mode); 779 html_fileperm(mode);
779} 780}
780 781
781void cgit_print_snapshot_links(const char *repo, const char *head, 782void cgit_print_snapshot_links(const char *repo, const char *head,
782 const char *hex, int snapshots) 783 const char *hex, int snapshots)
783{ 784{
784 const struct cgit_snapshot_format* f; 785 const struct cgit_snapshot_format* f;
785 char *prefix; 786 char *prefix;
786 char *filename; 787 char *filename;
787 unsigned char sha1[20]; 788 unsigned char sha1[20];
788 789
789 if (get_sha1(fmt("refs/tags/%s", hex), sha1) == 0 && 790 if (get_sha1(fmt("refs/tags/%s", hex), sha1) == 0 &&
790 (hex[0] == 'v' || hex[0] == 'V') && isdigit(hex[1])) 791 (hex[0] == 'v' || hex[0] == 'V') && isdigit(hex[1]))
791 hex++; 792 hex++;
792 prefix = xstrdup(fmt("%s-%s", cgit_repobasename(repo), hex)); 793 prefix = xstrdup(fmt("%s-%s", cgit_repobasename(repo), hex));
793 for (f = cgit_snapshot_formats; f->suffix; f++) { 794 for (f = cgit_snapshot_formats; f->suffix; f++) {
794 if (!(snapshots & f->bit)) 795 if (!(snapshots & f->bit))
795 continue; 796 continue;
796 filename = fmt("%s%s", prefix, f->suffix); 797 filename = fmt("%s%s", prefix, f->suffix);
797 cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename); 798 cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename);
798 html("<br/>"); 799 html("<br/>");
799 } 800 }
800} 801}