X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/f8f6e1fe789e9dbcea40a0f8d5ebfb019c2a1a19..c6fe94e02a3963d4fddaf09cfc3e3dc1e186a881:/ui-diff.c
diff --git a/ui-diff.c b/ui-diff.c
index 868ceec..3d46da2 100644
--- a/ui-diff.c
+++ b/ui-diff.c
@@ -97,10 +97,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",
@@ -227,11 +229,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 +246,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 +344,7 @@ void cgit_print_diff_ctrls()
html(" | mode: | ");
html("");
html(" | ");
@@ -393,8 +396,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();