-rw-r--r-- | ui-shared.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/ui-shared.c b/ui-shared.c index 97b9d46..a5eb25f 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
@@ -342,48 +342,54 @@ void cgit_diff_link(char *name, char *title, char *class, char *head, | |||
342 | 342 | ||
343 | delim = repolink(title, class, "diff", head, path); | 343 | delim = repolink(title, class, "diff", head, path); |
344 | if (new_rev && strcmp(new_rev, ctx.qry.head)) { | 344 | if (new_rev && strcmp(new_rev, ctx.qry.head)) { |
345 | html(delim); | 345 | html(delim); |
346 | html("id="); | 346 | html("id="); |
347 | html_url_arg(new_rev); | 347 | html_url_arg(new_rev); |
348 | delim = "&"; | 348 | delim = "&"; |
349 | } | 349 | } |
350 | if (old_rev) { | 350 | if (old_rev) { |
351 | html(delim); | 351 | html(delim); |
352 | html("id2="); | 352 | html("id2="); |
353 | html_url_arg(old_rev); | 353 | html_url_arg(old_rev); |
354 | } | 354 | } |
355 | html("'>"); | 355 | html("'>"); |
356 | html_txt(name); | 356 | html_txt(name); |
357 | html("</a>"); | 357 | html("</a>"); |
358 | } | 358 | } |
359 | 359 | ||
360 | void cgit_patch_link(char *name, char *title, char *class, char *head, | 360 | void cgit_patch_link(char *name, char *title, char *class, char *head, |
361 | char *rev) | 361 | char *rev) |
362 | { | 362 | { |
363 | reporevlink("patch", name, title, class, head, rev, NULL); | 363 | reporevlink("patch", name, title, class, head, rev, NULL); |
364 | } | 364 | } |
365 | 365 | ||
366 | void cgit_stats_link(char *name, char *title, char *class, char *head, | ||
367 | char *path) | ||
368 | { | ||
369 | reporevlink("stats", name, title, class, head, NULL, path); | ||
370 | } | ||
371 | |||
366 | void cgit_object_link(struct object *obj) | 372 | void cgit_object_link(struct object *obj) |
367 | { | 373 | { |
368 | char *page, *rev, *name; | 374 | char *page, *rev, *name; |
369 | 375 | ||
370 | if (obj->type == OBJ_COMMIT) { | 376 | if (obj->type == OBJ_COMMIT) { |
371 | cgit_commit_link(fmt("commit %s", sha1_to_hex(obj->sha1)), NULL, NULL, | 377 | cgit_commit_link(fmt("commit %s", sha1_to_hex(obj->sha1)), NULL, NULL, |
372 | ctx.qry.head, sha1_to_hex(obj->sha1)); | 378 | ctx.qry.head, sha1_to_hex(obj->sha1)); |
373 | return; | 379 | return; |
374 | } else if (obj->type == OBJ_TREE) | 380 | } else if (obj->type == OBJ_TREE) |
375 | page = "tree"; | 381 | page = "tree"; |
376 | else if (obj->type == OBJ_TAG) | 382 | else if (obj->type == OBJ_TAG) |
377 | page = "tag"; | 383 | page = "tag"; |
378 | else | 384 | else |
379 | page = "blob"; | 385 | page = "blob"; |
380 | rev = sha1_to_hex(obj->sha1); | 386 | rev = sha1_to_hex(obj->sha1); |
381 | name = fmt("%s %s", typename(obj->type), rev); | 387 | name = fmt("%s %s", typename(obj->type), rev); |
382 | reporevlink(page, name, NULL, NULL, ctx.qry.head, rev, NULL); | 388 | reporevlink(page, name, NULL, NULL, ctx.qry.head, rev, NULL); |
383 | } | 389 | } |
384 | 390 | ||
385 | void cgit_print_date(time_t secs, char *format, int local_time) | 391 | void cgit_print_date(time_t secs, char *format, int local_time) |
386 | { | 392 | { |
387 | char buf[64]; | 393 | char buf[64]; |
388 | struct tm *time; | 394 | struct tm *time; |
389 | 395 | ||
@@ -621,50 +627,50 @@ void cgit_print_pageheader(struct cgit_context *ctx) | |||
621 | html_txt(ctx->repo->owner); | 627 | html_txt(ctx->repo->owner); |
622 | } else { | 628 | } else { |
623 | if (ctx->cfg.root_desc) | 629 | if (ctx->cfg.root_desc) |
624 | html_txt(ctx->cfg.root_desc); | 630 | html_txt(ctx->cfg.root_desc); |
625 | else if (ctx->cfg.index_info) | 631 | else if (ctx->cfg.index_info) |
626 | html_include(ctx->cfg.index_info); | 632 | html_include(ctx->cfg.index_info); |
627 | } | 633 | } |
628 | html("</td></tr></table>\n"); | 634 | html("</td></tr></table>\n"); |
629 | 635 | ||
630 | html("<table class='tabs'><tr><td>\n"); | 636 | html("<table class='tabs'><tr><td>\n"); |
631 | if (ctx->repo) { | 637 | if (ctx->repo) { |
632 | cgit_summary_link("summary", NULL, hc(cmd, "summary"), | 638 | cgit_summary_link("summary", NULL, hc(cmd, "summary"), |
633 | ctx->qry.head); | 639 | ctx->qry.head); |
634 | cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, | 640 | cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, |
635 | ctx->qry.sha1, NULL); | 641 | ctx->qry.sha1, NULL); |
636 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, | 642 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, |
637 | NULL, NULL, 0, NULL, NULL); | 643 | NULL, NULL, 0, NULL, NULL); |
638 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, | 644 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, |
639 | ctx->qry.sha1, NULL); | 645 | ctx->qry.sha1, NULL); |
640 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), | 646 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), |
641 | ctx->qry.head, ctx->qry.sha1); | 647 | ctx->qry.head, ctx->qry.sha1); |
642 | cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, | 648 | cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, |
643 | ctx->qry.sha1, ctx->qry.sha2, NULL); | 649 | ctx->qry.sha1, ctx->qry.sha2, NULL); |
644 | if (ctx->repo->max_stats) | 650 | if (ctx->repo->max_stats) |
645 | reporevlink("stats", "stats", NULL, hc(cmd, "stats"), | 651 | cgit_stats_link("stats", NULL, hc(cmd, "stats"), |
646 | ctx->qry.head, NULL, NULL); | 652 | ctx->qry.head, NULL); |
647 | if (ctx->repo->readme) | 653 | if (ctx->repo->readme) |
648 | reporevlink("about", "about", NULL, | 654 | reporevlink("about", "about", NULL, |
649 | hc(cmd, "about"), ctx->qry.head, NULL, | 655 | hc(cmd, "about"), ctx->qry.head, NULL, |
650 | NULL); | 656 | NULL); |
651 | html("</td><td class='form'>"); | 657 | html("</td><td class='form'>"); |
652 | html("<form class='right' method='get' action='"); | 658 | html("<form class='right' method='get' action='"); |
653 | if (ctx->cfg.virtual_root) | 659 | if (ctx->cfg.virtual_root) |
654 | html_url_path(cgit_fileurl(ctx->qry.repo, "log", | 660 | html_url_path(cgit_fileurl(ctx->qry.repo, "log", |
655 | ctx->qry.path, NULL)); | 661 | ctx->qry.path, NULL)); |
656 | html("'>\n"); | 662 | html("'>\n"); |
657 | add_hidden_formfields(1, 0, "log"); | 663 | add_hidden_formfields(1, 0, "log"); |
658 | html("<select name='qt'>\n"); | 664 | html("<select name='qt'>\n"); |
659 | html_option("grep", "log msg", ctx->qry.grep); | 665 | html_option("grep", "log msg", ctx->qry.grep); |
660 | html_option("author", "author", ctx->qry.grep); | 666 | html_option("author", "author", ctx->qry.grep); |
661 | html_option("committer", "committer", ctx->qry.grep); | 667 | html_option("committer", "committer", ctx->qry.grep); |
662 | html("</select>\n"); | 668 | html("</select>\n"); |
663 | html("<input class='txt' type='text' size='10' name='q' value='"); | 669 | html("<input class='txt' type='text' size='10' name='q' value='"); |
664 | html_attr(ctx->qry.search); | 670 | html_attr(ctx->qry.search); |
665 | html("'/>\n"); | 671 | html("'/>\n"); |
666 | html("<input type='submit' value='search'/>\n"); | 672 | html("<input type='submit' value='search'/>\n"); |
667 | html("</form>\n"); | 673 | html("</form>\n"); |
668 | } else { | 674 | } else { |
669 | site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); | 675 | site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); |
670 | if (ctx->cfg.root_readme) | 676 | if (ctx->cfg.root_readme) |