X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=combine-diff.c;h=9bd27f82ec1d7c313987325a4948a5eed8c9b799;hb=ece634d1478a9f1bf19eed8a6b7dee305fadd46e;hp=c45d7736592f483c5c454c9571bb62c1e7835707;hpb=740659519e0b30bc6b64f00ba69825294c40db07;p=git.git diff --git a/combine-diff.c b/combine-diff.c index c45d7736..9bd27f82 100644 --- a/combine-diff.c +++ b/combine-diff.c @@ -506,8 +506,8 @@ static void dump_sline(struct sline *sline, unsigned long cnt, int num_parent) while (1) { struct sline *sl = &sline[lno]; - int hunk_end; - int rlines; + unsigned long hunk_end; + unsigned long rlines; while (lno <= cnt && !(sline[lno].flag & mark)) lno++; if (cnt < lno) @@ -843,6 +843,7 @@ const char *diff_tree_combined_merge(const unsigned char *sha1, diffopts = *opt; diffopts.output_format = DIFF_FORMAT_NO_OUTPUT; + diffopts.with_raw = 0; diffopts.recursive = 1; /* count parents */ @@ -869,6 +870,17 @@ const char *diff_tree_combined_merge(const unsigned char *sha1, num_paths++; } if (num_paths) { + if (opt->with_raw) { + int saved_format = opt->output_format; + opt->output_format = DIFF_FORMAT_RAW; + for (p = paths; p; p = p->next) { + if (show_combined_diff(p, num_parent, dense, + header, opt)) + header = NULL; + } + opt->output_format = saved_format; + putchar(opt->line_termination); + } for (p = paths; p; p = p->next) { if (show_combined_diff(p, num_parent, dense, header, opt))