summaryrefslogtreecommitdiffabout
path: root/ui-shared.c
Unidiff
Diffstat (limited to 'ui-shared.c') (more/less context) (ignore whitespace changes)
-rw-r--r--ui-shared.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/ui-shared.c b/ui-shared.c
index 03d147f..73e3d4c 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -457,104 +457,111 @@ void add_hidden_formfields(int incl_head, int incl_search, char *page)
457 html_hidden("id", ctx.qry.sha1); 457 html_hidden("id", ctx.qry.sha1);
458 if (ctx.qry.sha2) 458 if (ctx.qry.sha2)
459 html_hidden("id2", ctx.qry.sha2); 459 html_hidden("id2", ctx.qry.sha2);
460 460
461 if (incl_search) { 461 if (incl_search) {
462 if (ctx.qry.grep) 462 if (ctx.qry.grep)
463 html_hidden("qt", ctx.qry.grep); 463 html_hidden("qt", ctx.qry.grep);
464 if (ctx.qry.search) 464 if (ctx.qry.search)
465 html_hidden("q", ctx.qry.search); 465 html_hidden("q", ctx.qry.search);
466 } 466 }
467} 467}
468 468
469char *hc(struct cgit_cmd *cmd, const char *page) 469char *hc(struct cgit_cmd *cmd, const char *page)
470{ 470{
471 return (strcmp(cmd->name, page) ? NULL : "active"); 471 return (strcmp(cmd->name, page) ? NULL : "active");
472} 472}
473 473
474void cgit_print_pageheader(struct cgit_context *ctx) 474void cgit_print_pageheader(struct cgit_context *ctx)
475{ 475{
476 struct cgit_cmd *cmd = cgit_get_cmd(ctx); 476 struct cgit_cmd *cmd = cgit_get_cmd(ctx);
477 477
478 html("<table id='header'>\n"); 478 html("<table id='header'>\n");
479 html("<tr>\n"); 479 html("<tr>\n");
480 html("<td class='logo' rowspan='2'><a href='"); 480 html("<td class='logo' rowspan='2'><a href='");
481 if (ctx->cfg.logo_link) 481 if (ctx->cfg.logo_link)
482 html_attr(ctx->cfg.logo_link); 482 html_attr(ctx->cfg.logo_link);
483 else 483 else
484 html_attr(cgit_rooturl()); 484 html_attr(cgit_rooturl());
485 html("'><img src='"); 485 html("'><img src='");
486 html_attr(ctx->cfg.logo); 486 html_attr(ctx->cfg.logo);
487 html("'/></a></td>\n"); 487 html("'/></a></td>\n");
488 html("<td class='main'>"); 488 html("<td class='main'>");
489 if (ctx->repo) { 489 if (ctx->repo) {
490 html("<a href='"); 490 html("<a href='");
491 html_attr(cgit_rooturl()); 491 html_attr(cgit_rooturl());
492 html("'>index</a> / "); 492 html("'>index</a> / ");
493 html_txt(ctx->repo->name); 493 html_txt(ctx->repo->name);
494 } else 494 } else
495 html_txt(ctx->cfg.root_title); 495 html_txt(ctx->cfg.root_title);
496 html("</td></tr>\n"); 496 html("</td></tr>\n");
497 html("<tr><td class='sub'>"); 497 html("<tr><td class='sub'>");
498 if (ctx->repo) 498 if (ctx->repo)
499 html_txt(ctx->repo->desc); 499 html_txt(ctx->repo->desc);
500 else 500 else
501 html_txt(ctx->cfg.index_info); 501 html_txt(ctx->cfg.index_info);
502 html("</td></tr>\n"); 502 html("</td></tr>\n");
503 html("</table>\n"); 503 html("</table>\n");
504 504
505 html("<table class='tabs'><tr><td>\n"); 505 html("<table class='tabs'><tr><td>\n");
506 if (ctx->repo) { 506 if (ctx->repo) {
507 reporevlink(NULL, "summary", NULL, hc(cmd, "summary"), 507 reporevlink(NULL, "summary", NULL, hc(cmd, "summary"),
508 ctx->qry.head, NULL, NULL); 508 ctx->qry.head, NULL, NULL);
509 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, 509 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head,
510 ctx->qry.sha1, NULL); 510 ctx->qry.sha1, NULL);
511 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, 511 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head,
512 NULL, NULL, 0, NULL, NULL); 512 NULL, NULL, 0, NULL, NULL);
513 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, 513 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head,
514 ctx->qry.sha1, NULL); 514 ctx->qry.sha1, NULL);
515 cgit_commit_link("commit", NULL, hc(cmd, "commit"), 515 cgit_commit_link("commit", NULL, hc(cmd, "commit"),
516 ctx->qry.head, ctx->qry.sha1); 516 ctx->qry.head, ctx->qry.sha1);
517 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, 517 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head,
518 ctx->qry.sha1, ctx->qry.sha2, NULL); 518 ctx->qry.sha1, ctx->qry.sha2, NULL);
519 cgit_patch_link("patch", NULL, hc(cmd, "patch"), ctx->qry.head, 519 cgit_patch_link("patch", NULL, hc(cmd, "patch"), ctx->qry.head,
520 ctx->qry.sha1); 520 ctx->qry.sha1);
521 html("</td><td class='branch'>");
522 html("<form method='get' action=''>\n");
523 add_hidden_formfields(0, 1, ctx->qry.page);
524 html("<select name='h' onchange='this.form.submit();'>\n");
525 for_each_branch_ref(print_branch_option, ctx->qry.head);
526 html("</select> ");
527 html("<input type='submit' name='' value='switch'/>");
521 } else { 528 } else {
522 html("<a class='active' href='"); 529 html("<a class='active' href='");
523 html_attr(cgit_rooturl()); 530 html_attr(cgit_rooturl());
524 html("'>index</a>\n"); 531 html("'>index</a>\n");
525 } 532 }
526 html("</td></tr></table>\n"); 533 html("</td></tr></table>\n");
527 html("<div class='content'>"); 534 html("<div class='content'>");
528} 535}
529 536
530void cgit_print_filemode(unsigned short mode) 537void cgit_print_filemode(unsigned short mode)
531{ 538{
532 if (S_ISDIR(mode)) 539 if (S_ISDIR(mode))
533 html("d"); 540 html("d");
534 else if (S_ISLNK(mode)) 541 else if (S_ISLNK(mode))
535 html("l"); 542 html("l");
536 else if (S_ISGITLINK(mode)) 543 else if (S_ISGITLINK(mode))
537 html("m"); 544 html("m");
538 else 545 else
539 html("-"); 546 html("-");
540 html_fileperm(mode >> 6); 547 html_fileperm(mode >> 6);
541 html_fileperm(mode >> 3); 548 html_fileperm(mode >> 3);
542 html_fileperm(mode); 549 html_fileperm(mode);
543} 550}
544 551
545void cgit_print_snapshot_links(const char *repo, const char *head, 552void cgit_print_snapshot_links(const char *repo, const char *head,
546 const char *hex, int snapshots) 553 const char *hex, int snapshots)
547{ 554{
548 const struct cgit_snapshot_format* f; 555 const struct cgit_snapshot_format* f;
549 char *filename; 556 char *filename;
550 557
551 for (f = cgit_snapshot_formats; f->suffix; f++) { 558 for (f = cgit_snapshot_formats; f->suffix; f++) {
552 if (!(snapshots & f->bit)) 559 if (!(snapshots & f->bit))
553 continue; 560 continue;
554 filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, 561 filename = fmt("%s-%s%s", cgit_repobasename(repo), hex,
555 f->suffix); 562 f->suffix);
556 cgit_snapshot_link(filename, NULL, NULL, (char *)head, 563 cgit_snapshot_link(filename, NULL, NULL, (char *)head,
557 (char *)hex, filename); 564 (char *)hex, filename);
558 html("<br/>"); 565 html("<br/>");
559 } 566 }
560} 567}