-rw-r--r-- | ui-shared.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/ui-shared.c b/ui-shared.c index 7287956..03d147f 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
@@ -353,202 +353,208 @@ void cgit_print_age(time_t t, time_t max_relative, char *format) | |||
353 | htmlf("<span class='age-years'>%.0f years</span>", | 353 | htmlf("<span class='age-years'>%.0f years</span>", |
354 | secs * 1.0 / TM_YEAR); | 354 | secs * 1.0 / TM_YEAR); |
355 | } | 355 | } |
356 | 356 | ||
357 | void cgit_print_http_headers(struct cgit_context *ctx) | 357 | void cgit_print_http_headers(struct cgit_context *ctx) |
358 | { | 358 | { |
359 | if (ctx->page.mimetype && ctx->page.charset) | 359 | if (ctx->page.mimetype && ctx->page.charset) |
360 | htmlf("Content-Type: %s; charset=%s\n", ctx->page.mimetype, | 360 | htmlf("Content-Type: %s; charset=%s\n", ctx->page.mimetype, |
361 | ctx->page.charset); | 361 | ctx->page.charset); |
362 | else if (ctx->page.mimetype) | 362 | else if (ctx->page.mimetype) |
363 | htmlf("Content-Type: %s\n", ctx->page.mimetype); | 363 | htmlf("Content-Type: %s\n", ctx->page.mimetype); |
364 | if (ctx->page.filename) | 364 | if (ctx->page.filename) |
365 | htmlf("Content-Disposition: inline; filename=\"%s\"\n", | 365 | htmlf("Content-Disposition: inline; filename=\"%s\"\n", |
366 | ctx->page.filename); | 366 | ctx->page.filename); |
367 | htmlf("Last-Modified: %s\n", http_date(ctx->page.modified)); | 367 | htmlf("Last-Modified: %s\n", http_date(ctx->page.modified)); |
368 | htmlf("Expires: %s\n", http_date(ctx->page.expires)); | 368 | htmlf("Expires: %s\n", http_date(ctx->page.expires)); |
369 | html("\n"); | 369 | html("\n"); |
370 | } | 370 | } |
371 | 371 | ||
372 | void cgit_print_docstart(struct cgit_context *ctx) | 372 | void cgit_print_docstart(struct cgit_context *ctx) |
373 | { | 373 | { |
374 | html(cgit_doctype); | 374 | html(cgit_doctype); |
375 | html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); | 375 | html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); |
376 | html("<head>\n"); | 376 | html("<head>\n"); |
377 | html("<title>"); | 377 | html("<title>"); |
378 | html_txt(ctx->page.title); | 378 | html_txt(ctx->page.title); |
379 | html("</title>\n"); | 379 | html("</title>\n"); |
380 | htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version); | 380 | htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version); |
381 | if (ctx->cfg.robots && *ctx->cfg.robots) | 381 | if (ctx->cfg.robots && *ctx->cfg.robots) |
382 | htmlf("<meta name='robots' content='%s'/>\n", ctx->cfg.robots); | 382 | htmlf("<meta name='robots' content='%s'/>\n", ctx->cfg.robots); |
383 | html("<link rel='stylesheet' type='text/css' href='"); | 383 | html("<link rel='stylesheet' type='text/css' href='"); |
384 | html_attr(ctx->cfg.css); | 384 | html_attr(ctx->cfg.css); |
385 | html("'/>\n"); | 385 | html("'/>\n"); |
386 | html("</head>\n"); | 386 | html("</head>\n"); |
387 | html("<body>\n"); | 387 | html("<body>\n"); |
388 | } | 388 | } |
389 | 389 | ||
390 | void cgit_print_docend() | 390 | void cgit_print_docend() |
391 | { | 391 | { |
392 | html("</td>\n</tr>\n</table>\n</body>\n</html>\n"); | 392 | html("</td>\n</tr>\n</table>\n</body>\n</html>\n"); |
393 | } | 393 | } |
394 | 394 | ||
395 | int print_branch_option(const char *refname, const unsigned char *sha1, | 395 | int print_branch_option(const char *refname, const unsigned char *sha1, |
396 | int flags, void *cb_data) | 396 | int flags, void *cb_data) |
397 | { | 397 | { |
398 | char *name = (char *)refname; | 398 | char *name = (char *)refname; |
399 | html_option(name, name, ctx.qry.head); | 399 | html_option(name, name, ctx.qry.head); |
400 | return 0; | 400 | return 0; |
401 | } | 401 | } |
402 | 402 | ||
403 | int print_archive_ref(const char *refname, const unsigned char *sha1, | 403 | int print_archive_ref(const char *refname, const unsigned char *sha1, |
404 | int flags, void *cb_data) | 404 | int flags, void *cb_data) |
405 | { | 405 | { |
406 | struct tag *tag; | 406 | struct tag *tag; |
407 | struct taginfo *info; | 407 | struct taginfo *info; |
408 | struct object *obj; | 408 | struct object *obj; |
409 | char buf[256], *url; | 409 | char buf[256], *url; |
410 | unsigned char fileid[20]; | 410 | unsigned char fileid[20]; |
411 | int *header = (int *)cb_data; | 411 | int *header = (int *)cb_data; |
412 | 412 | ||
413 | if (prefixcmp(refname, "refs/archives")) | 413 | if (prefixcmp(refname, "refs/archives")) |
414 | return 0; | 414 | return 0; |
415 | strncpy(buf, refname+14, sizeof(buf)); | 415 | strncpy(buf, refname+14, sizeof(buf)); |
416 | obj = parse_object(sha1); | 416 | obj = parse_object(sha1); |
417 | if (!obj) | 417 | if (!obj) |
418 | return 1; | 418 | return 1; |
419 | if (obj->type == OBJ_TAG) { | 419 | if (obj->type == OBJ_TAG) { |
420 | tag = lookup_tag(sha1); | 420 | tag = lookup_tag(sha1); |
421 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) | 421 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) |
422 | return 0; | 422 | return 0; |
423 | hashcpy(fileid, tag->tagged->sha1); | 423 | hashcpy(fileid, tag->tagged->sha1); |
424 | } else if (obj->type != OBJ_BLOB) { | 424 | } else if (obj->type != OBJ_BLOB) { |
425 | return 0; | 425 | return 0; |
426 | } else { | 426 | } else { |
427 | hashcpy(fileid, sha1); | 427 | hashcpy(fileid, sha1); |
428 | } | 428 | } |
429 | if (!*header) { | 429 | if (!*header) { |
430 | html("<h1>download</h1>\n"); | 430 | html("<h1>download</h1>\n"); |
431 | *header = 1; | 431 | *header = 1; |
432 | } | 432 | } |
433 | url = cgit_pageurl(ctx.qry.repo, "blob", | 433 | url = cgit_pageurl(ctx.qry.repo, "blob", |
434 | fmt("id=%s&path=%s", sha1_to_hex(fileid), | 434 | fmt("id=%s&path=%s", sha1_to_hex(fileid), |
435 | buf)); | 435 | buf)); |
436 | html_link_open(url, NULL, "menu"); | 436 | html_link_open(url, NULL, "menu"); |
437 | html_txt(strlpart(buf, 20)); | 437 | html_txt(strlpart(buf, 20)); |
438 | html_link_close(); | 438 | html_link_close(); |
439 | return 0; | 439 | return 0; |
440 | } | 440 | } |
441 | 441 | ||
442 | void add_hidden_formfields(int incl_head, int incl_search, char *page) | 442 | void add_hidden_formfields(int incl_head, int incl_search, char *page) |
443 | { | 443 | { |
444 | char *url; | 444 | char *url; |
445 | 445 | ||
446 | if (!ctx.cfg.virtual_root) { | 446 | if (!ctx.cfg.virtual_root) { |
447 | url = fmt("%s/%s", ctx.qry.repo, page); | 447 | url = fmt("%s/%s", ctx.qry.repo, page); |
448 | if (ctx.qry.path) | 448 | if (ctx.qry.path) |
449 | url = fmt("%s/%s", url, ctx.qry.path); | 449 | url = fmt("%s/%s", url, ctx.qry.path); |
450 | html_hidden("url", url); | 450 | html_hidden("url", url); |
451 | } | 451 | } |
452 | 452 | ||
453 | if (incl_head && strcmp(ctx.qry.head, ctx.repo->defbranch)) | 453 | if (incl_head && strcmp(ctx.qry.head, ctx.repo->defbranch)) |
454 | html_hidden("h", ctx.qry.head); | 454 | html_hidden("h", ctx.qry.head); |
455 | 455 | ||
456 | if (ctx.qry.sha1) | 456 | if (ctx.qry.sha1) |
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 | ||
469 | char *hc(struct cgit_cmd *cmd, const char *page) | 469 | char *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 | ||
474 | void cgit_print_pageheader(struct cgit_context *ctx) | 474 | void 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 | html_attr(cgit_rooturl()); | 481 | if (ctx->cfg.logo_link) |
482 | html_attr(ctx->cfg.logo_link); | ||
483 | else | ||
484 | html_attr(cgit_rooturl()); | ||
482 | html("'><img src='"); | 485 | html("'><img src='"); |
483 | html_attr(ctx->cfg.logo); | 486 | html_attr(ctx->cfg.logo); |
484 | html("'/></a></td>\n"); | 487 | html("'/></a></td>\n"); |
485 | html("<td class='main'>"); | 488 | html("<td class='main'>"); |
486 | if (ctx->repo) | 489 | if (ctx->repo) { |
490 | html("<a href='"); | ||
491 | html_attr(cgit_rooturl()); | ||
492 | html("'>index</a> / "); | ||
487 | html_txt(ctx->repo->name); | 493 | html_txt(ctx->repo->name); |
488 | else | 494 | } else |
489 | html_txt(ctx->cfg.root_title); | 495 | html_txt(ctx->cfg.root_title); |
490 | html("</td></tr>\n"); | 496 | html("</td></tr>\n"); |
491 | html("<tr><td class='sub'>"); | 497 | html("<tr><td class='sub'>"); |
492 | if (ctx->repo) | 498 | if (ctx->repo) |
493 | html_txt(ctx->repo->desc); | 499 | html_txt(ctx->repo->desc); |
494 | else | 500 | else |
495 | html_txt(ctx->cfg.index_info); | 501 | html_txt(ctx->cfg.index_info); |
496 | html("</td></tr>\n"); | 502 | html("</td></tr>\n"); |
497 | html("</table>\n"); | 503 | html("</table>\n"); |
498 | 504 | ||
499 | html("<table class='tabs'><tr><td>\n"); | 505 | html("<table class='tabs'><tr><td>\n"); |
500 | if (ctx->repo) { | 506 | if (ctx->repo) { |
501 | reporevlink(NULL, "summary", NULL, hc(cmd, "summary"), | 507 | reporevlink(NULL, "summary", NULL, hc(cmd, "summary"), |
502 | ctx->qry.head, NULL, NULL); | 508 | ctx->qry.head, NULL, NULL); |
503 | cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, | 509 | cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, |
504 | ctx->qry.sha1, NULL); | 510 | ctx->qry.sha1, NULL); |
505 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, | 511 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, |
506 | NULL, NULL, 0, NULL, NULL); | 512 | NULL, NULL, 0, NULL, NULL); |
507 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, | 513 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, |
508 | ctx->qry.sha1, NULL); | 514 | ctx->qry.sha1, NULL); |
509 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), | 515 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), |
510 | ctx->qry.head, ctx->qry.sha1); | 516 | ctx->qry.head, ctx->qry.sha1); |
511 | cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, | 517 | cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, |
512 | ctx->qry.sha1, ctx->qry.sha2, NULL); | 518 | ctx->qry.sha1, ctx->qry.sha2, NULL); |
513 | cgit_patch_link("patch", NULL, hc(cmd, "patch"), ctx->qry.head, | 519 | cgit_patch_link("patch", NULL, hc(cmd, "patch"), ctx->qry.head, |
514 | ctx->qry.sha1); | 520 | ctx->qry.sha1); |
515 | } else { | 521 | } else { |
516 | html("<a class='active' href='"); | 522 | html("<a class='active' href='"); |
517 | html_attr(cgit_rooturl()); | 523 | html_attr(cgit_rooturl()); |
518 | html("'>index</a>\n"); | 524 | html("'>index</a>\n"); |
519 | } | 525 | } |
520 | html("</td></tr></table>\n"); | 526 | html("</td></tr></table>\n"); |
521 | html("<div class='content'>"); | 527 | html("<div class='content'>"); |
522 | } | 528 | } |
523 | 529 | ||
524 | void cgit_print_filemode(unsigned short mode) | 530 | void cgit_print_filemode(unsigned short mode) |
525 | { | 531 | { |
526 | if (S_ISDIR(mode)) | 532 | if (S_ISDIR(mode)) |
527 | html("d"); | 533 | html("d"); |
528 | else if (S_ISLNK(mode)) | 534 | else if (S_ISLNK(mode)) |
529 | html("l"); | 535 | html("l"); |
530 | else if (S_ISGITLINK(mode)) | 536 | else if (S_ISGITLINK(mode)) |
531 | html("m"); | 537 | html("m"); |
532 | else | 538 | else |
533 | html("-"); | 539 | html("-"); |
534 | html_fileperm(mode >> 6); | 540 | html_fileperm(mode >> 6); |
535 | html_fileperm(mode >> 3); | 541 | html_fileperm(mode >> 3); |
536 | html_fileperm(mode); | 542 | html_fileperm(mode); |
537 | } | 543 | } |
538 | 544 | ||
539 | void cgit_print_snapshot_links(const char *repo, const char *head, | 545 | void cgit_print_snapshot_links(const char *repo, const char *head, |
540 | const char *hex, int snapshots) | 546 | const char *hex, int snapshots) |
541 | { | 547 | { |
542 | const struct cgit_snapshot_format* f; | 548 | const struct cgit_snapshot_format* f; |
543 | char *filename; | 549 | char *filename; |
544 | 550 | ||
545 | for (f = cgit_snapshot_formats; f->suffix; f++) { | 551 | for (f = cgit_snapshot_formats; f->suffix; f++) { |
546 | if (!(snapshots & f->bit)) | 552 | if (!(snapshots & f->bit)) |
547 | continue; | 553 | continue; |
548 | filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, | 554 | filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, |
549 | f->suffix); | 555 | f->suffix); |
550 | cgit_snapshot_link(filename, NULL, NULL, (char *)head, | 556 | cgit_snapshot_link(filename, NULL, NULL, (char *)head, |
551 | (char *)hex, filename); | 557 | (char *)hex, filename); |
552 | html("<br/>"); | 558 | html("<br/>"); |
553 | } | 559 | } |
554 | } | 560 | } |