summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--ui-shared.c6
-rw-r--r--ui-shared.h3
2 files changed, 5 insertions, 4 deletions
diff --git a/ui-shared.c b/ui-shared.c
index a5eb25f..1bb30c2 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -534,49 +534,49 @@ int print_archive_ref(const char *refname, const unsigned char *sha1,
534 return 1; 534 return 1;
535 if (obj->type == OBJ_TAG) { 535 if (obj->type == OBJ_TAG) {
536 tag = lookup_tag(sha1); 536 tag = lookup_tag(sha1);
537 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 537 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
538 return 0; 538 return 0;
539 hashcpy(fileid, tag->tagged->sha1); 539 hashcpy(fileid, tag->tagged->sha1);
540 } else if (obj->type != OBJ_BLOB) { 540 } else if (obj->type != OBJ_BLOB) {
541 return 0; 541 return 0;
542 } else { 542 } else {
543 hashcpy(fileid, sha1); 543 hashcpy(fileid, sha1);
544 } 544 }
545 if (!*header) { 545 if (!*header) {
546 html("<h1>download</h1>\n"); 546 html("<h1>download</h1>\n");
547 *header = 1; 547 *header = 1;
548 } 548 }
549 url = cgit_pageurl(ctx.qry.repo, "blob", 549 url = cgit_pageurl(ctx.qry.repo, "blob",
550 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid), 550 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid),
551 buf)); 551 buf));
552 html_link_open(url, NULL, "menu"); 552 html_link_open(url, NULL, "menu");
553 html_txt(strlpart(buf, 20)); 553 html_txt(strlpart(buf, 20));
554 html_link_close(); 554 html_link_close();
555 return 0; 555 return 0;
556} 556}
557 557
558void add_hidden_formfields(int incl_head, int incl_search, char *page) 558void cgit_add_hidden_formfields(int incl_head, int incl_search, char *page)
559{ 559{
560 char *url; 560 char *url;
561 561
562 if (!ctx.cfg.virtual_root) { 562 if (!ctx.cfg.virtual_root) {
563 url = fmt("%s/%s", ctx.qry.repo, page); 563 url = fmt("%s/%s", ctx.qry.repo, page);
564 if (ctx.qry.path) 564 if (ctx.qry.path)
565 url = fmt("%s/%s", url, ctx.qry.path); 565 url = fmt("%s/%s", url, ctx.qry.path);
566 html_hidden("url", url); 566 html_hidden("url", url);
567 } 567 }
568 568
569 if (incl_head && ctx.qry.head && ctx.repo->defbranch && 569 if (incl_head && ctx.qry.head && ctx.repo->defbranch &&
570 strcmp(ctx.qry.head, ctx.repo->defbranch)) 570 strcmp(ctx.qry.head, ctx.repo->defbranch))
571 html_hidden("h", ctx.qry.head); 571 html_hidden("h", ctx.qry.head);
572 572
573 if (ctx.qry.sha1) 573 if (ctx.qry.sha1)
574 html_hidden("id", ctx.qry.sha1); 574 html_hidden("id", ctx.qry.sha1);
575 if (ctx.qry.sha2) 575 if (ctx.qry.sha2)
576 html_hidden("id2", ctx.qry.sha2); 576 html_hidden("id2", ctx.qry.sha2);
577 577
578 if (incl_search) { 578 if (incl_search) {
579 if (ctx.qry.grep) 579 if (ctx.qry.grep)
580 html_hidden("qt", ctx.qry.grep); 580 html_hidden("qt", ctx.qry.grep);
581 if (ctx.qry.search) 581 if (ctx.qry.search)
582 html_hidden("q", ctx.qry.search); 582 html_hidden("q", ctx.qry.search);
@@ -589,49 +589,49 @@ char *hc(struct cgit_cmd *cmd, const char *page)
589} 589}
590 590
591void cgit_print_pageheader(struct cgit_context *ctx) 591void cgit_print_pageheader(struct cgit_context *ctx)
592{ 592{
593 struct cgit_cmd *cmd = cgit_get_cmd(ctx); 593 struct cgit_cmd *cmd = cgit_get_cmd(ctx);
594 594
595 html("<table id='header'>\n"); 595 html("<table id='header'>\n");
596 html("<tr>\n"); 596 html("<tr>\n");
597 html("<td class='logo' rowspan='2'><a href='"); 597 html("<td class='logo' rowspan='2'><a href='");
598 if (ctx->cfg.logo_link) 598 if (ctx->cfg.logo_link)
599 html_attr(ctx->cfg.logo_link); 599 html_attr(ctx->cfg.logo_link);
600 else 600 else
601 html_attr(cgit_rooturl()); 601 html_attr(cgit_rooturl());
602 html("'><img src='"); 602 html("'><img src='");
603 html_attr(ctx->cfg.logo); 603 html_attr(ctx->cfg.logo);
604 html("' alt='cgit logo'/></a></td>\n"); 604 html("' alt='cgit logo'/></a></td>\n");
605 605
606 html("<td class='main'>"); 606 html("<td class='main'>");
607 if (ctx->repo) { 607 if (ctx->repo) {
608 cgit_index_link("index", NULL, NULL, NULL, 0); 608 cgit_index_link("index", NULL, NULL, NULL, 0);
609 html(" : "); 609 html(" : ");
610 cgit_summary_link(ctx->repo->name, ctx->repo->name, NULL, NULL); 610 cgit_summary_link(ctx->repo->name, ctx->repo->name, NULL, NULL);
611 html("</td><td class='form'>"); 611 html("</td><td class='form'>");
612 html("<form method='get' action=''>\n"); 612 html("<form method='get' action=''>\n");
613 add_hidden_formfields(0, 1, ctx->qry.page); 613 cgit_add_hidden_formfields(0, 1, ctx->qry.page);
614 html("<select name='h' onchange='this.form.submit();'>\n"); 614 html("<select name='h' onchange='this.form.submit();'>\n");
615 for_each_branch_ref(print_branch_option, ctx->qry.head); 615 for_each_branch_ref(print_branch_option, ctx->qry.head);
616 html("</select> "); 616 html("</select> ");
617 html("<input type='submit' name='' value='switch'/>"); 617 html("<input type='submit' name='' value='switch'/>");
618 html("</form>"); 618 html("</form>");
619 } else 619 } else
620 html_txt(ctx->cfg.root_title); 620 html_txt(ctx->cfg.root_title);
621 html("</td></tr>\n"); 621 html("</td></tr>\n");
622 622
623 html("<tr><td class='sub'>"); 623 html("<tr><td class='sub'>");
624 if (ctx->repo) { 624 if (ctx->repo) {
625 html_txt(ctx->repo->desc); 625 html_txt(ctx->repo->desc);
626 html("</td><td class='sub right'>"); 626 html("</td><td class='sub right'>");
627 html_txt(ctx->repo->owner); 627 html_txt(ctx->repo->owner);
628 } else { 628 } else {
629 if (ctx->cfg.root_desc) 629 if (ctx->cfg.root_desc)
630 html_txt(ctx->cfg.root_desc); 630 html_txt(ctx->cfg.root_desc);
631 else if (ctx->cfg.index_info) 631 else if (ctx->cfg.index_info)
632 html_include(ctx->cfg.index_info); 632 html_include(ctx->cfg.index_info);
633 } 633 }
634 html("</td></tr></table>\n"); 634 html("</td></tr></table>\n");
635 635
636 html("<table class='tabs'><tr><td>\n"); 636 html("<table class='tabs'><tr><td>\n");
637 if (ctx->repo) { 637 if (ctx->repo) {
@@ -639,49 +639,49 @@ void cgit_print_pageheader(struct cgit_context *ctx)
639 ctx->qry.head); 639 ctx->qry.head);
640 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, 640 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head,
641 ctx->qry.sha1, NULL); 641 ctx->qry.sha1, NULL);
642 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, 642 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head,
643 NULL, NULL, 0, NULL, NULL); 643 NULL, NULL, 0, NULL, NULL);
644 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, 644 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head,
645 ctx->qry.sha1, NULL); 645 ctx->qry.sha1, NULL);
646 cgit_commit_link("commit", NULL, hc(cmd, "commit"), 646 cgit_commit_link("commit", NULL, hc(cmd, "commit"),
647 ctx->qry.head, ctx->qry.sha1); 647 ctx->qry.head, ctx->qry.sha1);
648 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, 648 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head,
649 ctx->qry.sha1, ctx->qry.sha2, NULL); 649 ctx->qry.sha1, ctx->qry.sha2, NULL);
650 if (ctx->repo->max_stats) 650 if (ctx->repo->max_stats)
651 cgit_stats_link("stats", NULL, hc(cmd, "stats"), 651 cgit_stats_link("stats", NULL, hc(cmd, "stats"),
652 ctx->qry.head, NULL); 652 ctx->qry.head, NULL);
653 if (ctx->repo->readme) 653 if (ctx->repo->readme)
654 reporevlink("about", "about", NULL, 654 reporevlink("about", "about", NULL,
655 hc(cmd, "about"), ctx->qry.head, NULL, 655 hc(cmd, "about"), ctx->qry.head, NULL,
656 NULL); 656 NULL);
657 html("</td><td class='form'>"); 657 html("</td><td class='form'>");
658 html("<form class='right' method='get' action='"); 658 html("<form class='right' method='get' action='");
659 if (ctx->cfg.virtual_root) 659 if (ctx->cfg.virtual_root)
660 html_url_path(cgit_fileurl(ctx->qry.repo, "log", 660 html_url_path(cgit_fileurl(ctx->qry.repo, "log",
661 ctx->qry.path, NULL)); 661 ctx->qry.path, NULL));
662 html("'>\n"); 662 html("'>\n");
663 add_hidden_formfields(1, 0, "log"); 663 cgit_add_hidden_formfields(1, 0, "log");
664 html("<select name='qt'>\n"); 664 html("<select name='qt'>\n");
665 html_option("grep", "log msg", ctx->qry.grep); 665 html_option("grep", "log msg", ctx->qry.grep);
666 html_option("author", "author", ctx->qry.grep); 666 html_option("author", "author", ctx->qry.grep);
667 html_option("committer", "committer", ctx->qry.grep); 667 html_option("committer", "committer", ctx->qry.grep);
668 html("</select>\n"); 668 html("</select>\n");
669 html("<input class='txt' type='text' size='10' name='q' value='"); 669 html("<input class='txt' type='text' size='10' name='q' value='");
670 html_attr(ctx->qry.search); 670 html_attr(ctx->qry.search);
671 html("'/>\n"); 671 html("'/>\n");
672 html("<input type='submit' value='search'/>\n"); 672 html("<input type='submit' value='search'/>\n");
673 html("</form>\n"); 673 html("</form>\n");
674 } else { 674 } else {
675 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); 675 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0);
676 if (ctx->cfg.root_readme) 676 if (ctx->cfg.root_readme)
677 site_link("about", "about", NULL, hc(cmd, "about"), 677 site_link("about", "about", NULL, hc(cmd, "about"),
678 NULL, 0); 678 NULL, 0);
679 html("</td><td class='form'>"); 679 html("</td><td class='form'>");
680 html("<form method='get' action='"); 680 html("<form method='get' action='");
681 html_attr(cgit_rooturl()); 681 html_attr(cgit_rooturl());
682 html("'>\n"); 682 html("'>\n");
683 html("<input type='text' name='q' size='10' value='"); 683 html("<input type='text' name='q' size='10' value='");
684 html_attr(ctx->qry.search); 684 html_attr(ctx->qry.search);
685 html("'/>\n"); 685 html("'/>\n");
686 html("<input type='submit' value='search'/>\n"); 686 html("<input type='submit' value='search'/>\n");
687 html("</form>"); 687 html("</form>");
diff --git a/ui-shared.h b/ui-shared.h
index e3fae64..1524dc3 100644
--- a/ui-shared.h
+++ b/ui-shared.h
@@ -23,26 +23,27 @@ extern void cgit_log_link(char *name, char *title, char *class, char *head,
23extern void cgit_commit_link(char *name, char *title, char *class, char *head, 23extern void cgit_commit_link(char *name, char *title, char *class, char *head,
24 char *rev); 24 char *rev);
25extern void cgit_patch_link(char *name, char *title, char *class, char *head, 25extern void cgit_patch_link(char *name, char *title, char *class, char *head,
26 char *rev); 26 char *rev);
27extern void cgit_refs_link(char *name, char *title, char *class, char *head, 27extern void cgit_refs_link(char *name, char *title, char *class, char *head,
28 char *rev, char *path); 28 char *rev, char *path);
29extern void cgit_snapshot_link(char *name, char *title, char *class, 29extern void cgit_snapshot_link(char *name, char *title, char *class,
30 char *head, char *rev, char *archivename); 30 char *head, char *rev, char *archivename);
31extern void cgit_diff_link(char *name, char *title, char *class, char *head, 31extern void cgit_diff_link(char *name, char *title, char *class, char *head,
32 char *new_rev, char *old_rev, char *path); 32 char *new_rev, char *old_rev, char *path);
33extern void cgit_stats_link(char *name, char *title, char *class, char *head, 33extern void cgit_stats_link(char *name, char *title, char *class, char *head,
34 char *path); 34 char *path);
35extern void cgit_object_link(struct object *obj); 35extern void cgit_object_link(struct object *obj);
36 36
37extern void cgit_print_error(char *msg); 37extern void cgit_print_error(char *msg);
38extern void cgit_print_date(time_t secs, char *format, int local_time); 38extern void cgit_print_date(time_t secs, char *format, int local_time);
39extern void cgit_print_age(time_t t, time_t max_relative, char *format); 39extern void cgit_print_age(time_t t, time_t max_relative, char *format);
40extern void cgit_print_http_headers(struct cgit_context *ctx); 40extern void cgit_print_http_headers(struct cgit_context *ctx);
41extern void cgit_print_docstart(struct cgit_context *ctx); 41extern void cgit_print_docstart(struct cgit_context *ctx);
42extern void cgit_print_docend(); 42extern void cgit_print_docend();
43extern void cgit_print_pageheader(struct cgit_context *ctx); 43extern void cgit_print_pageheader(struct cgit_context *ctx);
44extern void cgit_print_filemode(unsigned short mode); 44extern void cgit_print_filemode(unsigned short mode);
45extern void cgit_print_snapshot_links(const char *repo, const char *head, 45extern void cgit_print_snapshot_links(const char *repo, const char *head,
46 const char *hex, int snapshots); 46 const char *hex, int snapshots);
47 47extern void cgit_add_hidden_formfields(int incl_head, int incl_search,
48 char *page);
48#endif /* UI_SHARED_H */ 49#endif /* UI_SHARED_H */