diff options
| author | 2010-06-11 03:15:51 (JST) | |
|---|---|---|
| committer | 2010-06-19 20:00:07 (JST) | |
| commit | d20313e3daf855ee5d4808e050f54614c200d7b1 (patch) | |
| tree | 5c462f3ba6ec97c0b099a309dfd0fa87d03fbc72 | |
| parent | 6180e6169d6e87a3bea7e4da835dca17f93e5cfd (diff) | |
| download | cgit-d20313e3daf855ee5d4808e050f54614c200d7b1.zip cgit-d20313e3daf855ee5d4808e050f54614c200d7b1.tar.gz | |
ui-diff: Add links to increase/decrease number of context lines in diffs
Add two links to the "Diffstat" line to show more/less context lines in the
generated diff.
To support this, cgit_commit_link() and cgit_diff_link() has learned to
preserve the ctx.qry.context variable.
Signed-off-by: Johan Herland <johan@herland.net>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
| -rw-r--r-- | ui-diff.c | 10 | ||||
| -rw-r--r-- | ui-shared.c | 14 | 
2 files changed, 23 insertions, 1 deletions
| @@ -156,13 +156,21 @@ static void inspect_filepair(struct diff_filepair *pair) | |||
| 156 | void cgit_print_diffstat(const unsigned char *old_sha1, | 156 | void cgit_print_diffstat(const unsigned char *old_sha1, | 
| 157 | const unsigned char *new_sha1, const char *prefix) | 157 | const unsigned char *new_sha1, const char *prefix) | 
| 158 | { | 158 | { | 
| 159 | int i; | 159 | int i, save_context = ctx.qry.context; | 
| 160 | 160 | ||
| 161 | html("<div class='diffstat-header'>"); | 161 | html("<div class='diffstat-header'>"); | 
| 162 | cgit_diff_link("Diffstat", NULL, NULL, ctx.qry.head, ctx.qry.sha1, | 162 | cgit_diff_link("Diffstat", NULL, NULL, ctx.qry.head, ctx.qry.sha1, | 
| 163 | ctx.qry.sha2, NULL, 0); | 163 | ctx.qry.sha2, NULL, 0); | 
| 164 | if (prefix) | 164 | if (prefix) | 
| 165 | htmlf(" (limited to '%s')", prefix); | 165 | htmlf(" (limited to '%s')", prefix); | 
| 166 | html(" ("); | ||
| 167 | ctx.qry.context = (save_context > 0 ? save_context : 3) << 1; | ||
| 168 | cgit_self_link("more", NULL, NULL, &ctx); | ||
| 169 | html("/"); | ||
| 170 | ctx.qry.context = (save_context > 3 ? save_context : 3) >> 1; | ||
| 171 | cgit_self_link("less", NULL, NULL, &ctx); | ||
| 172 | ctx.qry.context = save_context; | ||
| 173 | html(" context)"); | ||
| 166 | html("</div>"); | 174 | html("</div>"); | 
| 167 | html("<table summary='diffstat' class='diffstat'>"); | 175 | html("<table summary='diffstat' class='diffstat'>"); | 
| 168 | max_changes = 0; | 176 | max_changes = 0; | 
| diff --git a/ui-shared.c b/ui-shared.c index e991799..c99bcec 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
| @@ -341,6 +341,13 @@ void cgit_commit_link(char *name, const char *title, const char *class, | |||
| 341 | if ((ctx.qry.ssdiff && !toggle_ssdiff) || (!ctx.qry.ssdiff && toggle_ssdiff)) { | 341 | if ((ctx.qry.ssdiff && !toggle_ssdiff) || (!ctx.qry.ssdiff && toggle_ssdiff)) { | 
| 342 | html(delim); | 342 | html(delim); | 
| 343 | html("ss=1"); | 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 = "&"; | ||
| 344 | } | 351 | } | 
| 345 | html("'>"); | 352 | html("'>"); | 
| 346 | html_txt(name); | 353 | html_txt(name); | 
| @@ -382,6 +389,13 @@ void cgit_diff_link(const char *name, const char *title, const char *class, | |||
| 382 | if ((ctx.qry.ssdiff && !toggle_ssdiff) || (!ctx.qry.ssdiff && toggle_ssdiff)) { | 389 | if ((ctx.qry.ssdiff && !toggle_ssdiff) || (!ctx.qry.ssdiff && toggle_ssdiff)) { | 
| 383 | html(delim); | 390 | html(delim); | 
| 384 | html("ss=1"); | 391 | html("ss=1"); | 
| 392 | delim = "&"; | ||
| 393 | } | ||
| 394 | if (ctx.qry.context > 0 && ctx.qry.context != 3) { | ||
| 395 | html(delim); | ||
| 396 | html("context="); | ||
| 397 | htmlf("%d", ctx.qry.context); | ||
| 398 | delim = "&"; | ||
| 385 | } | 399 | } | 
| 386 | html("'>"); | 400 | html("'>"); | 
| 387 | html_txt(name); | 401 | html_txt(name); | 
