Browse Source

[PATCH] diff: consolidate various calls into diffcore.

The three diff-* brothers had a sequence of calls into diffcore
that were almost identical.  Introduce a new diffcore_std()
function that takes all the necessary arguments to consolidate
it.  This will make later enhancements and changing the order of
diffcore application simpler.

Signed-off-by: Junio C Hamano <junkio@cox.net>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
maint
Junio C Hamano 20 years ago committed by Linus Torvalds
parent
commit
befe86392c
  1. 9
      diff-cache.c
  2. 9
      diff-files.c
  3. 7
      diff-tree.c
  4. 12
      diff.c
  5. 4
      diff.h

9
diff-cache.c

@ -240,12 +240,9 @@ int main(int argc, const char **argv) @@ -240,12 +240,9 @@ int main(int argc, const char **argv)
die("unable to read tree object %s", tree_name);

ret = diff_cache(active_cache, active_nr);
if (pathspec)
diffcore_pathspec(pathspec);
if (detect_rename)
diffcore_rename(detect_rename, diff_score_opt);
if (pickaxe)
diffcore_pickaxe(pickaxe, pickaxe_opts);
diffcore_std(pathspec,
detect_rename, diff_score_opt,
pickaxe, pickaxe_opts);
diff_flush(diff_output_format, 1);
return ret;
}

9
diff-files.c

@ -116,12 +116,9 @@ int main(int argc, const char **argv) @@ -116,12 +116,9 @@ int main(int argc, const char **argv)
show_modified(oldmode, mode, ce->sha1, null_sha1,
ce->name);
}
if (1 < argc)
diffcore_pathspec(argv + 1);
if (detect_rename)
diffcore_rename(detect_rename, diff_score_opt);
if (pickaxe)
diffcore_pickaxe(pickaxe, pickaxe_opts);
diffcore_std(argv + 1,
detect_rename, diff_score_opt,
pickaxe, pickaxe_opts);
diff_flush(diff_output_format, 1);
return 0;
}

7
diff-tree.c

@ -261,10 +261,9 @@ static void call_diff_setup(void) @@ -261,10 +261,9 @@ static void call_diff_setup(void)

static int call_diff_flush(void)
{
if (detect_rename)
diffcore_rename(detect_rename, diff_score_opt);
if (pickaxe)
diffcore_pickaxe(pickaxe, pickaxe_opts);
diffcore_std(0,
detect_rename, diff_score_opt,
pickaxe, pickaxe_opts);
if (diff_queue_is_empty()) {
diff_flush(DIFF_FORMAT_NO_OUTPUT, 0);
return 0;

12
diff.c

@ -887,6 +887,18 @@ void diff_flush(int diff_output_style, int resolve_rename_copy) @@ -887,6 +887,18 @@ void diff_flush(int diff_output_style, int resolve_rename_copy)
q->nr = q->alloc = 0;
}

void diffcore_std(const char **paths,
int detect_rename, int rename_score,
const char *pickaxe, int pickaxe_opts)
{
if (paths && paths[0])
diffcore_pathspec(paths);
if (detect_rename)
diffcore_rename(detect_rename, rename_score);
if (pickaxe)
diffcore_pickaxe(pickaxe, pickaxe_opts);
}

void diff_addremove(int addremove, unsigned mode,
const unsigned char *sha1,
const char *base, const char *path)

4
diff.h

@ -43,6 +43,10 @@ extern void diffcore_pickaxe(const char *needle, int opts); @@ -43,6 +43,10 @@ extern void diffcore_pickaxe(const char *needle, int opts);

extern void diffcore_pathspec(const char **pathspec);

extern void diffcore_std(const char **paths,
int detect_rename, int rename_score,
const char *pickaxe, int pickaxe_opts);

extern int diff_queue_is_empty(void);

#define DIFF_FORMAT_HUMAN 0

Loading…
Cancel
Save