diff options
Diffstat (limited to 'ui-shared.c')
| -rw-r--r-- | ui-shared.c | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/ui-shared.c b/ui-shared.c index 224e5f3..95dfeb4 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
| @@ -281,7 +281,8 @@ void cgit_plain_link(char *name, char *title, char *class, char *head, | |||
| 281 | } | 281 | } |
| 282 | 282 | ||
| 283 | void cgit_log_link(char *name, char *title, char *class, char *head, | 283 | void cgit_log_link(char *name, char *title, char *class, char *head, |
| 284 | char *rev, char *path, int ofs, char *grep, char *pattern) | 284 | char *rev, char *path, int ofs, char *grep, char *pattern, |
| 285 | int showmsg) | ||
| 285 | { | 286 | { |
| 286 | char *delim; | 287 | char *delim; |
| 287 | 288 | ||
| @@ -305,6 +306,11 @@ void cgit_log_link(char *name, char *title, char *class, char *head, | |||
| 305 | html(delim); | 306 | html(delim); |
| 306 | html("ofs="); | 307 | html("ofs="); |
| 307 | htmlf("%d", ofs); | 308 | htmlf("%d", ofs); |
| 309 | delim = "&"; | ||
| 310 | } | ||
| 311 | if (showmsg) { | ||
| 312 | html(delim); | ||
| 313 | html("showmsg=1"); | ||
| 308 | } | 314 | } |
| 309 | html("'>"); | 315 | html("'>"); |
| 310 | html_txt(name); | 316 | html_txt(name); |
| @@ -365,11 +371,14 @@ void cgit_patch_link(char *name, char *title, char *class, char *head, | |||
| 365 | 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, *shortrev, *fullrev, *name; |
| 369 | 375 | ||
| 376 | fullrev = sha1_to_hex(obj->sha1); | ||
| 377 | shortrev = xstrdup(fullrev); | ||
| 378 | shortrev[10] = '\0'; | ||
| 370 | if (obj->type == OBJ_COMMIT) { | 379 | if (obj->type == OBJ_COMMIT) { |
| 371 | cgit_commit_link(fmt("commit %s", sha1_to_hex(obj->sha1)), NULL, NULL, | 380 | cgit_commit_link(fmt("commit %s...", shortrev), NULL, NULL, |
| 372 | ctx.qry.head, sha1_to_hex(obj->sha1)); | 381 | ctx.qry.head, fullrev); |
| 373 | return; | 382 | return; |
| 374 | } else if (obj->type == OBJ_TREE) | 383 | } else if (obj->type == OBJ_TREE) |
| 375 | page = "tree"; | 384 | page = "tree"; |
| @@ -377,9 +386,8 @@ void cgit_object_link(struct object *obj) | |||
| 377 | page = "tag"; | 386 | page = "tag"; |
| 378 | else | 387 | else |
| 379 | page = "blob"; | 388 | page = "blob"; |
| 380 | rev = sha1_to_hex(obj->sha1); | 389 | name = fmt("%s %s...", typename(obj->type), shortrev); |
| 381 | name = fmt("%s %s", typename(obj->type), rev); | 390 | reporevlink(page, name, NULL, NULL, ctx.qry.head, fullrev, NULL); |
| 382 | reporevlink(page, name, NULL, NULL, ctx.qry.head, rev, NULL); | ||
| 383 | } | 391 | } |
| 384 | 392 | ||
| 385 | void cgit_print_date(time_t secs, char *format, int local_time) | 393 | void cgit_print_date(time_t secs, char *format, int local_time) |
| @@ -568,6 +576,8 @@ void add_hidden_formfields(int incl_head, int incl_search, char *page) | |||
| 568 | html_hidden("id", ctx.qry.sha1); | 576 | html_hidden("id", ctx.qry.sha1); |
| 569 | if (ctx.qry.sha2) | 577 | if (ctx.qry.sha2) |
| 570 | html_hidden("id2", ctx.qry.sha2); | 578 | html_hidden("id2", ctx.qry.sha2); |
| 579 | if (ctx.qry.showmsg) | ||
| 580 | html_hidden("showmsg", "1"); | ||
| 571 | 581 | ||
| 572 | if (incl_search) { | 582 | if (incl_search) { |
| 573 | if (ctx.qry.grep) | 583 | if (ctx.qry.grep) |
| @@ -634,7 +644,7 @@ void cgit_print_pageheader(struct cgit_context *ctx) | |||
| 634 | cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, | 644 | cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, |
| 635 | ctx->qry.sha1, NULL); | 645 | ctx->qry.sha1, NULL); |
| 636 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, | 646 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, |
| 637 | NULL, NULL, 0, NULL, NULL); | 647 | NULL, NULL, 0, NULL, NULL, ctx->qry.showmsg); |
| 638 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, | 648 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, |
| 639 | ctx->qry.sha1, NULL); | 649 | ctx->qry.sha1, NULL); |
| 640 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), | 650 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), |
| @@ -707,8 +717,7 @@ void cgit_print_snapshot_links(const char *repo, const char *head, | |||
| 707 | continue; | 717 | continue; |
| 708 | filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, | 718 | filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, |
| 709 | f->suffix); | 719 | f->suffix); |
| 710 | cgit_snapshot_link(filename, NULL, NULL, (char *)head, | 720 | cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename); |
| 711 | (char *)hex, filename); | ||
| 712 | html("<br/>"); | 721 | html("<br/>"); |
| 713 | } | 722 | } |
| 714 | } | 723 | } |
