X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/38a0f9cd89c4c5a97bd5b38e7b56da809a00fccb..5b94c96a83f19a0175a8e1699d71080965793cc2:/ui-diff.c diff --git a/ui-diff.c b/ui-diff.c index 96106af..7ec5701 100644 --- a/ui-diff.c +++ b/ui-diff.c @@ -31,15 +31,72 @@ static void print_line(char *line, int len) line[len-1] = c; } -void cgit_print_diff(const char *old_hex, const char *new_hex) +static void header(unsigned char *sha1, char *path1, + unsigned char *sha2, char *path2) +{ + char *abbrev1, *abbrev2; + + 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) { unsigned char sha1[20], sha2[20]; + enum object_type type; + unsigned long size; get_sha1(old_hex, sha1); get_sha1(new_hex, sha2); - html("
"); - if (cgit_diff_files(sha1, sha2, print_line)) - cgit_print_error("Error running diff"); + type = sha1_object_info(sha1, &size); + if (type == OBJ_BAD) { + type = sha1_object_info(sha2, &size); + if (type == OBJ_BAD) { + cgit_print_error(fmt("Bad object names: %s, %s", old_hex, new_hex)); + return; + } + } + + html(""); + switch(type) { + case OBJ_BLOB: + html(""); + break; + case OBJ_TREE: + cgit_diff_tree(sha1, sha2, filepair_cb); + break; + default: + cgit_print_error(fmt("Unhandled object type: %s", + typename(type))); + break; + } html("
"); + header(sha1, path, sha2, path); + if (cgit_diff_files(sha1, sha2, print_line)) + cgit_print_error("Error running diff"); + html("
"); }