summaryrefslogtreecommitdiffabout
path: root/ui-shared.c
authorLars Hjemli <hjemli@gmail.com>2008-11-29 17:39:41 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-11-29 17:39:41 (UTC)
commit0274b57d55a12ed38259757dbfae96b79cfa2e0b (patch) (unidiff)
tree34c7204f88168f791ef48f603bb8ab66e9df523c /ui-shared.c
parent7b5cee65fd9cf31e4f19ce4ff613778cb95512a9 (diff)
downloadcgit-0274b57d55a12ed38259757dbfae96b79cfa2e0b.zip
cgit-0274b57d55a12ed38259757dbfae96b79cfa2e0b.tar.gz
cgit-0274b57d55a12ed38259757dbfae96b79cfa2e0b.tar.bz2
ui-log: add support for showing the full commit message
Some users prefer to see the full message, so to make these users happy the new querystring parameter "showmsg" can be used to print the full commit message per log entry. A link is provided in the log heading to make this function accessible, and all links and forms tries to preserve the users preference. Note: the new link is not displayed on the summary page since the point of the summary page is to be a summary, but it is still obeyed if specified manually. 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.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/ui-shared.c b/ui-shared.c
index 224e5f3..dc39e64 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -236,120 +236,126 @@ static char *repolink(char *title, char *class, char *page, char *head,
236 html(delim); 236 html(delim);
237 html("h="); 237 html("h=");
238 html_url_arg(head); 238 html_url_arg(head);
239 delim = "&amp;"; 239 delim = "&amp;";
240 } 240 }
241 return fmt("%s", delim); 241 return fmt("%s", delim);
242} 242}
243 243
244static void reporevlink(char *page, char *name, char *title, char *class, 244static void reporevlink(char *page, char *name, char *title, char *class,
245 char *head, char *rev, char *path) 245 char *head, char *rev, char *path)
246{ 246{
247 char *delim; 247 char *delim;
248 248
249 delim = repolink(title, class, page, head, path); 249 delim = repolink(title, class, page, head, path);
250 if (rev && strcmp(rev, ctx.qry.head)) { 250 if (rev && strcmp(rev, ctx.qry.head)) {
251 html(delim); 251 html(delim);
252 html("id="); 252 html("id=");
253 html_url_arg(rev); 253 html_url_arg(rev);
254 } 254 }
255 html("'>"); 255 html("'>");
256 html_txt(name); 256 html_txt(name);
257 html("</a>"); 257 html("</a>");
258} 258}
259 259
260void cgit_summary_link(char *name, char *title, char *class, char *head) 260void cgit_summary_link(char *name, char *title, char *class, char *head)
261{ 261{
262 reporevlink(NULL, name, title, class, head, NULL, NULL); 262 reporevlink(NULL, name, title, class, head, NULL, NULL);
263} 263}
264 264
265void cgit_tag_link(char *name, char *title, char *class, char *head, 265void cgit_tag_link(char *name, char *title, char *class, char *head,
266 char *rev) 266 char *rev)
267{ 267{
268 reporevlink("tag", name, title, class, head, rev, NULL); 268 reporevlink("tag", name, title, class, head, rev, NULL);
269} 269}
270 270
271void cgit_tree_link(char *name, char *title, char *class, char *head, 271void cgit_tree_link(char *name, char *title, char *class, char *head,
272 char *rev, char *path) 272 char *rev, char *path)
273{ 273{
274 reporevlink("tree", name, title, class, head, rev, path); 274 reporevlink("tree", name, title, class, head, rev, path);
275} 275}
276 276
277void cgit_plain_link(char *name, char *title, char *class, char *head, 277void cgit_plain_link(char *name, char *title, char *class, char *head,
278 char *rev, char *path) 278 char *rev, char *path)
279{ 279{
280 reporevlink("plain", name, title, class, head, rev, path); 280 reporevlink("plain", name, title, class, head, rev, path);
281} 281}
282 282
283void cgit_log_link(char *name, char *title, char *class, char *head, 283void 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
288 delim = repolink(title, class, "log", head, path); 289 delim = repolink(title, class, "log", head, path);
289 if (rev && strcmp(rev, ctx.qry.head)) { 290 if (rev && strcmp(rev, ctx.qry.head)) {
290 html(delim); 291 html(delim);
291 html("id="); 292 html("id=");
292 html_url_arg(rev); 293 html_url_arg(rev);
293 delim = "&"; 294 delim = "&";
294 } 295 }
295 if (grep && pattern) { 296 if (grep && pattern) {
296 html(delim); 297 html(delim);
297 html("qt="); 298 html("qt=");
298 html_url_arg(grep); 299 html_url_arg(grep);
299 delim = "&"; 300 delim = "&";
300 html(delim); 301 html(delim);
301 html("q="); 302 html("q=");
302 html_url_arg(pattern); 303 html_url_arg(pattern);
303 } 304 }
304 if (ofs > 0) { 305 if (ofs > 0) {
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);
311 html("</a>"); 317 html("</a>");
312} 318}
313 319
314void cgit_commit_link(char *name, char *title, char *class, char *head, 320void cgit_commit_link(char *name, char *title, char *class, char *head,
315 char *rev) 321 char *rev)
316{ 322{
317 if (strlen(name) > ctx.cfg.max_msg_len && ctx.cfg.max_msg_len >= 15) { 323 if (strlen(name) > ctx.cfg.max_msg_len && ctx.cfg.max_msg_len >= 15) {
318 name[ctx.cfg.max_msg_len] = '\0'; 324 name[ctx.cfg.max_msg_len] = '\0';
319 name[ctx.cfg.max_msg_len - 1] = '.'; 325 name[ctx.cfg.max_msg_len - 1] = '.';
320 name[ctx.cfg.max_msg_len - 2] = '.'; 326 name[ctx.cfg.max_msg_len - 2] = '.';
321 name[ctx.cfg.max_msg_len - 3] = '.'; 327 name[ctx.cfg.max_msg_len - 3] = '.';
322 } 328 }
323 reporevlink("commit", name, title, class, head, rev, NULL); 329 reporevlink("commit", name, title, class, head, rev, NULL);
324} 330}
325 331
326void cgit_refs_link(char *name, char *title, char *class, char *head, 332void cgit_refs_link(char *name, char *title, char *class, char *head,
327 char *rev, char *path) 333 char *rev, char *path)
328{ 334{
329 reporevlink("refs", name, title, class, head, rev, path); 335 reporevlink("refs", name, title, class, head, rev, path);
330} 336}
331 337
332void cgit_snapshot_link(char *name, char *title, char *class, char *head, 338void cgit_snapshot_link(char *name, char *title, char *class, char *head,
333 char *rev, char *archivename) 339 char *rev, char *archivename)
334{ 340{
335 reporevlink("snapshot", name, title, class, head, rev, archivename); 341 reporevlink("snapshot", name, title, class, head, rev, archivename);
336} 342}
337 343
338void cgit_diff_link(char *name, char *title, char *class, char *head, 344void cgit_diff_link(char *name, char *title, char *class, char *head,
339 char *new_rev, char *old_rev, char *path) 345 char *new_rev, char *old_rev, char *path)
340{ 346{
341 char *delim; 347 char *delim;
342 348
343 delim = repolink(title, class, "diff", head, path); 349 delim = repolink(title, class, "diff", head, path);
344 if (new_rev && strcmp(new_rev, ctx.qry.head)) { 350 if (new_rev && strcmp(new_rev, ctx.qry.head)) {
345 html(delim); 351 html(delim);
346 html("id="); 352 html("id=");
347 html_url_arg(new_rev); 353 html_url_arg(new_rev);
348 delim = "&amp;"; 354 delim = "&amp;";
349 } 355 }
350 if (old_rev) { 356 if (old_rev) {
351 html(delim); 357 html(delim);
352 html("id2="); 358 html("id2=");
353 html_url_arg(old_rev); 359 html_url_arg(old_rev);
354 } 360 }
355 html("'>"); 361 html("'>");
@@ -523,163 +529,165 @@ int print_archive_ref(const char *refname, const unsigned char *sha1,
523 if (prefixcmp(refname, "refs/archives")) 529 if (prefixcmp(refname, "refs/archives"))
524 return 0; 530 return 0;
525 strncpy(buf, refname+14, sizeof(buf)); 531 strncpy(buf, refname+14, sizeof(buf));
526 obj = parse_object(sha1); 532 obj = parse_object(sha1);
527 if (!obj) 533 if (!obj)
528 return 1; 534 return 1;
529 if (obj->type == OBJ_TAG) { 535 if (obj->type == OBJ_TAG) {
530 tag = lookup_tag(sha1); 536 tag = lookup_tag(sha1);
531 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 537 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
532 return 0; 538 return 0;
533 hashcpy(fileid, tag->tagged->sha1); 539 hashcpy(fileid, tag->tagged->sha1);
534 } else if (obj->type != OBJ_BLOB) { 540 } else if (obj->type != OBJ_BLOB) {
535 return 0; 541 return 0;
536 } else { 542 } else {
537 hashcpy(fileid, sha1); 543 hashcpy(fileid, sha1);
538 } 544 }
539 if (!*header) { 545 if (!*header) {
540 html("<h1>download</h1>\n"); 546 html("<h1>download</h1>\n");
541 *header = 1; 547 *header = 1;
542 } 548 }
543 url = cgit_pageurl(ctx.qry.repo, "blob", 549 url = cgit_pageurl(ctx.qry.repo, "blob",
544 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid), 550 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid),
545 buf)); 551 buf));
546 html_link_open(url, NULL, "menu"); 552 html_link_open(url, NULL, "menu");
547 html_txt(strlpart(buf, 20)); 553 html_txt(strlpart(buf, 20));
548 html_link_close(); 554 html_link_close();
549 return 0; 555 return 0;
550} 556}
551 557
552void add_hidden_formfields(int incl_head, int incl_search, char *page) 558void add_hidden_formfields(int incl_head, int incl_search, char *page)
553{ 559{
554 char *url; 560 char *url;
555 561
556 if (!ctx.cfg.virtual_root) { 562 if (!ctx.cfg.virtual_root) {
557 url = fmt("%s/%s", ctx.qry.repo, page); 563 url = fmt("%s/%s", ctx.qry.repo, page);
558 if (ctx.qry.path) 564 if (ctx.qry.path)
559 url = fmt("%s/%s", url, ctx.qry.path); 565 url = fmt("%s/%s", url, ctx.qry.path);
560 html_hidden("url", url); 566 html_hidden("url", url);
561 } 567 }
562 568
563 if (incl_head && ctx.qry.head && ctx.repo->defbranch && 569 if (incl_head && ctx.qry.head && ctx.repo->defbranch &&
564 strcmp(ctx.qry.head, ctx.repo->defbranch)) 570 strcmp(ctx.qry.head, ctx.repo->defbranch))
565 html_hidden("h", ctx.qry.head); 571 html_hidden("h", ctx.qry.head);
566 572
567 if (ctx.qry.sha1) 573 if (ctx.qry.sha1)
568 html_hidden("id", ctx.qry.sha1); 574 html_hidden("id", ctx.qry.sha1);
569 if (ctx.qry.sha2) 575 if (ctx.qry.sha2)
570 html_hidden("id2", ctx.qry.sha2); 576 html_hidden("id2", ctx.qry.sha2);
577 if (ctx.qry.showmsg)
578 html_hidden("showmsg", "1");
571 579
572 if (incl_search) { 580 if (incl_search) {
573 if (ctx.qry.grep) 581 if (ctx.qry.grep)
574 html_hidden("qt", ctx.qry.grep); 582 html_hidden("qt", ctx.qry.grep);
575 if (ctx.qry.search) 583 if (ctx.qry.search)
576 html_hidden("q", ctx.qry.search); 584 html_hidden("q", ctx.qry.search);
577 } 585 }
578} 586}
579 587
580char *hc(struct cgit_cmd *cmd, const char *page) 588char *hc(struct cgit_cmd *cmd, const char *page)
581{ 589{
582 return (strcmp(cmd->name, page) ? NULL : "active"); 590 return (strcmp(cmd->name, page) ? NULL : "active");
583} 591}
584 592
585void cgit_print_pageheader(struct cgit_context *ctx) 593void cgit_print_pageheader(struct cgit_context *ctx)
586{ 594{
587 struct cgit_cmd *cmd = cgit_get_cmd(ctx); 595 struct cgit_cmd *cmd = cgit_get_cmd(ctx);
588 596
589 html("<table id='header'>\n"); 597 html("<table id='header'>\n");
590 html("<tr>\n"); 598 html("<tr>\n");
591 html("<td class='logo' rowspan='2'><a href='"); 599 html("<td class='logo' rowspan='2'><a href='");
592 if (ctx->cfg.logo_link) 600 if (ctx->cfg.logo_link)
593 html_attr(ctx->cfg.logo_link); 601 html_attr(ctx->cfg.logo_link);
594 else 602 else
595 html_attr(cgit_rooturl()); 603 html_attr(cgit_rooturl());
596 html("'><img src='"); 604 html("'><img src='");
597 html_attr(ctx->cfg.logo); 605 html_attr(ctx->cfg.logo);
598 html("' alt='cgit logo'/></a></td>\n"); 606 html("' alt='cgit logo'/></a></td>\n");
599 607
600 html("<td class='main'>"); 608 html("<td class='main'>");
601 if (ctx->repo) { 609 if (ctx->repo) {
602 cgit_index_link("index", NULL, NULL, NULL, 0); 610 cgit_index_link("index", NULL, NULL, NULL, 0);
603 html(" : "); 611 html(" : ");
604 cgit_summary_link(ctx->repo->name, ctx->repo->name, NULL, NULL); 612 cgit_summary_link(ctx->repo->name, ctx->repo->name, NULL, NULL);
605 html("</td><td class='form'>"); 613 html("</td><td class='form'>");
606 html("<form method='get' action=''>\n"); 614 html("<form method='get' action=''>\n");
607 add_hidden_formfields(0, 1, ctx->qry.page); 615 add_hidden_formfields(0, 1, ctx->qry.page);
608 html("<select name='h' onchange='this.form.submit();'>\n"); 616 html("<select name='h' onchange='this.form.submit();'>\n");
609 for_each_branch_ref(print_branch_option, ctx->qry.head); 617 for_each_branch_ref(print_branch_option, ctx->qry.head);
610 html("</select> "); 618 html("</select> ");
611 html("<input type='submit' name='' value='switch'/>"); 619 html("<input type='submit' name='' value='switch'/>");
612 html("</form>"); 620 html("</form>");
613 } else 621 } else
614 html_txt(ctx->cfg.root_title); 622 html_txt(ctx->cfg.root_title);
615 html("</td></tr>\n"); 623 html("</td></tr>\n");
616 624
617 html("<tr><td class='sub'>"); 625 html("<tr><td class='sub'>");
618 if (ctx->repo) { 626 if (ctx->repo) {
619 html_txt(ctx->repo->desc); 627 html_txt(ctx->repo->desc);
620 html("</td><td class='sub right'>"); 628 html("</td><td class='sub right'>");
621 html_txt(ctx->repo->owner); 629 html_txt(ctx->repo->owner);
622 } else { 630 } else {
623 if (ctx->cfg.root_desc) 631 if (ctx->cfg.root_desc)
624 html_txt(ctx->cfg.root_desc); 632 html_txt(ctx->cfg.root_desc);
625 else if (ctx->cfg.index_info) 633 else if (ctx->cfg.index_info)
626 html_include(ctx->cfg.index_info); 634 html_include(ctx->cfg.index_info);
627 } 635 }
628 html("</td></tr></table>\n"); 636 html("</td></tr></table>\n");
629 637
630 html("<table class='tabs'><tr><td>\n"); 638 html("<table class='tabs'><tr><td>\n");
631 if (ctx->repo) { 639 if (ctx->repo) {
632 cgit_summary_link("summary", NULL, hc(cmd, "summary"), 640 cgit_summary_link("summary", NULL, hc(cmd, "summary"),
633 ctx->qry.head); 641 ctx->qry.head);
634 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, 642 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head,
635 ctx->qry.sha1, NULL); 643 ctx->qry.sha1, NULL);
636 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, 644 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head,
637 NULL, NULL, 0, NULL, NULL); 645 NULL, NULL, 0, NULL, NULL, ctx->qry.showmsg);
638 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, 646 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head,
639 ctx->qry.sha1, NULL); 647 ctx->qry.sha1, NULL);
640 cgit_commit_link("commit", NULL, hc(cmd, "commit"), 648 cgit_commit_link("commit", NULL, hc(cmd, "commit"),
641 ctx->qry.head, ctx->qry.sha1); 649 ctx->qry.head, ctx->qry.sha1);
642 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, 650 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head,
643 ctx->qry.sha1, ctx->qry.sha2, NULL); 651 ctx->qry.sha1, ctx->qry.sha2, NULL);
644 if (ctx->repo->readme) 652 if (ctx->repo->readme)
645 reporevlink("about", "about", NULL, 653 reporevlink("about", "about", NULL,
646 hc(cmd, "about"), ctx->qry.head, NULL, 654 hc(cmd, "about"), ctx->qry.head, NULL,
647 NULL); 655 NULL);
648 html("</td><td class='form'>"); 656 html("</td><td class='form'>");
649 html("<form class='right' method='get' action='"); 657 html("<form class='right' method='get' action='");
650 if (ctx->cfg.virtual_root) 658 if (ctx->cfg.virtual_root)
651 html_url_path(cgit_fileurl(ctx->qry.repo, "log", 659 html_url_path(cgit_fileurl(ctx->qry.repo, "log",
652 ctx->qry.path, NULL)); 660 ctx->qry.path, NULL));
653 html("'>\n"); 661 html("'>\n");
654 add_hidden_formfields(1, 0, "log"); 662 add_hidden_formfields(1, 0, "log");
655 html("<select name='qt'>\n"); 663 html("<select name='qt'>\n");
656 html_option("grep", "log msg", ctx->qry.grep); 664 html_option("grep", "log msg", ctx->qry.grep);
657 html_option("author", "author", ctx->qry.grep); 665 html_option("author", "author", ctx->qry.grep);
658 html_option("committer", "committer", ctx->qry.grep); 666 html_option("committer", "committer", ctx->qry.grep);
659 html("</select>\n"); 667 html("</select>\n");
660 html("<input class='txt' type='text' size='10' name='q' value='"); 668 html("<input class='txt' type='text' size='10' name='q' value='");
661 html_attr(ctx->qry.search); 669 html_attr(ctx->qry.search);
662 html("'/>\n"); 670 html("'/>\n");
663 html("<input type='submit' value='search'/>\n"); 671 html("<input type='submit' value='search'/>\n");
664 html("</form>\n"); 672 html("</form>\n");
665 } else { 673 } else {
666 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0); 674 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL, 0);
667 if (ctx->cfg.root_readme) 675 if (ctx->cfg.root_readme)
668 site_link("about", "about", NULL, hc(cmd, "about"), 676 site_link("about", "about", NULL, hc(cmd, "about"),
669 NULL, 0); 677 NULL, 0);
670 html("</td><td class='form'>"); 678 html("</td><td class='form'>");
671 html("<form method='get' action='"); 679 html("<form method='get' action='");
672 html_attr(cgit_rooturl()); 680 html_attr(cgit_rooturl());
673 html("'>\n"); 681 html("'>\n");
674 html("<input type='text' name='q' size='10' value='"); 682 html("<input type='text' name='q' size='10' value='");
675 html_attr(ctx->qry.search); 683 html_attr(ctx->qry.search);
676 html("'/>\n"); 684 html("'/>\n");
677 html("<input type='submit' value='search'/>\n"); 685 html("<input type='submit' value='search'/>\n");
678 html("</form>"); 686 html("</form>");
679 } 687 }
680 html("</td></tr></table>\n"); 688 html("</td></tr></table>\n");
681 html("<div class='content'>"); 689 html("<div class='content'>");
682} 690}
683 691
684void cgit_print_filemode(unsigned short mode) 692void cgit_print_filemode(unsigned short mode)
685{ 693{