X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/bf8c7a4c93bdc95d841b25a60644cca3ec124625..4b4a62d507adc61e20e75e2748301ef307a6c95f:/ui-diff.c
diff --git a/ui-diff.c b/ui-diff.c
index 868ceec..1115518 100644
--- a/ui-diff.c
+++ b/ui-diff.c
@@ -7,6 +7,7 @@
*/
#include "cgit.h"
+#include "ui-diff.h"
#include "html.h"
#include "ui-shared.h"
#include "ui-ssdiff.h"
@@ -97,10 +98,12 @@ static void print_fileinfo(struct fileinfo *info)
htmlf("
", class);
cgit_diff_link(info->new_path, NULL, NULL, ctx.qry.head, ctx.qry.sha1,
ctx.qry.sha2, info->new_path, 0);
- if (info->status == DIFF_STATUS_COPIED || info->status == DIFF_STATUS_RENAMED)
- htmlf(" (%s from %s)",
- info->status == DIFF_STATUS_COPIED ? "copied" : "renamed",
- info->old_path);
+ if (info->status == DIFF_STATUS_COPIED || info->status == DIFF_STATUS_RENAMED) {
+ htmlf(" (%s from ",
+ info->status == DIFF_STATUS_COPIED ? "copied" : "renamed");
+ html_txt(info->old_path);
+ html(")");
+ }
html(" | ");
if (info->binary) {
htmlf("bin | %ld -> %ld bytes",
@@ -164,8 +167,9 @@ static void inspect_filepair(struct diff_filepair *pair)
total_rems += lines_removed;
}
-void cgit_print_diffstat(const unsigned char *old_sha1,
- const unsigned char *new_sha1, const char *prefix)
+static void cgit_print_diffstat(const unsigned char *old_sha1,
+ const unsigned char *new_sha1,
+ const char *prefix)
{
int i;
@@ -182,7 +186,7 @@ void cgit_print_diffstat(const unsigned char *old_sha1,
max_changes = 0;
cgit_diff_tree(old_sha1, new_sha1, inspect_filepair, prefix,
ctx.qry.ignorews);
- for(i = 0; i");
html(" ");
@@ -227,11 +231,6 @@ static void header(unsigned char *sha1, char *path1, int mode1,
html(" b/");
html_txt(path2);
- if (is_null_sha1(sha1))
- path1 = "dev/null";
- if (is_null_sha1(sha2))
- path2 = "dev/null";
-
if (mode1 == 0)
htmlf(" new file mode %.6o", mode2);
@@ -249,13 +248,21 @@ static void header(unsigned char *sha1, char *path1, int mode1,
if (mode2 != mode1)
htmlf("..%.6o", mode2);
}
- html(" --- a/");
+ if (is_null_sha1(sha1)) {
+ path1 = "dev/null";
+ html(" --- /");
+ } else
+ html(" --- a/");
if (mode1 != 0)
cgit_tree_link(path1, NULL, NULL, ctx.qry.head,
sha1_to_hex(old_rev_sha1), path1);
else
html_txt(path1);
- html(" +++ b/");
+ if (is_null_sha1(sha2)) {
+ path2 = "dev/null";
+ html(" +++ /");
+ } else
+ html(" +++ b/");
if (mode2 != 0)
cgit_tree_link(path2, NULL, NULL, ctx.qry.head,
sha1_to_hex(new_rev_sha1), path2);
@@ -339,9 +346,7 @@ void cgit_print_diff_ctrls()
html(" mode: | ");
html("");
html(" | ");
@@ -393,8 +398,7 @@ void cgit_print_diff(const char *new_rev, const char *old_rev,
}
}
- if ((ctx.qry.ssdiff && !ctx.cfg.ssdiff) || (!ctx.qry.ssdiff && ctx.cfg.ssdiff))
- use_ssdiff = 1;
+ use_ssdiff = ctx.qry.has_ssdiff ? ctx.qry.ssdiff : ctx.cfg.ssdiff;
if (show_ctrls)
cgit_print_diff_ctrls();
|