X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/6a8749d3bd1570faa3dc07e80efc8fcef5953aa0..723469962b42de9f73960a883403cfdc422f176f:/ui-diff.c diff --git a/ui-diff.c b/ui-diff.c index 10330d3..afe1c90 100644 --- a/ui-diff.c +++ b/ui-diff.c @@ -31,22 +31,58 @@ static void print_line(char *line, int len) line[len-1] = c; } -static void filepair_cb(struct diff_filepair *pair) +static void header(unsigned char *sha1, char *path1, + unsigned char *sha2, char *path2) { - html(""); - html_txt(pair->two->path); - html(""); + char *abbrev1, *abbrev2; + if (is_null_sha1(sha1)) + path1 = "dev/null"; + if (is_null_sha1(sha2)) + path2 = "dev/null"; html(""); + html("
"); + html("diff --git a/"); + html_txt(path1); + html(" b/"); + html_txt(path2); + abbrev1 = xstrdup(find_unique_abbrev(sha1, DEFAULT_ABBREV)); + abbrev2 = xstrdup(find_unique_abbrev(sha2, DEFAULT_ABBREV)); + htmlf("\nindex %s..%s", abbrev1, abbrev2); + free(abbrev1); + free(abbrev2); + html("\n--- a/"); + html_txt(path1); + html("\n+++ b/"); + html_txt(path2); + html("
"); +} + +static void filepair_cb(struct diff_filepair *pair) +{ + header(pair->one->sha1, pair->one->path, + pair->two->sha1, pair->two->path); if (cgit_diff_files(pair->one->sha1, pair->two->sha1, print_line)) cgit_print_error("Error running diff"); html(""); } -void cgit_print_diff(const char *old_hex, const char *new_hex, char *path) +void cgit_print_diff(const char *head, const char *old_hex, const char *new_hex, char *path) { unsigned char sha1[20], sha2[20]; enum object_type type; unsigned long size; + struct commit *commit; + + if (head && !old_hex && !new_hex) { + get_sha1(head, sha1); + commit = lookup_commit_reference(sha1); + if (commit && !parse_commit(commit)) { + html(""); + cgit_diff_commit(commit, filepair_cb); + html("
"); + } + return; + } get_sha1(old_hex, sha1); get_sha1(new_hex, sha2); @@ -63,9 +99,8 @@ void cgit_print_diff(const char *old_hex, const char *new_hex, char *path) html(""); switch(type) { case OBJ_BLOB: - if (path) - htmlf("", path); html("");
%s
"); + header(sha1, path, sha2, path); if (cgit_diff_files(sha1, sha2, print_line)) cgit_print_error("Error running diff"); html("