diff options
Diffstat (limited to 'ui-shared.c')
| -rw-r--r-- | ui-shared.c | 270 |
1 files changed, 203 insertions, 67 deletions
diff --git a/ui-shared.c b/ui-shared.c index 8a7cc32..ae29615 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
| @@ -27,7 +27,7 @@ static char *http_date(time_t t) | |||
| 27 | tm->tm_hour, tm->tm_min, tm->tm_sec); | 27 | tm->tm_hour, tm->tm_min, tm->tm_sec); |
| 28 | } | 28 | } |
| 29 | 29 | ||
| 30 | void cgit_print_error(char *msg) | 30 | void cgit_print_error(const char *msg) |
| 31 | { | 31 | { |
| 32 | html("<div class='error'>"); | 32 | html("<div class='error'>"); |
| 33 | html_txt(msg); | 33 | html_txt(msg); |
| @@ -133,7 +133,7 @@ char *cgit_currurl() | |||
| 133 | return fmt("%s/", ctx.cfg.virtual_root); | 133 | return fmt("%s/", ctx.cfg.virtual_root); |
| 134 | } | 134 | } |
| 135 | 135 | ||
| 136 | static void site_url(char *page, char *search, int ofs) | 136 | static void site_url(const char *page, const char *search, int ofs) |
| 137 | { | 137 | { |
| 138 | char *delim = "?"; | 138 | char *delim = "?"; |
| 139 | 139 | ||
| @@ -160,8 +160,8 @@ static void site_url(char *page, char *search, int ofs) | |||
| 160 | } | 160 | } |
| 161 | } | 161 | } |
| 162 | 162 | ||
| 163 | static void site_link(char *page, char *name, char *title, char *class, | 163 | static void site_link(const char *page, const char *name, const char *title, |
| 164 | char *search, int ofs) | 164 | const char *class, const char *search, int ofs) |
| 165 | { | 165 | { |
| 166 | html("<a"); | 166 | html("<a"); |
| 167 | if (title) { | 167 | if (title) { |
| @@ -181,14 +181,14 @@ static void site_link(char *page, char *name, char *title, char *class, | |||
| 181 | html("</a>"); | 181 | html("</a>"); |
| 182 | } | 182 | } |
| 183 | 183 | ||
| 184 | void cgit_index_link(char *name, char *title, char *class, char *pattern, | 184 | void cgit_index_link(const char *name, const char *title, const char *class, |
| 185 | int ofs) | 185 | const char *pattern, int ofs) |
| 186 | { | 186 | { |
| 187 | site_link(NULL, name, title, class, pattern, ofs); | 187 | site_link(NULL, name, title, class, pattern, ofs); |
| 188 | } | 188 | } |
| 189 | 189 | ||
| 190 | static char *repolink(char *title, char *class, char *page, char *head, | 190 | static char *repolink(const char *title, const char *class, const char *page, |
| 191 | char *path) | 191 | const char *head, const char *path) |
| 192 | { | 192 | { |
| 193 | char *delim = "?"; | 193 | char *delim = "?"; |
| 194 | 194 | ||
| @@ -240,8 +240,9 @@ static char *repolink(char *title, char *class, char *page, char *head, | |||
| 240 | return fmt("%s", delim); | 240 | return fmt("%s", delim); |
| 241 | } | 241 | } |
| 242 | 242 | ||
| 243 | static void reporevlink(char *page, char *name, char *title, char *class, | 243 | static void reporevlink(const char *page, const char *name, const char *title, |
| 244 | char *head, char *rev, char *path) | 244 | const char *class, const char *head, const char *rev, |
| 245 | const char *path) | ||
| 245 | { | 246 | { |
| 246 | char *delim; | 247 | char *delim; |
| 247 | 248 | ||
| @@ -256,32 +257,33 @@ static void reporevlink(char *page, char *name, char *title, char *class, | |||
| 256 | html("</a>"); | 257 | html("</a>"); |
| 257 | } | 258 | } |
| 258 | 259 | ||
| 259 | void cgit_summary_link(char *name, char *title, char *class, char *head) | 260 | void cgit_summary_link(const char *name, const char *title, const char *class, |
| 261 | const char *head) | ||
| 260 | { | 262 | { |
| 261 | reporevlink(NULL, name, title, class, head, NULL, NULL); | 263 | reporevlink(NULL, name, title, class, head, NULL, NULL); |
| 262 | } | 264 | } |
| 263 | 265 | ||
| 264 | void cgit_tag_link(char *name, char *title, char *class, char *head, | 266 | void cgit_tag_link(const char *name, const char *title, const char *class, |
| 265 | char *rev) | 267 | const char *head, const char *rev) |
| 266 | { | 268 | { |
| 267 | reporevlink("tag", name, title, class, head, rev, NULL); | 269 | reporevlink("tag", name, title, class, head, rev, NULL); |
| 268 | } | 270 | } |
| 269 | 271 | ||
| 270 | void cgit_tree_link(char *name, char *title, char *class, char *head, | 272 | void cgit_tree_link(const char *name, const char *title, const char *class, |
| 271 | char *rev, char *path) | 273 | const char *head, const char *rev, const char *path) |
| 272 | { | 274 | { |
| 273 | reporevlink("tree", name, title, class, head, rev, path); | 275 | reporevlink("tree", name, title, class, head, rev, path); |
| 274 | } | 276 | } |
| 275 | 277 | ||
| 276 | void cgit_plain_link(char *name, char *title, char *class, char *head, | 278 | void cgit_plain_link(const char *name, const char *title, const char *class, |
| 277 | char *rev, char *path) | 279 | const char *head, const char *rev, const char *path) |
| 278 | { | 280 | { |
| 279 | reporevlink("plain", name, title, class, head, rev, path); | 281 | reporevlink("plain", name, title, class, head, rev, path); |
| 280 | } | 282 | } |
| 281 | 283 | ||
| 282 | void cgit_log_link(char *name, char *title, char *class, char *head, | 284 | void cgit_log_link(const char *name, const char *title, const char *class, |
| 283 | char *rev, char *path, int ofs, char *grep, char *pattern, | 285 | const char *head, const char *rev, const char *path, |
| 284 | int showmsg) | 286 | int ofs, const char *grep, const char *pattern, int showmsg) |
| 285 | { | 287 | { |
| 286 | char *delim; | 288 | char *delim; |
| 287 | 289 | ||
| @@ -316,8 +318,9 @@ void cgit_log_link(char *name, char *title, char *class, char *head, | |||
| 316 | html("</a>"); | 318 | html("</a>"); |
| 317 | } | 319 | } |
| 318 | 320 | ||
| 319 | void cgit_commit_link(char *name, char *title, char *class, char *head, | 321 | void cgit_commit_link(char *name, const char *title, const char *class, |
| 320 | char *rev) | 322 | const char *head, const char *rev, const char *path, |
| 323 | int toggle_ssdiff) | ||
| 321 | { | 324 | { |
| 322 | if (strlen(name) > ctx.cfg.max_msg_len && ctx.cfg.max_msg_len >= 15) { | 325 | if (strlen(name) > ctx.cfg.max_msg_len && ctx.cfg.max_msg_len >= 15) { |
| 323 | name[ctx.cfg.max_msg_len] = '\0'; | 326 | name[ctx.cfg.max_msg_len] = '\0'; |
| @@ -325,23 +328,53 @@ void cgit_commit_link(char *name, char *title, char *class, char *head, | |||
| 325 | name[ctx.cfg.max_msg_len - 2] = '.'; | 328 | name[ctx.cfg.max_msg_len - 2] = '.'; |
| 326 | name[ctx.cfg.max_msg_len - 3] = '.'; | 329 | name[ctx.cfg.max_msg_len - 3] = '.'; |
| 327 | } | 330 | } |
| 328 | reporevlink("commit", name, title, class, head, rev, NULL); | 331 | |
| 332 | char *delim; | ||
| 333 | |||
| 334 | delim = repolink(title, class, "commit", head, path); | ||
| 335 | if (rev && strcmp(rev, ctx.qry.head)) { | ||
| 336 | html(delim); | ||
| 337 | html("id="); | ||
| 338 | html_url_arg(rev); | ||
| 339 | delim = "&"; | ||
| 340 | } | ||
| 341 | if ((ctx.qry.ssdiff && !toggle_ssdiff) || (!ctx.qry.ssdiff && toggle_ssdiff)) { | ||
| 342 | html(delim); | ||
| 343 | html("ss=1"); | ||
| 344 | delim = "&"; | ||
| 345 | } | ||
| 346 | if (ctx.qry.context > 0 && ctx.qry.context != 3) { | ||
| 347 | html(delim); | ||
| 348 | html("context="); | ||
| 349 | htmlf("%d", ctx.qry.context); | ||
| 350 | delim = "&"; | ||
| 351 | } | ||
| 352 | if (ctx.qry.ignorews) { | ||
| 353 | html(delim); | ||
| 354 | html("ignorews=1"); | ||
| 355 | delim = "&"; | ||
| 356 | } | ||
| 357 | html("'>"); | ||
| 358 | html_txt(name); | ||
| 359 | html("</a>"); | ||
| 329 | } | 360 | } |
| 330 | 361 | ||
| 331 | void cgit_refs_link(char *name, char *title, char *class, char *head, | 362 | void cgit_refs_link(const char *name, const char *title, const char *class, |
| 332 | char *rev, char *path) | 363 | const char *head, const char *rev, const char *path) |
| 333 | { | 364 | { |
| 334 | reporevlink("refs", name, title, class, head, rev, path); | 365 | reporevlink("refs", name, title, class, head, rev, path); |
| 335 | } | 366 | } |
| 336 | 367 | ||
| 337 | void cgit_snapshot_link(char *name, char *title, char *class, char *head, | 368 | void cgit_snapshot_link(const char *name, const char *title, const char *class, |
| 338 | char *rev, char *archivename) | 369 | const char *head, const char *rev, |
| 370 | const char *archivename) | ||
| 339 | { | 371 | { |
| 340 | reporevlink("snapshot", name, title, class, head, rev, archivename); | 372 | reporevlink("snapshot", name, title, class, head, rev, archivename); |
| 341 | } | 373 | } |
| 342 | 374 | ||
| 343 | void cgit_diff_link(char *name, char *title, char *class, char *head, | 375 | void cgit_diff_link(const char *name, const char *title, const char *class, |
| 344 | char *new_rev, char *old_rev, char *path) | 376 | const char *head, const char *new_rev, const char *old_rev, |
| 377 | const char *path, int toggle_ssdiff) | ||
| 345 | { | 378 | { |
| 346 | char *delim; | 379 | char *delim; |
| 347 | 380 | ||
| @@ -356,24 +389,99 @@ void cgit_diff_link(char *name, char *title, char *class, char *head, | |||
| 356 | html(delim); | 389 | html(delim); |
| 357 | html("id2="); | 390 | html("id2="); |
| 358 | html_url_arg(old_rev); | 391 | html_url_arg(old_rev); |
| 392 | delim = "&"; | ||
| 393 | } | ||
| 394 | if ((ctx.qry.ssdiff && !toggle_ssdiff) || (!ctx.qry.ssdiff && toggle_ssdiff)) { | ||
| 395 | html(delim); | ||
| 396 | html("ss=1"); | ||
| 397 | delim = "&"; | ||
| 398 | } | ||
| 399 | if (ctx.qry.context > 0 && ctx.qry.context != 3) { | ||
| 400 | html(delim); | ||
| 401 | html("context="); | ||
| 402 | htmlf("%d", ctx.qry.context); | ||
| 403 | delim = "&"; | ||
| 404 | } | ||
| 405 | if (ctx.qry.ignorews) { | ||
| 406 | html(delim); | ||
| 407 | html("ignorews=1"); | ||
| 408 | delim = "&"; | ||
| 359 | } | 409 | } |
| 360 | html("'>"); | 410 | html("'>"); |
| 361 | html_txt(name); | 411 | html_txt(name); |
| 362 | html("</a>"); | 412 | html("</a>"); |
| 363 | } | 413 | } |
| 364 | 414 | ||
| 365 | void cgit_patch_link(char *name, char *title, char *class, char *head, | 415 | void cgit_patch_link(const char *name, const char *title, const char *class, |
| 366 | char *rev) | 416 | const char *head, const char *rev, const char *path) |
| 367 | { | 417 | { |
| 368 | reporevlink("patch", name, title, class, head, rev, NULL); | 418 | reporevlink("patch", name, title, class, head, rev, path); |
| 369 | } | 419 | } |
| 370 | 420 | ||
| 371 | void cgit_stats_link(char *name, char *title, char *class, char *head, | 421 | void cgit_stats_link(const char *name, const char *title, const char *class, |
| 372 | char *path) | 422 | const char *head, const char *path) |
| 373 | { | 423 | { |
| 374 | reporevlink("stats", name, title, class, head, NULL, path); | 424 | reporevlink("stats", name, title, class, head, NULL, path); |
| 375 | } | 425 | } |
| 376 | 426 | ||
| 427 | void cgit_self_link(char *name, const char *title, const char *class, | ||
| 428 | struct cgit_context *ctx) | ||
| 429 | { | ||
| 430 | if (!strcmp(ctx->qry.page, "repolist")) | ||
| 431 | return cgit_index_link(name, title, class, ctx->qry.search, | ||
| 432 | ctx->qry.ofs); | ||
| 433 | else if (!strcmp(ctx->qry.page, "summary")) | ||
| 434 | return cgit_summary_link(name, title, class, ctx->qry.head); | ||
| 435 | else if (!strcmp(ctx->qry.page, "tag")) | ||
| 436 | return cgit_tag_link(name, title, class, ctx->qry.head, | ||
| 437 | ctx->qry.has_sha1 ? ctx->qry.sha1 : NULL); | ||
| 438 | else if (!strcmp(ctx->qry.page, "tree")) | ||
| 439 | return cgit_tree_link(name, title, class, ctx->qry.head, | ||
| 440 | ctx->qry.has_sha1 ? ctx->qry.sha1 : NULL, | ||
| 441 | ctx->qry.path); | ||
| 442 | else if (!strcmp(ctx->qry.page, "plain")) | ||
| 443 | return cgit_plain_link(name, title, class, ctx->qry.head, | ||
| 444 | ctx->qry.has_sha1 ? ctx->qry.sha1 : NULL, | ||
| 445 | ctx->qry.path); | ||
| 446 | else if (!strcmp(ctx->qry.page, "log")) | ||
| 447 | return cgit_log_link(name, title, class, ctx->qry.head, | ||
| 448 | ctx->qry.has_sha1 ? ctx->qry.sha1 : NULL, | ||
| 449 | ctx->qry.path, ctx->qry.ofs, | ||
| 450 | ctx->qry.grep, ctx->qry.search, | ||
| 451 | ctx->qry.showmsg); | ||
| 452 | else if (!strcmp(ctx->qry.page, "commit")) | ||
| 453 | return cgit_commit_link(name, title, class, ctx->qry.head, | ||
| 454 | ctx->qry.has_sha1 ? ctx->qry.sha1 : NULL, | ||
| 455 | ctx->qry.path, 0); | ||
| 456 | else if (!strcmp(ctx->qry.page, "patch")) | ||
| 457 | return cgit_patch_link(name, title, class, ctx->qry.head, | ||
| 458 | ctx->qry.has_sha1 ? ctx->qry.sha1 : NULL, | ||
| 459 | ctx->qry.path); | ||
| 460 | else if (!strcmp(ctx->qry.page, "refs")) | ||
| 461 | return cgit_refs_link(name, title, class, ctx->qry.head, | ||
| 462 | ctx->qry.has_sha1 ? ctx->qry.sha1 : NULL, | ||
| 463 | ctx->qry.path); | ||
| 464 | else if (!strcmp(ctx->qry.page, "snapshot")) | ||
| 465 | return cgit_snapshot_link(name, title, class, ctx->qry.head, | ||
| 466 | ctx->qry.has_sha1 ? ctx->qry.sha1 : NULL, | ||
| 467 | ctx->qry.path); | ||
| 468 | else if (!strcmp(ctx->qry.page, "diff")) | ||
| 469 | return cgit_diff_link(name, title, class, ctx->qry.head, | ||
| 470 | ctx->qry.sha1, ctx->qry.sha2, | ||
| 471 | ctx->qry.path, 0); | ||
| 472 | else if (!strcmp(ctx->qry.page, "stats")) | ||
| 473 | return cgit_stats_link(name, title, class, ctx->qry.head, | ||
| 474 | ctx->qry.path); | ||
| 475 | |||
| 476 | /* Don't known how to make link for this page */ | ||
| 477 | repolink(title, class, ctx->qry.page, ctx->qry.head, ctx->qry.path); | ||
| 478 | html("><!-- cgit_self_link() doesn't know how to make link for page '"); | ||
| 479 | html_txt(ctx->qry.page); | ||
| 480 | html("' -->"); | ||
| 481 | html_txt(name); | ||
| 482 | html("</a>"); | ||
| 483 | } | ||
| 484 | |||
| 377 | void cgit_object_link(struct object *obj) | 485 | void cgit_object_link(struct object *obj) |
| 378 | { | 486 | { |
| 379 | char *page, *shortrev, *fullrev, *name; | 487 | char *page, *shortrev, *fullrev, *name; |
| @@ -383,7 +491,7 @@ void cgit_object_link(struct object *obj) | |||
| 383 | shortrev[10] = '\0'; | 491 | shortrev[10] = '\0'; |
| 384 | if (obj->type == OBJ_COMMIT) { | 492 | if (obj->type == OBJ_COMMIT) { |
| 385 | cgit_commit_link(fmt("commit %s...", shortrev), NULL, NULL, | 493 | cgit_commit_link(fmt("commit %s...", shortrev), NULL, NULL, |
| 386 | ctx.qry.head, fullrev); | 494 | ctx.qry.head, fullrev, NULL, 0); |
| 387 | return; | 495 | return; |
| 388 | } else if (obj->type == OBJ_TREE) | 496 | } else if (obj->type == OBJ_TREE) |
| 389 | page = "tree"; | 497 | page = "tree"; |
| @@ -395,7 +503,7 @@ void cgit_object_link(struct object *obj) | |||
| 395 | reporevlink(page, name, NULL, NULL, ctx.qry.head, fullrev, NULL); | 503 | reporevlink(page, name, NULL, NULL, ctx.qry.head, fullrev, NULL); |
| 396 | } | 504 | } |
| 397 | 505 | ||
| 398 | void cgit_print_date(time_t secs, char *format, int local_time) | 506 | void cgit_print_date(time_t secs, const char *format, int local_time) |
| 399 | { | 507 | { |
| 400 | char buf[64]; | 508 | char buf[64]; |
| 401 | struct tm *time; | 509 | struct tm *time; |
| @@ -410,7 +518,7 @@ void cgit_print_date(time_t secs, char *format, int local_time) | |||
| 410 | html_txt(buf); | 518 | html_txt(buf); |
| 411 | } | 519 | } |
| 412 | 520 | ||
| 413 | void cgit_print_age(time_t t, time_t max_relative, char *format) | 521 | void cgit_print_age(time_t t, time_t max_relative, const char *format) |
| 414 | { | 522 | { |
| 415 | time_t now, secs; | 523 | time_t now, secs; |
| 416 | 524 | ||
| @@ -509,7 +617,7 @@ void cgit_print_docstart(struct cgit_context *ctx) | |||
| 509 | html("<link rel='alternate' title='Atom feed' href='"); | 617 | html("<link rel='alternate' title='Atom feed' href='"); |
| 510 | html(cgit_httpscheme()); | 618 | html(cgit_httpscheme()); |
| 511 | html_attr(cgit_hosturl()); | 619 | html_attr(cgit_hosturl()); |
| 512 | html_attr(cgit_fileurl(ctx->repo->url, "atom", ctx->qry.path, | 620 | html_attr(cgit_fileurl(ctx->repo->url, "atom", ctx->qry.vpath, |
| 513 | fmt("h=%s", ctx->qry.head))); | 621 | fmt("h=%s", ctx->qry.head))); |
| 514 | html("' type='application/atom+xml'/>\n"); | 622 | html("' type='application/atom+xml'/>\n"); |
| 515 | } | 623 | } |
| @@ -589,14 +697,15 @@ int print_archive_ref(const char *refname, const unsigned char *sha1, | |||
| 589 | return 0; | 697 | return 0; |
| 590 | } | 698 | } |
| 591 | 699 | ||
| 592 | void cgit_add_hidden_formfields(int incl_head, int incl_search, char *page) | 700 | void cgit_add_hidden_formfields(int incl_head, int incl_search, |
| 701 | const char *page) | ||
| 593 | { | 702 | { |
| 594 | char *url; | 703 | char *url; |
| 595 | 704 | ||
| 596 | if (!ctx.cfg.virtual_root) { | 705 | if (!ctx.cfg.virtual_root) { |
| 597 | url = fmt("%s/%s", ctx.qry.repo, page); | 706 | url = fmt("%s/%s", ctx.qry.repo, page); |
| 598 | if (ctx.qry.path) | 707 | if (ctx.qry.vpath) |
| 599 | url = fmt("%s/%s", url, ctx.qry.path); | 708 | url = fmt("%s/%s", url, ctx.qry.vpath); |
| 600 | html_hidden("url", url); | 709 | html_hidden("url", url); |
| 601 | } | 710 | } |
| 602 | 711 | ||
| @@ -619,11 +728,30 @@ void cgit_add_hidden_formfields(int incl_head, int incl_search, char *page) | |||
| 619 | } | 728 | } |
| 620 | } | 729 | } |
| 621 | 730 | ||
| 622 | const char *fallback_cmd = "repolist"; | 731 | static const char *hc(struct cgit_context *ctx, const char *page) |
| 732 | { | ||
| 733 | return strcmp(ctx->qry.page, page) ? NULL : "active"; | ||
| 734 | } | ||
| 623 | 735 | ||
| 624 | char *hc(struct cgit_cmd *cmd, const char *page) | 736 | static void cgit_print_path_crumbs(struct cgit_context *ctx, char *path) |
| 625 | { | 737 | { |
| 626 | return (strcmp(cmd ? cmd->name : fallback_cmd, page) ? NULL : "active"); | 738 | char *old_path = ctx->qry.path; |
| 739 | char *p = path, *q, *end = path + strlen(path); | ||
| 740 | |||
| 741 | ctx->qry.path = NULL; | ||
| 742 | cgit_self_link("root", NULL, NULL, ctx); | ||
| 743 | ctx->qry.path = p = path; | ||
| 744 | while (p < end) { | ||
| 745 | if (!(q = strchr(p, '/'))) | ||
| 746 | q = end; | ||
| 747 | *q = '\0'; | ||
| 748 | html_txt("/"); | ||
| 749 | cgit_self_link(p, NULL, NULL, ctx); | ||
| 750 | if (q < end) | ||
| 751 | *q = '/'; | ||
| 752 | p = q + 1; | ||
| 753 | } | ||
| 754 | ctx->qry.path = old_path; | ||
| 627 | } | 755 | } |
| 628 | 756 | ||
| 629 | static void print_header(struct cgit_context *ctx) | 757 | static void print_header(struct cgit_context *ctx) |
| @@ -675,47 +803,44 @@ static void print_header(struct cgit_context *ctx) | |||
| 675 | 803 | ||
| 676 | void cgit_print_pageheader(struct cgit_context *ctx) | 804 | void cgit_print_pageheader(struct cgit_context *ctx) |
| 677 | { | 805 | { |
| 678 | struct cgit_cmd *cmd = cgit_get_cmd(ctx); | ||
| 679 | |||
| 680 | if (!cmd && ctx->repo) | ||
| 681 | fallback_cmd = "summary"; | ||
| 682 | |||
| 683 | html("<div id='cgit'>"); | 806 | html("<div id='cgit'>"); |
| 684 | if (!ctx->cfg.noheader) | 807 | if (!ctx->cfg.noheader) |
| 685 | print_header(ctx); | 808 | print_header(ctx); |
| 686 | 809 | ||
| 687 | html("<table class='tabs'><tr><td>\n"); | 810 | html("<table class='tabs'><tr><td>\n"); |
| 688 | if (ctx->repo) { | 811 | if (ctx->repo) { |
| 689 | cgit_summary_link("summary", NULL, hc(cmd, "summary"), | 812 | cgit_summary_link("summary", NULL, hc(ctx, "summary"), |
| 690 | ctx->qry.head); | 813 | ctx->qry.head); |
| 691 | cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, | 814 | cgit_refs_link("refs", NULL, hc(ctx, "refs"), ctx->qry.head, |
| 692 | ctx->qry.sha1, NULL); | 815 | ctx->qry.sha1, NULL); |
| 693 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, | 816 | cgit_log_link("log", NULL, hc(ctx, "log"), ctx->qry.head, |
| 694 | NULL, NULL, 0, NULL, NULL, ctx->qry.showmsg); | 817 | NULL, ctx->qry.vpath, 0, NULL, NULL, |
| 695 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, | 818 | ctx->qry.showmsg); |
| 696 | ctx->qry.sha1, NULL); | 819 | cgit_tree_link("tree", NULL, hc(ctx, "tree"), ctx->qry.head, |
| 697 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), | 820 | ctx->qry.sha1, ctx->qry.vpath); |
| 698 | ctx->qry.head, ctx->qry.sha1); | 821 | cgit_commit_link("commit", NULL, hc(ctx, "commit"), |
| 699 | cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, | 822 | ctx->qry.head, ctx->qry.sha1, ctx->qry.vpath, 0); |
| 700 | ctx->qry.sha1, ctx->qry.sha2, NULL); | 823 | cgit_diff_link("diff", NULL, hc(ctx, "diff"), ctx->qry.head, |
| 824 | ctx->qry.sha1, ctx->qry.sha2, ctx->qry.vpath, 0); | ||
| 701 | if (ctx->repo->max_stats) | 825 | if (ctx->repo->max_stats) |
| 702 | cgit_stats_link("stats", NULL, hc(cmd, "stats"), | 826 | cgit_stats_link("stats", NULL, hc(ctx, "stats"), |
| 703 | ctx->qry.head, NULL); | 827 | ctx->qry.head, ctx->qry.vpath); |
| 704 | if (ctx->repo->readme) | 828 | if (ctx->repo->readme) |
| 705 | reporevlink("about", "about", NULL, | 829 | reporevlink("about", "about", NULL, |
| 706 | hc(cmd, "about"), ctx->qry.head, NULL, | 830 | hc(ctx, "about"), ctx->qry.head, NULL, |
| 707 | NULL); | 831 | NULL); |
| 708 | html("</td><td class='form'>"); | 832 | html("</td><td class='form'>"); |
| 709 | html("<form class='right' method='get' action='"); | 833 | html("<form class='right' method='get' action='"); |
| 710 | if (ctx->cfg.virtual_root) | 834 | if (ctx->cfg.virtual_root) |
| 711 | html_url_path(cgit_fileurl(ctx->qry.repo, "log", | 835 | html_url_path(cgit_fileurl(ctx->qry.repo, "log", |
| 712 | ctx->qry.path, NULL)); | 836 | ctx->qry.vpath, NULL)); |
| 713 | html("'>\n"); | 837 | html("'>\n"); |
| 714 | cgit_add_hidden_formfields(1, 0, "log"); | 838 | cgit_add_hidden_formfields(1, 0, "log"); |
| 715 | html("<select name='qt'>\n"); | 839 | html("<select name='qt'>\n"); |
| 716 | html_option("grep", "log msg", ctx->qry.grep); | 840 | html_option("grep", "log msg", ctx->qry.grep); |
| 717 | html_option("author", "author", ctx->qry.grep); | 841 | html_option("author", "author", ctx->qry.grep); |
| 718 | html_option("committer", "committer", ctx->qry.grep); | 842 | html_option("committer", "committer", ctx->qry.grep); |
| 843 | html_option("range", "range", ctx->qry.grep); | ||
| 719 | html("</select>\n"); | 844 | html("</select>\n"); |
| 720 | html("<input class='txt' type='text' size='10' name='q' value='"); | 845 | html("<input class='txt' type='text' size='10' name='q' value='"); |
| 721 | html_attr(ctx->qry.search); | 846 | html_attr(ctx->qry.search); |
| @@ -723,9 +848,9 @@ void cgit_print_pageheader(struct cgit_context *ctx) | |||
| 723 | html("<input type='submit' value='search'/>\n"); | 848 | html("<input type='submit' value='search'/>\n"); |
| 724 | html("</form>\n"); | 849 | html("</form>\n"); |
| 725 | } else { | 850 | } else { |
| 726 | site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); | 851 | site_link(NULL, "index", NULL, hc(ctx, "repolist"), NULL, 0); |
| 727 | if (ctx->cfg.root_readme) | 852 | if (ctx->cfg.root_readme) |
| 728 | site_link("about", "about", NULL, hc(cmd, "about"), | 853 | site_link("about", "about", NULL, hc(ctx, "about"), |
| 729 | NULL, 0); | 854 | NULL, 0); |
| 730 | html("</td><td class='form'>"); | 855 | html("</td><td class='form'>"); |
| 731 | html("<form method='get' action='"); | 856 | html("<form method='get' action='"); |
| @@ -738,6 +863,12 @@ void cgit_print_pageheader(struct cgit_context *ctx) | |||
| 738 | html("</form>"); | 863 | html("</form>"); |
| 739 | } | 864 | } |
| 740 | html("</td></tr></table>\n"); | 865 | html("</td></tr></table>\n"); |
| 866 | if (ctx->qry.vpath) { | ||
| 867 | html("<div class='path'>"); | ||
| 868 | html("path: "); | ||
| 869 | cgit_print_path_crumbs(ctx, ctx->qry.vpath); | ||
| 870 | html("</div>"); | ||
| 871 | } | ||
| 741 | html("<div class='content'>"); | 872 | html("<div class='content'>"); |
| 742 | } | 873 | } |
| 743 | 874 | ||
| @@ -760,13 +891,18 @@ void cgit_print_snapshot_links(const char *repo, const char *head, | |||
| 760 | const char *hex, int snapshots) | 891 | const char *hex, int snapshots) |
| 761 | { | 892 | { |
| 762 | const struct cgit_snapshot_format* f; | 893 | const struct cgit_snapshot_format* f; |
| 894 | char *prefix; | ||
| 763 | char *filename; | 895 | char *filename; |
| 896 | unsigned char sha1[20]; | ||
| 764 | 897 | ||
| 898 | if (get_sha1(fmt("refs/tags/%s", hex), sha1) == 0 && | ||
| 899 | (hex[0] == 'v' || hex[0] == 'V') && isdigit(hex[1])) | ||
| 900 | hex++; | ||
| 901 | prefix = xstrdup(fmt("%s-%s", cgit_repobasename(repo), hex)); | ||
| 765 | for (f = cgit_snapshot_formats; f->suffix; f++) { | 902 | for (f = cgit_snapshot_formats; f->suffix; f++) { |
| 766 | if (!(snapshots & f->bit)) | 903 | if (!(snapshots & f->bit)) |
| 767 | continue; | 904 | continue; |
| 768 | filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, | 905 | filename = fmt("%s%s", prefix, f->suffix); |
| 769 | f->suffix); | ||
| 770 | cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename); | 906 | cgit_snapshot_link(filename, NULL, NULL, NULL, NULL, filename); |
| 771 | html("<br/>"); | 907 | html("<br/>"); |
| 772 | } | 908 | } |
