-rw-r--r-- | ui-diff.c | 15 |
1 files changed, 13 insertions, 2 deletions
@@ -10,4 +10,5 @@ #include "html.h" #include "ui-shared.h" +#include "ui-ssdiff.h" unsigned char old_rev_sha1[20]; @@ -33,4 +34,5 @@ static struct fileinfo { } *items; +static int use_ssdiff = 0; static void print_fileinfo(struct fileinfo *info) @@ -245,4 +247,6 @@ static void header(unsigned char *sha1, char *path1, int mode1, } html("</div>"); + if (use_ssdiff) + cgit_ssdiff_header(); } @@ -252,7 +256,12 @@ static void filepair_cb(struct diff_filepair *pair) unsigned long new_size = 0; int binary = 0; + linediff_fn print_line_fn = print_line; header(pair->one->sha1, pair->one->path, pair->one->mode, pair->two->sha1, pair->two->path, pair->two->mode); + if (use_ssdiff) { + cgit_ssdiff_header(); + print_line_fn = cgit_ssdiff_line_cb; + } if (S_ISGITLINK(pair->one->mode) || S_ISGITLINK(pair->two->mode)) { if (S_ISGITLINK(pair->one->mode)) @@ -262,9 +271,11 @@ static void filepair_cb(struct diff_filepair *pair) return; } - if (cgit_diff_files(pair->one->sha1, pair->two->sha1, &old_size, - &new_size, &binary, print_line)) + if (cgit_diff_files(pair->one->sha1, pair->two->sha1, &old_size, + &new_size, &binary, print_line_fn)) cgit_print_error("Error running diff"); if (binary) html("Binary files differ"); + if (use_ssdiff) + cgit_ssdiff_footer(); } |