summaryrefslogtreecommitdiffabout
path: root/ui-shared.c
authorLars Hjemli <hjemli@gmail.com>2008-05-03 10:44:20 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-05-04 15:30:02 (UTC)
commit17890d0058c1555133c8767ceb123e809e6971ab (patch) (unidiff)
treee20eac18444fd75f6e25f03b6622245ca848d0d6 /ui-shared.c
parentaa3c4486b41b8b13d0f52477f033837fc8bb9524 (diff)
downloadcgit-17890d0058c1555133c8767ceb123e809e6971ab.zip
cgit-17890d0058c1555133c8767ceb123e809e6971ab.tar.gz
cgit-17890d0058c1555133c8767ceb123e809e6971ab.tar.bz2
Add link to index page from repo header, remove page name
This makes it more obvious how to get back to the index, especially when the config option `logo-link` is used. And the page name displayed in the header provided no extra information. It only consumed space and deserved to die. While at it, make sure that the different parts of the header doesn't wrap when horizontal space is limited. 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.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/ui-shared.c b/ui-shared.c
index 44269a7..cd98387 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -356,306 +356,306 @@ void cgit_object_link(struct object *obj)
356void cgit_print_date(time_t secs, char *format) 356void cgit_print_date(time_t secs, char *format)
357{ 357{
358 char buf[64]; 358 char buf[64];
359 struct tm *time; 359 struct tm *time;
360 360
361 if (!secs) 361 if (!secs)
362 return; 362 return;
363 time = gmtime(&secs); 363 time = gmtime(&secs);
364 strftime(buf, sizeof(buf)-1, format, time); 364 strftime(buf, sizeof(buf)-1, format, time);
365 html_txt(buf); 365 html_txt(buf);
366} 366}
367 367
368void cgit_print_age(time_t t, time_t max_relative, char *format) 368void cgit_print_age(time_t t, time_t max_relative, char *format)
369{ 369{
370 time_t now, secs; 370 time_t now, secs;
371 371
372 if (!t) 372 if (!t)
373 return; 373 return;
374 time(&now); 374 time(&now);
375 secs = now - t; 375 secs = now - t;
376 376
377 if (secs > max_relative && max_relative >= 0) { 377 if (secs > max_relative && max_relative >= 0) {
378 cgit_print_date(t, format); 378 cgit_print_date(t, format);
379 return; 379 return;
380 } 380 }
381 381
382 if (secs < TM_HOUR * 2) { 382 if (secs < TM_HOUR * 2) {
383 htmlf("<span class='age-mins'>%.0f min.</span>", 383 htmlf("<span class='age-mins'>%.0f min.</span>",
384 secs * 1.0 / TM_MIN); 384 secs * 1.0 / TM_MIN);
385 return; 385 return;
386 } 386 }
387 if (secs < TM_DAY * 2) { 387 if (secs < TM_DAY * 2) {
388 htmlf("<span class='age-hours'>%.0f hours</span>", 388 htmlf("<span class='age-hours'>%.0f hours</span>",
389 secs * 1.0 / TM_HOUR); 389 secs * 1.0 / TM_HOUR);
390 return; 390 return;
391 } 391 }
392 if (secs < TM_WEEK * 2) { 392 if (secs < TM_WEEK * 2) {
393 htmlf("<span class='age-days'>%.0f days</span>", 393 htmlf("<span class='age-days'>%.0f days</span>",
394 secs * 1.0 / TM_DAY); 394 secs * 1.0 / TM_DAY);
395 return; 395 return;
396 } 396 }
397 if (secs < TM_MONTH * 2) { 397 if (secs < TM_MONTH * 2) {
398 htmlf("<span class='age-weeks'>%.0f weeks</span>", 398 htmlf("<span class='age-weeks'>%.0f weeks</span>",
399 secs * 1.0 / TM_WEEK); 399 secs * 1.0 / TM_WEEK);
400 return; 400 return;
401 } 401 }
402 if (secs < TM_YEAR * 2) { 402 if (secs < TM_YEAR * 2) {
403 htmlf("<span class='age-months'>%.0f months</span>", 403 htmlf("<span class='age-months'>%.0f months</span>",
404 secs * 1.0 / TM_MONTH); 404 secs * 1.0 / TM_MONTH);
405 return; 405 return;
406 } 406 }
407 htmlf("<span class='age-years'>%.0f years</span>", 407 htmlf("<span class='age-years'>%.0f years</span>",
408 secs * 1.0 / TM_YEAR); 408 secs * 1.0 / TM_YEAR);
409} 409}
410 410
411void cgit_print_http_headers(struct cgit_context *ctx) 411void cgit_print_http_headers(struct cgit_context *ctx)
412{ 412{
413 if (ctx->page.mimetype && ctx->page.charset) 413 if (ctx->page.mimetype && ctx->page.charset)
414 htmlf("Content-Type: %s; charset=%s\n", ctx->page.mimetype, 414 htmlf("Content-Type: %s; charset=%s\n", ctx->page.mimetype,
415 ctx->page.charset); 415 ctx->page.charset);
416 else if (ctx->page.mimetype) 416 else if (ctx->page.mimetype)
417 htmlf("Content-Type: %s\n", ctx->page.mimetype); 417 htmlf("Content-Type: %s\n", ctx->page.mimetype);
418 if (ctx->page.filename) 418 if (ctx->page.filename)
419 htmlf("Content-Disposition: inline; filename=\"%s\"\n", 419 htmlf("Content-Disposition: inline; filename=\"%s\"\n",
420 ctx->page.filename); 420 ctx->page.filename);
421 htmlf("Last-Modified: %s\n", http_date(ctx->page.modified)); 421 htmlf("Last-Modified: %s\n", http_date(ctx->page.modified));
422 htmlf("Expires: %s\n", http_date(ctx->page.expires)); 422 htmlf("Expires: %s\n", http_date(ctx->page.expires));
423 html("\n"); 423 html("\n");
424} 424}
425 425
426void cgit_print_docstart(struct cgit_context *ctx) 426void cgit_print_docstart(struct cgit_context *ctx)
427{ 427{
428 html(cgit_doctype); 428 html(cgit_doctype);
429 html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); 429 html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n");
430 html("<head>\n"); 430 html("<head>\n");
431 html("<title>"); 431 html("<title>");
432 html_txt(ctx->page.title); 432 html_txt(ctx->page.title);
433 html("</title>\n"); 433 html("</title>\n");
434 htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version); 434 htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version);
435 if (ctx->cfg.robots && *ctx->cfg.robots) 435 if (ctx->cfg.robots && *ctx->cfg.robots)
436 htmlf("<meta name='robots' content='%s'/>\n", ctx->cfg.robots); 436 htmlf("<meta name='robots' content='%s'/>\n", ctx->cfg.robots);
437 html("<link rel='stylesheet' type='text/css' href='"); 437 html("<link rel='stylesheet' type='text/css' href='");
438 html_attr(ctx->cfg.css); 438 html_attr(ctx->cfg.css);
439 html("'/>\n"); 439 html("'/>\n");
440 html("</head>\n"); 440 html("</head>\n");
441 html("<body>\n"); 441 html("<body>\n");
442} 442}
443 443
444void cgit_print_docend() 444void cgit_print_docend()
445{ 445{
446 html("</div><div class='footer'>generated "); 446 html("</div><div class='footer'>generated ");
447 cgit_print_date(time(NULL), FMT_LONGDATE); 447 cgit_print_date(time(NULL), FMT_LONGDATE);
448 htmlf(" by cgit %s", cgit_version); 448 htmlf(" by cgit %s", cgit_version);
449 html("</div>\n</body>\n</html>\n"); 449 html("</div>\n</body>\n</html>\n");
450} 450}
451 451
452int print_branch_option(const char *refname, const unsigned char *sha1, 452int print_branch_option(const char *refname, const unsigned char *sha1,
453 int flags, void *cb_data) 453 int flags, void *cb_data)
454{ 454{
455 char *name = (char *)refname; 455 char *name = (char *)refname;
456 html_option(name, name, ctx.qry.head); 456 html_option(name, name, ctx.qry.head);
457 return 0; 457 return 0;
458} 458}
459 459
460int print_archive_ref(const char *refname, const unsigned char *sha1, 460int print_archive_ref(const char *refname, const unsigned char *sha1,
461 int flags, void *cb_data) 461 int flags, void *cb_data)
462{ 462{
463 struct tag *tag; 463 struct tag *tag;
464 struct taginfo *info; 464 struct taginfo *info;
465 struct object *obj; 465 struct object *obj;
466 char buf[256], *url; 466 char buf[256], *url;
467 unsigned char fileid[20]; 467 unsigned char fileid[20];
468 int *header = (int *)cb_data; 468 int *header = (int *)cb_data;
469 469
470 if (prefixcmp(refname, "refs/archives")) 470 if (prefixcmp(refname, "refs/archives"))
471 return 0; 471 return 0;
472 strncpy(buf, refname+14, sizeof(buf)); 472 strncpy(buf, refname+14, sizeof(buf));
473 obj = parse_object(sha1); 473 obj = parse_object(sha1);
474 if (!obj) 474 if (!obj)
475 return 1; 475 return 1;
476 if (obj->type == OBJ_TAG) { 476 if (obj->type == OBJ_TAG) {
477 tag = lookup_tag(sha1); 477 tag = lookup_tag(sha1);
478 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 478 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
479 return 0; 479 return 0;
480 hashcpy(fileid, tag->tagged->sha1); 480 hashcpy(fileid, tag->tagged->sha1);
481 } else if (obj->type != OBJ_BLOB) { 481 } else if (obj->type != OBJ_BLOB) {
482 return 0; 482 return 0;
483 } else { 483 } else {
484 hashcpy(fileid, sha1); 484 hashcpy(fileid, sha1);
485 } 485 }
486 if (!*header) { 486 if (!*header) {
487 html("<h1>download</h1>\n"); 487 html("<h1>download</h1>\n");
488 *header = 1; 488 *header = 1;
489 } 489 }
490 url = cgit_pageurl(ctx.qry.repo, "blob", 490 url = cgit_pageurl(ctx.qry.repo, "blob",
491 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid), 491 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid),
492 buf)); 492 buf));
493 html_link_open(url, NULL, "menu"); 493 html_link_open(url, NULL, "menu");
494 html_txt(strlpart(buf, 20)); 494 html_txt(strlpart(buf, 20));
495 html_link_close(); 495 html_link_close();
496 return 0; 496 return 0;
497} 497}
498 498
499void add_hidden_formfields(int incl_head, int incl_search, char *page) 499void add_hidden_formfields(int incl_head, int incl_search, char *page)
500{ 500{
501 char *url; 501 char *url;
502 502
503 if (!ctx.cfg.virtual_root) { 503 if (!ctx.cfg.virtual_root) {
504 url = fmt("%s/%s", ctx.qry.repo, page); 504 url = fmt("%s/%s", ctx.qry.repo, page);
505 if (ctx.qry.path) 505 if (ctx.qry.path)
506 url = fmt("%s/%s", url, ctx.qry.path); 506 url = fmt("%s/%s", url, ctx.qry.path);
507 html_hidden("url", url); 507 html_hidden("url", url);
508 } 508 }
509 509
510 if (incl_head && strcmp(ctx.qry.head, ctx.repo->defbranch)) 510 if (incl_head && strcmp(ctx.qry.head, ctx.repo->defbranch))
511 html_hidden("h", ctx.qry.head); 511 html_hidden("h", ctx.qry.head);
512 512
513 if (ctx.qry.sha1) 513 if (ctx.qry.sha1)
514 html_hidden("id", ctx.qry.sha1); 514 html_hidden("id", ctx.qry.sha1);
515 if (ctx.qry.sha2) 515 if (ctx.qry.sha2)
516 html_hidden("id2", ctx.qry.sha2); 516 html_hidden("id2", ctx.qry.sha2);
517 517
518 if (incl_search) { 518 if (incl_search) {
519 if (ctx.qry.grep) 519 if (ctx.qry.grep)
520 html_hidden("qt", ctx.qry.grep); 520 html_hidden("qt", ctx.qry.grep);
521 if (ctx.qry.search) 521 if (ctx.qry.search)
522 html_hidden("q", ctx.qry.search); 522 html_hidden("q", ctx.qry.search);
523 } 523 }
524} 524}
525 525
526char *hc(struct cgit_cmd *cmd, const char *page) 526char *hc(struct cgit_cmd *cmd, const char *page)
527{ 527{
528 return (strcmp(cmd->name, page) ? NULL : "active"); 528 return (strcmp(cmd->name, page) ? NULL : "active");
529} 529}
530 530
531void cgit_print_pageheader(struct cgit_context *ctx) 531void cgit_print_pageheader(struct cgit_context *ctx)
532{ 532{
533 struct cgit_cmd *cmd = cgit_get_cmd(ctx); 533 struct cgit_cmd *cmd = cgit_get_cmd(ctx);
534 534
535 html("<table id='header'>\n"); 535 html("<table id='header'>\n");
536 html("<tr>\n"); 536 html("<tr>\n");
537 html("<td class='logo' rowspan='2'><a href='"); 537 html("<td class='logo' rowspan='2'><a href='");
538 if (ctx->cfg.logo_link) 538 if (ctx->cfg.logo_link)
539 html_attr(ctx->cfg.logo_link); 539 html_attr(ctx->cfg.logo_link);
540 else 540 else
541 html_attr(cgit_rooturl()); 541 html_attr(cgit_rooturl());
542 html("'><img src='"); 542 html("'><img src='");
543 html_attr(ctx->cfg.logo); 543 html_attr(ctx->cfg.logo);
544 html("' alt='cgit logo'/></a></td>\n"); 544 html("' alt='cgit logo'/></a></td>\n");
545 545
546 html("<td class='main'>"); 546 html("<td class='main'>");
547 if (ctx->repo) { 547 if (ctx->repo) {
548 cgit_index_link("index", NULL, NULL, NULL, 0);
549 html(" : ");
548 reporevlink(NULL, ctx->repo->name, NULL, hc(cmd, "summary"), 550 reporevlink(NULL, ctx->repo->name, NULL, hc(cmd, "summary"),
549 ctx->qry.head, NULL, NULL); 551 ctx->qry.head, NULL, NULL);
550 html(" : ");
551 html_txt(ctx->qry.page);
552 html("</td><td class='form'>"); 552 html("</td><td class='form'>");
553 html("<form method='get' action=''>\n"); 553 html("<form method='get' action=''>\n");
554 add_hidden_formfields(0, 1, ctx->qry.page); 554 add_hidden_formfields(0, 1, ctx->qry.page);
555 html("<select name='h' onchange='this.form.submit();'>\n"); 555 html("<select name='h' onchange='this.form.submit();'>\n");
556 for_each_branch_ref(print_branch_option, ctx->qry.head); 556 for_each_branch_ref(print_branch_option, ctx->qry.head);
557 html("</select> "); 557 html("</select> ");
558 html("<input type='submit' name='' value='switch'/>"); 558 html("<input type='submit' name='' value='switch'/>");
559 html("</form>"); 559 html("</form>");
560 } else 560 } else
561 html_txt(ctx->cfg.root_title); 561 html_txt(ctx->cfg.root_title);
562 html("</td></tr>\n"); 562 html("</td></tr>\n");
563 563
564 html("<tr><td class='sub'"); 564 html("<tr><td class='sub'");
565 if (ctx->repo) { 565 if (ctx->repo) {
566 html(" colspan='2'>"); 566 html(" colspan='2'>");
567 html_txt(ctx->repo->desc); 567 html_txt(ctx->repo->desc);
568 } else { 568 } else {
569 html(">"); 569 html(">");
570 if (ctx->cfg.root_desc) 570 if (ctx->cfg.root_desc)
571 html_txt(ctx->cfg.root_desc); 571 html_txt(ctx->cfg.root_desc);
572 else if (ctx->cfg.index_info) 572 else if (ctx->cfg.index_info)
573 html_include(ctx->cfg.index_info); 573 html_include(ctx->cfg.index_info);
574 } 574 }
575 html("</td></tr></table>\n"); 575 html("</td></tr></table>\n");
576 576
577 html("<table class='tabs'><tr><td>\n"); 577 html("<table class='tabs'><tr><td>\n");
578 if (ctx->repo) { 578 if (ctx->repo) {
579 reporevlink(NULL, "summary", NULL, hc(cmd, "summary"), 579 reporevlink(NULL, "summary", NULL, hc(cmd, "summary"),
580 ctx->qry.head, NULL, NULL); 580 ctx->qry.head, NULL, NULL);
581 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, 581 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head,
582 ctx->qry.sha1, NULL); 582 ctx->qry.sha1, NULL);
583 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, 583 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head,
584 NULL, NULL, 0, NULL, NULL); 584 NULL, NULL, 0, NULL, NULL);
585 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, 585 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head,
586 ctx->qry.sha1, NULL); 586 ctx->qry.sha1, NULL);
587 cgit_commit_link("commit", NULL, hc(cmd, "commit"), 587 cgit_commit_link("commit", NULL, hc(cmd, "commit"),
588 ctx->qry.head, ctx->qry.sha1); 588 ctx->qry.head, ctx->qry.sha1);
589 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, 589 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head,
590 ctx->qry.sha1, ctx->qry.sha2, NULL); 590 ctx->qry.sha1, ctx->qry.sha2, NULL);
591 if (ctx->repo->readme) 591 if (ctx->repo->readme)
592 reporevlink("about", "about", NULL, 592 reporevlink("about", "about", NULL,
593 hc(cmd, "about"), ctx->qry.head, NULL, 593 hc(cmd, "about"), ctx->qry.head, NULL,
594 NULL); 594 NULL);
595 html("</td><td class='form'>"); 595 html("</td><td class='form'>");
596 html("<form class='right' method='get' action='"); 596 html("<form class='right' method='get' action='");
597 if (ctx->cfg.virtual_root) 597 if (ctx->cfg.virtual_root)
598 html_attr(cgit_fileurl(ctx->qry.repo, "log", 598 html_attr(cgit_fileurl(ctx->qry.repo, "log",
599 ctx->qry.path, NULL)); 599 ctx->qry.path, NULL));
600 html("'>\n"); 600 html("'>\n");
601 add_hidden_formfields(1, 0, "log"); 601 add_hidden_formfields(1, 0, "log");
602 html("<select name='qt'>\n"); 602 html("<select name='qt'>\n");
603 html_option("grep", "log msg", ctx->qry.grep); 603 html_option("grep", "log msg", ctx->qry.grep);
604 html_option("author", "author", ctx->qry.grep); 604 html_option("author", "author", ctx->qry.grep);
605 html_option("committer", "committer", ctx->qry.grep); 605 html_option("committer", "committer", ctx->qry.grep);
606 html("</select>\n"); 606 html("</select>\n");
607 html("<input class='txt' type='text' size='10' name='q' value='"); 607 html("<input class='txt' type='text' size='10' name='q' value='");
608 html_attr(ctx->qry.search); 608 html_attr(ctx->qry.search);
609 html("'/>\n"); 609 html("'/>\n");
610 html("<input type='submit' value='search'/>\n"); 610 html("<input type='submit' value='search'/>\n");
611 html("</form>\n"); 611 html("</form>\n");
612 } else { 612 } else {
613 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); 613 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0);
614 if (ctx->cfg.root_readme) 614 if (ctx->cfg.root_readme)
615 site_link("about", "about", NULL, hc(cmd, "about"), 615 site_link("about", "about", NULL, hc(cmd, "about"),
616 NULL, 0); 616 NULL, 0);
617 html("</td><td class='form'>"); 617 html("</td><td class='form'>");
618 html("<form method='get' action='"); 618 html("<form method='get' action='");
619 html_attr(cgit_rooturl()); 619 html_attr(cgit_rooturl());
620 html("'>\n"); 620 html("'>\n");
621 html("<input type='text' name='q' size='10' value='"); 621 html("<input type='text' name='q' size='10' value='");
622 html_attr(ctx->qry.search); 622 html_attr(ctx->qry.search);
623 html("'/>\n"); 623 html("'/>\n");
624 html("<input type='submit' value='search'/>\n"); 624 html("<input type='submit' value='search'/>\n");
625 html("</form>"); 625 html("</form>");
626 } 626 }
627 html("</td></tr></table>\n"); 627 html("</td></tr></table>\n");
628 html("<div class='content'>"); 628 html("<div class='content'>");
629} 629}
630 630
631void cgit_print_filemode(unsigned short mode) 631void cgit_print_filemode(unsigned short mode)
632{ 632{
633 if (S_ISDIR(mode)) 633 if (S_ISDIR(mode))
634 html("d"); 634 html("d");
635 else if (S_ISLNK(mode)) 635 else if (S_ISLNK(mode))
636 html("l"); 636 html("l");
637 else if (S_ISGITLINK(mode)) 637 else if (S_ISGITLINK(mode))
638 html("m"); 638 html("m");
639 else 639 else
640 html("-"); 640 html("-");
641 html_fileperm(mode >> 6); 641 html_fileperm(mode >> 6);
642 html_fileperm(mode >> 3); 642 html_fileperm(mode >> 3);
643 html_fileperm(mode); 643 html_fileperm(mode);
644} 644}
645 645
646void cgit_print_snapshot_links(const char *repo, const char *head, 646void cgit_print_snapshot_links(const char *repo, const char *head,
647 const char *hex, int snapshots) 647 const char *hex, int snapshots)
648{ 648{
649 const struct cgit_snapshot_format* f; 649 const struct cgit_snapshot_format* f;
650 char *filename; 650 char *filename;
651 651
652 for (f = cgit_snapshot_formats; f->suffix; f++) { 652 for (f = cgit_snapshot_formats; f->suffix; f++) {
653 if (!(snapshots & f->bit)) 653 if (!(snapshots & f->bit))
654 continue; 654 continue;
655 filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, 655 filename = fmt("%s-%s%s", cgit_repobasename(repo), hex,
656 f->suffix); 656 f->suffix);
657 cgit_snapshot_link(filename, NULL, NULL, (char *)head, 657 cgit_snapshot_link(filename, NULL, NULL, (char *)head,
658 (char *)hex, filename); 658 (char *)hex, filename);
659 html("<br/>"); 659 html("<br/>");
660 } 660 }
661} 661}