diff options
Diffstat (limited to 'diff-no-index.c')
-rw-r--r-- | diff-no-index.c | 66 |
1 files changed, 2 insertions, 64 deletions
diff --git a/diff-no-index.c b/diff-no-index.c index 0320605a..265709ba 100644 --- a/diff-no-index.c +++ b/diff-no-index.c @@ -97,27 +97,8 @@ static int queue_diff(struct diff_options *o, if (get_mode(name1, &mode1) || get_mode(name2, &mode2)) return -1; - if (mode1 && mode2 && S_ISDIR(mode1) != S_ISDIR(mode2)) { - struct diff_filespec *d1, *d2; - - if (S_ISDIR(mode1)) { - /* 2 is file that is created */ - d1 = noindex_filespec(NULL, 0); - d2 = noindex_filespec(name2, mode2); - name2 = NULL; - mode2 = 0; - } else { - /* 1 is file that is deleted */ - d1 = noindex_filespec(name1, mode1); - d2 = noindex_filespec(NULL, 0); - name1 = NULL; - mode1 = 0; - } - /* emit that file */ - diff_queue(&diff_queued_diff, d1, d2); - - /* and then let the entire directory be created or deleted */ - } + if (mode1 && mode2 && S_ISDIR(mode1) != S_ISDIR(mode2)) + return error("file/directory conflict: %s, %s", name1, name2); if (S_ISDIR(mode1) || S_ISDIR(mode2)) { struct strbuf buffer1 = STRBUF_INIT; @@ -201,50 +182,12 @@ static int queue_diff(struct diff_options *o, } } -/* append basename of F to D */ -static void append_basename(struct strbuf *path, const char *dir, const char *file) -{ - const char *tail = strrchr(file, '/'); - - strbuf_addstr(path, dir); - while (path->len && path->buf[path->len - 1] == '/') - path->len--; - strbuf_addch(path, '/'); - strbuf_addstr(path, tail ? tail + 1 : file); -} - -/* - * DWIM "diff D F" into "diff D/F F" and "diff F D" into "diff F D/F" - * Note that we append the basename of F to D/, so "diff a/b/file D" - * becomes "diff a/b/file D/file", not "diff a/b/file D/a/b/file". - */ -static void fixup_paths(const char **path, struct strbuf *replacement) -{ - unsigned int isdir0, isdir1; - - if (path[0] == file_from_standard_input || - path[1] == file_from_standard_input) - return; - isdir0 = is_directory(path[0]); - isdir1 = is_directory(path[1]); - if (isdir0 == isdir1) - return; - if (isdir0) { - append_basename(replacement, path[0], path[1]); - path[0] = replacement->buf; - } else { - append_basename(replacement, path[1], path[0]); - path[1] = replacement->buf; - } -} - void diff_no_index(struct rev_info *revs, int argc, const char **argv, const char *prefix) { int i, prefixlen; const char *paths[2]; - struct strbuf replacement = STRBUF_INIT; diff_setup(&revs->diffopt); for (i = 1; i < argc - 2; ) { @@ -274,9 +217,6 @@ void diff_no_index(struct rev_info *revs, p = xstrdup(prefix_filename(prefix, prefixlen, p)); paths[i] = p; } - - fixup_paths(paths, &replacement); - revs->diffopt.skip_stat_unmatch = 1; if (!revs->diffopt.output_format) revs->diffopt.output_format = DIFF_FORMAT_PATCH; @@ -295,8 +235,6 @@ void diff_no_index(struct rev_info *revs, diffcore_std(&revs->diffopt); diff_flush(&revs->diffopt); - strbuf_release(&replacement); - /* * The return code for --no-index imitates diff(1): * 0 = no changes, 1 = changes, else error |