summaryrefslogtreecommitdiffabout
path: root/ui-shared.c
Unidiff
Diffstat (limited to 'ui-shared.c') (more/less context) (show whitespace changes)
-rw-r--r--ui-shared.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/ui-shared.c b/ui-shared.c
index 95dfeb4..fba1ba6 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -558,73 +558,78 @@ int print_archive_ref(const char *refname, const unsigned char *sha1,
558} 558}
559 559
560void add_hidden_formfields(int incl_head, int incl_search, char *page) 560void add_hidden_formfields(int incl_head, int incl_search, char *page)
561{ 561{
562 char *url; 562 char *url;
563 563
564 if (!ctx.cfg.virtual_root) { 564 if (!ctx.cfg.virtual_root) {
565 url = fmt("%s/%s", ctx.qry.repo, page); 565 url = fmt("%s/%s", ctx.qry.repo, page);
566 if (ctx.qry.path) 566 if (ctx.qry.path)
567 url = fmt("%s/%s", url, ctx.qry.path); 567 url = fmt("%s/%s", url, ctx.qry.path);
568 html_hidden("url", url); 568 html_hidden("url", url);
569 } 569 }
570 570
571 if (incl_head && ctx.qry.head && ctx.repo->defbranch && 571 if (incl_head && ctx.qry.head && ctx.repo->defbranch &&
572 strcmp(ctx.qry.head, ctx.repo->defbranch)) 572 strcmp(ctx.qry.head, ctx.repo->defbranch))
573 html_hidden("h", ctx.qry.head); 573 html_hidden("h", ctx.qry.head);
574 574
575 if (ctx.qry.sha1) 575 if (ctx.qry.sha1)
576 html_hidden("id", ctx.qry.sha1); 576 html_hidden("id", ctx.qry.sha1);
577 if (ctx.qry.sha2) 577 if (ctx.qry.sha2)
578 html_hidden("id2", ctx.qry.sha2); 578 html_hidden("id2", ctx.qry.sha2);
579 if (ctx.qry.showmsg) 579 if (ctx.qry.showmsg)
580 html_hidden("showmsg", "1"); 580 html_hidden("showmsg", "1");
581 581
582 if (incl_search) { 582 if (incl_search) {
583 if (ctx.qry.grep) 583 if (ctx.qry.grep)
584 html_hidden("qt", ctx.qry.grep); 584 html_hidden("qt", ctx.qry.grep);
585 if (ctx.qry.search) 585 if (ctx.qry.search)
586 html_hidden("q", ctx.qry.search); 586 html_hidden("q", ctx.qry.search);
587 } 587 }
588} 588}
589 589
590const char *fallback_cmd = "repolist";
591
590char *hc(struct cgit_cmd *cmd, const char *page) 592char *hc(struct cgit_cmd *cmd, const char *page)
591{ 593{
592 return (strcmp(cmd->name, page) ? NULL : "active"); 594 return (strcmp(cmd ? cmd->name : fallback_cmd, page) ? NULL : "active");
593} 595}
594 596
595void cgit_print_pageheader(struct cgit_context *ctx) 597void cgit_print_pageheader(struct cgit_context *ctx)
596{ 598{
597 struct cgit_cmd *cmd = cgit_get_cmd(ctx); 599 struct cgit_cmd *cmd = cgit_get_cmd(ctx);
598 600
601 if (!cmd && ctx->repo)
602 fallback_cmd = "summary";
603
599 html("<table id='header'>\n"); 604 html("<table id='header'>\n");
600 html("<tr>\n"); 605 html("<tr>\n");
601 html("<td class='logo' rowspan='2'><a href='"); 606 html("<td class='logo' rowspan='2'><a href='");
602 if (ctx->cfg.logo_link) 607 if (ctx->cfg.logo_link)
603 html_attr(ctx->cfg.logo_link); 608 html_attr(ctx->cfg.logo_link);
604 else 609 else
605 html_attr(cgit_rooturl()); 610 html_attr(cgit_rooturl());
606 html("'><img src='"); 611 html("'><img src='");
607 html_attr(ctx->cfg.logo); 612 html_attr(ctx->cfg.logo);
608 html("' alt='cgit logo'/></a></td>\n"); 613 html("' alt='cgit logo'/></a></td>\n");
609 614
610 html("<td class='main'>"); 615 html("<td class='main'>");
611 if (ctx->repo) { 616 if (ctx->repo) {
612 cgit_index_link("index", NULL, NULL, NULL, 0); 617 cgit_index_link("index", NULL, NULL, NULL, 0);
613 html(" : "); 618 html(" : ");
614 cgit_summary_link(ctx->repo->name, ctx->repo->name, NULL, NULL); 619 cgit_summary_link(ctx->repo->name, ctx->repo->name, NULL, NULL);
615 html("</td><td class='form'>"); 620 html("</td><td class='form'>");
616 html("<form method='get' action=''>\n"); 621 html("<form method='get' action=''>\n");
617 add_hidden_formfields(0, 1, ctx->qry.page); 622 add_hidden_formfields(0, 1, ctx->qry.page);
618 html("<select name='h' onchange='this.form.submit();'>\n"); 623 html("<select name='h' onchange='this.form.submit();'>\n");
619 for_each_branch_ref(print_branch_option, ctx->qry.head); 624 for_each_branch_ref(print_branch_option, ctx->qry.head);
620 html("</select> "); 625 html("</select> ");
621 html("<input type='submit' name='' value='switch'/>"); 626 html("<input type='submit' name='' value='switch'/>");
622 html("</form>"); 627 html("</form>");
623 } else 628 } else
624 html_txt(ctx->cfg.root_title); 629 html_txt(ctx->cfg.root_title);
625 html("</td></tr>\n"); 630 html("</td></tr>\n");
626 631
627 html("<tr><td class='sub'>"); 632 html("<tr><td class='sub'>");
628 if (ctx->repo) { 633 if (ctx->repo) {
629 html_txt(ctx->repo->desc); 634 html_txt(ctx->repo->desc);
630 html("</td><td class='sub right'>"); 635 html("</td><td class='sub right'>");