Merge branch 'ph/diffopts'
* ph/diffopts: Reorder diff_opt_parse options more logically per topics. Make the diff_options bitfields be an unsigned with explicit masks. Use OPT_BIT in builtin-pack-refs Use OPT_BIT in builtin-for-each-ref Use OPT_SET_INT and OPT_BIT in builtin-branch parse-options new features.
This commit is contained in:
commit
e6cb314c08
@ -335,7 +335,7 @@ static struct origin *find_origin(struct scoreboard *sb,
|
|||||||
* same and diff-tree is fairly efficient about this.
|
* same and diff-tree is fairly efficient about this.
|
||||||
*/
|
*/
|
||||||
diff_setup(&diff_opts);
|
diff_setup(&diff_opts);
|
||||||
diff_opts.recursive = 1;
|
DIFF_OPT_SET(&diff_opts, RECURSIVE);
|
||||||
diff_opts.detect_rename = 0;
|
diff_opts.detect_rename = 0;
|
||||||
diff_opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
diff_opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
||||||
paths[0] = origin->path;
|
paths[0] = origin->path;
|
||||||
@ -409,7 +409,7 @@ static struct origin *find_rename(struct scoreboard *sb,
|
|||||||
const char *paths[2];
|
const char *paths[2];
|
||||||
|
|
||||||
diff_setup(&diff_opts);
|
diff_setup(&diff_opts);
|
||||||
diff_opts.recursive = 1;
|
DIFF_OPT_SET(&diff_opts, RECURSIVE);
|
||||||
diff_opts.detect_rename = DIFF_DETECT_RENAME;
|
diff_opts.detect_rename = DIFF_DETECT_RENAME;
|
||||||
diff_opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
diff_opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
||||||
diff_opts.single_follow = origin->path;
|
diff_opts.single_follow = origin->path;
|
||||||
@ -1075,7 +1075,7 @@ static int find_copy_in_parent(struct scoreboard *sb,
|
|||||||
return 1; /* nothing remains for this target */
|
return 1; /* nothing remains for this target */
|
||||||
|
|
||||||
diff_setup(&diff_opts);
|
diff_setup(&diff_opts);
|
||||||
diff_opts.recursive = 1;
|
DIFF_OPT_SET(&diff_opts, RECURSIVE);
|
||||||
diff_opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
diff_opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
||||||
|
|
||||||
paths[0] = NULL;
|
paths[0] = NULL;
|
||||||
@ -1093,7 +1093,7 @@ static int find_copy_in_parent(struct scoreboard *sb,
|
|||||||
if ((opt & PICKAXE_BLAME_COPY_HARDEST)
|
if ((opt & PICKAXE_BLAME_COPY_HARDEST)
|
||||||
|| ((opt & PICKAXE_BLAME_COPY_HARDER)
|
|| ((opt & PICKAXE_BLAME_COPY_HARDER)
|
||||||
&& (!porigin || strcmp(target->path, porigin->path))))
|
&& (!porigin || strcmp(target->path, porigin->path))))
|
||||||
diff_opts.find_copies_harder = 1;
|
DIFF_OPT_SET(&diff_opts, FIND_COPIES_HARDER);
|
||||||
|
|
||||||
if (is_null_sha1(target->commit->object.sha1))
|
if (is_null_sha1(target->commit->object.sha1))
|
||||||
do_diff_cache(parent->tree->object.sha1, &diff_opts);
|
do_diff_cache(parent->tree->object.sha1, &diff_opts);
|
||||||
@ -1102,7 +1102,7 @@ static int find_copy_in_parent(struct scoreboard *sb,
|
|||||||
target->commit->tree->object.sha1,
|
target->commit->tree->object.sha1,
|
||||||
"", &diff_opts);
|
"", &diff_opts);
|
||||||
|
|
||||||
if (!diff_opts.find_copies_harder)
|
if (!DIFF_OPT_TST(&diff_opts, FIND_COPIES_HARDER))
|
||||||
diffcore_std(&diff_opts);
|
diffcore_std(&diff_opts);
|
||||||
|
|
||||||
retval = 0;
|
retval = 0;
|
||||||
|
@ -507,48 +507,36 @@ static void rename_branch(const char *oldname, const char *newname, int force)
|
|||||||
|
|
||||||
int cmd_branch(int argc, const char **argv, const char *prefix)
|
int cmd_branch(int argc, const char **argv, const char *prefix)
|
||||||
{
|
{
|
||||||
int delete = 0, force_delete = 0, force_create = 0;
|
int delete = 0, rename = 0, force_create = 0;
|
||||||
int rename = 0, force_rename = 0;
|
|
||||||
int verbose = 0, abbrev = DEFAULT_ABBREV, detached = 0;
|
int verbose = 0, abbrev = DEFAULT_ABBREV, detached = 0;
|
||||||
int reflog = 0, track;
|
int reflog = 0, track;
|
||||||
int kinds = REF_LOCAL_BRANCH, kind_remote = 0, kind_any = 0;
|
int kinds = REF_LOCAL_BRANCH;
|
||||||
|
|
||||||
struct option options[] = {
|
struct option options[] = {
|
||||||
OPT_GROUP("Generic options"),
|
OPT_GROUP("Generic options"),
|
||||||
OPT__VERBOSE(&verbose),
|
OPT__VERBOSE(&verbose),
|
||||||
OPT_BOOLEAN( 0 , "track", &track, "set up tracking mode (see git-pull(1))"),
|
OPT_BOOLEAN( 0 , "track", &track, "set up tracking mode (see git-pull(1))"),
|
||||||
OPT_BOOLEAN( 0 , "color", &branch_use_color, "use colored output"),
|
OPT_BOOLEAN( 0 , "color", &branch_use_color, "use colored output"),
|
||||||
OPT_BOOLEAN('r', NULL, &kind_remote, "act on remote-tracking branches"),
|
OPT_SET_INT('r', NULL, &kinds, "act on remote-tracking branches",
|
||||||
|
REF_REMOTE_BRANCH),
|
||||||
OPT__ABBREV(&abbrev),
|
OPT__ABBREV(&abbrev),
|
||||||
|
|
||||||
OPT_GROUP("Specific git-branch actions:"),
|
OPT_GROUP("Specific git-branch actions:"),
|
||||||
OPT_BOOLEAN('a', NULL, &kind_any, "list both remote-tracking and local branches"),
|
OPT_SET_INT('a', NULL, &kinds, "list both remote-tracking and local branches",
|
||||||
OPT_BOOLEAN('d', NULL, &delete, "delete fully merged branch"),
|
REF_REMOTE_BRANCH | REF_LOCAL_BRANCH),
|
||||||
OPT_BOOLEAN('D', NULL, &force_delete, "delete branch (even if not merged)"),
|
OPT_BIT('d', NULL, &delete, "delete fully merged branch", 1),
|
||||||
|
OPT_BIT('D', NULL, &delete, "delete branch (even if not merged)", 2),
|
||||||
|
OPT_BIT('m', NULL, &rename, "move/rename a branch and its reflog", 1),
|
||||||
|
OPT_BIT('M', NULL, &rename, "move/rename a branch, even if target exists", 2),
|
||||||
OPT_BOOLEAN('l', NULL, &reflog, "create the branch's reflog"),
|
OPT_BOOLEAN('l', NULL, &reflog, "create the branch's reflog"),
|
||||||
OPT_BOOLEAN('f', NULL, &force_create, "force creation (when already exists)"),
|
OPT_BOOLEAN('f', NULL, &force_create, "force creation (when already exists)"),
|
||||||
OPT_BOOLEAN('m', NULL, &rename, "move/rename a branch and its reflog"),
|
|
||||||
OPT_BOOLEAN('M', NULL, &force_rename, "move/rename a branch, even if target exists"),
|
|
||||||
OPT_END(),
|
OPT_END(),
|
||||||
};
|
};
|
||||||
|
|
||||||
git_config(git_branch_config);
|
git_config(git_branch_config);
|
||||||
track = branch_track;
|
track = branch_track;
|
||||||
argc = parse_options(argc, argv, options, builtin_branch_usage, 0);
|
argc = parse_options(argc, argv, options, builtin_branch_usage, 0);
|
||||||
|
if (!!delete + !!rename + !!force_create > 1)
|
||||||
delete |= force_delete;
|
|
||||||
rename |= force_rename;
|
|
||||||
if (kind_remote)
|
|
||||||
kinds = REF_REMOTE_BRANCH;
|
|
||||||
if (kind_any)
|
|
||||||
kinds = REF_REMOTE_BRANCH | REF_LOCAL_BRANCH;
|
|
||||||
if (abbrev && abbrev < MINIMUM_ABBREV)
|
|
||||||
abbrev = MINIMUM_ABBREV;
|
|
||||||
else if (abbrev > 40)
|
|
||||||
abbrev = 40;
|
|
||||||
|
|
||||||
if ((delete && rename) || (delete && force_create) ||
|
|
||||||
(rename && force_create))
|
|
||||||
usage_with_options(builtin_branch_usage, options);
|
usage_with_options(builtin_branch_usage, options);
|
||||||
|
|
||||||
head = resolve_ref("HEAD", head_sha1, 0, NULL);
|
head = resolve_ref("HEAD", head_sha1, 0, NULL);
|
||||||
@ -564,13 +552,13 @@ int cmd_branch(int argc, const char **argv, const char *prefix)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (delete)
|
if (delete)
|
||||||
return delete_branches(argc, argv, force_delete, kinds);
|
return delete_branches(argc, argv, delete > 1, kinds);
|
||||||
else if (argc == 0)
|
else if (argc == 0)
|
||||||
print_ref_list(kinds, detached, verbose, abbrev);
|
print_ref_list(kinds, detached, verbose, abbrev);
|
||||||
else if (rename && (argc == 1))
|
else if (rename && (argc == 1))
|
||||||
rename_branch(head, argv[0], force_rename);
|
rename_branch(head, argv[0], rename > 1);
|
||||||
else if (rename && (argc == 2))
|
else if (rename && (argc == 2))
|
||||||
rename_branch(argv[0], argv[1], force_rename);
|
rename_branch(argv[0], argv[1], rename > 1);
|
||||||
else if (argc <= 2)
|
else if (argc <= 2)
|
||||||
create_branch(argv[0], (argc == 2) ? argv[1] : head,
|
create_branch(argv[0], (argc == 2) ? argv[1] : head,
|
||||||
force_create, reflog, track);
|
force_create, reflog, track);
|
||||||
|
@ -31,5 +31,7 @@ int cmd_diff_files(int argc, const char **argv, const char *prefix)
|
|||||||
if (!rev.diffopt.output_format)
|
if (!rev.diffopt.output_format)
|
||||||
rev.diffopt.output_format = DIFF_FORMAT_RAW;
|
rev.diffopt.output_format = DIFF_FORMAT_RAW;
|
||||||
result = run_diff_files_cmd(&rev, argc, argv);
|
result = run_diff_files_cmd(&rev, argc, argv);
|
||||||
return rev.diffopt.exit_with_status ? rev.diffopt.has_changes: result;
|
if (DIFF_OPT_TST(&rev.diffopt, EXIT_WITH_STATUS))
|
||||||
|
return DIFF_OPT_TST(&rev.diffopt, HAS_CHANGES) != 0;
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -44,5 +44,7 @@ int cmd_diff_index(int argc, const char **argv, const char *prefix)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
result = run_diff_index(&rev, cached);
|
result = run_diff_index(&rev, cached);
|
||||||
return rev.diffopt.exit_with_status ? rev.diffopt.has_changes: result;
|
if (DIFF_OPT_TST(&rev.diffopt, EXIT_WITH_STATUS))
|
||||||
|
return DIFF_OPT_TST(&rev.diffopt, HAS_CHANGES) != 0;
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -118,8 +118,8 @@ int cmd_diff_tree(int argc, const char **argv, const char *prefix)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!read_stdin)
|
if (!read_stdin)
|
||||||
return opt->diffopt.exit_with_status ?
|
return DIFF_OPT_TST(&opt->diffopt, EXIT_WITH_STATUS)
|
||||||
opt->diffopt.has_changes: 0;
|
&& DIFF_OPT_TST(&opt->diffopt, HAS_CHANGES);
|
||||||
|
|
||||||
if (opt->diffopt.detect_rename)
|
if (opt->diffopt.detect_rename)
|
||||||
opt->diffopt.setup |= (DIFF_SETUP_USE_SIZE_CACHE |
|
opt->diffopt.setup |= (DIFF_SETUP_USE_SIZE_CACHE |
|
||||||
@ -134,5 +134,6 @@ int cmd_diff_tree(int argc, const char **argv, const char *prefix)
|
|||||||
else
|
else
|
||||||
diff_tree_stdin(line);
|
diff_tree_stdin(line);
|
||||||
}
|
}
|
||||||
return opt->diffopt.exit_with_status ? opt->diffopt.has_changes: 0;
|
return DIFF_OPT_TST(&opt->diffopt, EXIT_WITH_STATUS)
|
||||||
|
&& DIFF_OPT_TST(&opt->diffopt, HAS_CHANGES);
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,7 @@ static void stuff_change(struct diff_options *opt,
|
|||||||
!hashcmp(old_sha1, new_sha1) && (old_mode == new_mode))
|
!hashcmp(old_sha1, new_sha1) && (old_mode == new_mode))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (opt->reverse_diff) {
|
if (DIFF_OPT_TST(opt, REVERSE_DIFF)) {
|
||||||
unsigned tmp;
|
unsigned tmp;
|
||||||
const unsigned char *tmp_u;
|
const unsigned char *tmp_u;
|
||||||
const char *tmp_c;
|
const char *tmp_c;
|
||||||
@ -253,13 +253,13 @@ int cmd_diff(int argc, const char **argv, const char *prefix)
|
|||||||
if (diff_setup_done(&rev.diffopt) < 0)
|
if (diff_setup_done(&rev.diffopt) < 0)
|
||||||
die("diff_setup_done failed");
|
die("diff_setup_done failed");
|
||||||
}
|
}
|
||||||
rev.diffopt.allow_external = 1;
|
DIFF_OPT_SET(&rev.diffopt, ALLOW_EXTERNAL);
|
||||||
rev.diffopt.recursive = 1;
|
DIFF_OPT_SET(&rev.diffopt, RECURSIVE);
|
||||||
|
|
||||||
/* If the user asked for our exit code then don't start a
|
/* If the user asked for our exit code then don't start a
|
||||||
* pager or we would end up reporting its exit code instead.
|
* pager or we would end up reporting its exit code instead.
|
||||||
*/
|
*/
|
||||||
if (!rev.diffopt.exit_with_status)
|
if (!DIFF_OPT_TST(&rev.diffopt, EXIT_WITH_STATUS))
|
||||||
setup_pager();
|
setup_pager();
|
||||||
|
|
||||||
/* Do we have --cached and not have a pending object, then
|
/* Do we have --cached and not have a pending object, then
|
||||||
@ -363,8 +363,8 @@ int cmd_diff(int argc, const char **argv, const char *prefix)
|
|||||||
else
|
else
|
||||||
result = builtin_diff_combined(&rev, argc, argv,
|
result = builtin_diff_combined(&rev, argc, argv,
|
||||||
ent, ents);
|
ent, ents);
|
||||||
if (rev.diffopt.exit_with_status)
|
if (DIFF_OPT_TST(&rev.diffopt, EXIT_WITH_STATUS))
|
||||||
result = rev.diffopt.has_changes;
|
result = DIFF_OPT_TST(&rev.diffopt, HAS_CHANGES) != 0;
|
||||||
|
|
||||||
if (1 < rev.diffopt.skip_stat_unmatch)
|
if (1 < rev.diffopt.skip_stat_unmatch)
|
||||||
refresh_index_quietly();
|
refresh_index_quietly();
|
||||||
|
@ -833,16 +833,19 @@ int cmd_for_each_ref(int argc, const char **argv, const char *prefix)
|
|||||||
int i, num_refs;
|
int i, num_refs;
|
||||||
const char *format = "%(objectname) %(objecttype)\t%(refname)";
|
const char *format = "%(objectname) %(objecttype)\t%(refname)";
|
||||||
struct ref_sort *sort = NULL, **sort_tail = &sort;
|
struct ref_sort *sort = NULL, **sort_tail = &sort;
|
||||||
int maxcount = 0, quote_style;
|
int maxcount = 0, quote_style = 0;
|
||||||
int quote_shell = 0, quote_perl = 0, quote_python = 0, quote_tcl = 0;
|
|
||||||
struct refinfo **refs;
|
struct refinfo **refs;
|
||||||
struct grab_ref_cbdata cbdata;
|
struct grab_ref_cbdata cbdata;
|
||||||
|
|
||||||
struct option opts[] = {
|
struct option opts[] = {
|
||||||
OPT_BOOLEAN('s', "shell", "e_shell, "quote placeholders suitably for shells"),
|
OPT_BIT('s', "shell", "e_style,
|
||||||
OPT_BOOLEAN('p', "perl", "e_perl, "quote placeholders suitably for perl"),
|
"quote placeholders suitably for shells", QUOTE_SHELL),
|
||||||
OPT_BOOLEAN( 0 , "python", "e_python, "quote placeholders suitably for python"),
|
OPT_BIT('p', "perl", "e_style,
|
||||||
OPT_BOOLEAN( 0 , "tcl", "e_tcl, "quote placeholders suitably for tcl"),
|
"quote placeholders suitably for perl", QUOTE_PERL),
|
||||||
|
OPT_BIT(0 , "python", "e_style,
|
||||||
|
"quote placeholders suitably for python", QUOTE_PYTHON),
|
||||||
|
OPT_BIT(0 , "tcl", "e_style,
|
||||||
|
"quote placeholders suitably for tcl", QUOTE_TCL),
|
||||||
|
|
||||||
OPT_GROUP(""),
|
OPT_GROUP(""),
|
||||||
OPT_INTEGER( 0 , "count", &maxcount, "show only <n> matched refs"),
|
OPT_INTEGER( 0 , "count", &maxcount, "show only <n> matched refs"),
|
||||||
@ -857,15 +860,13 @@ int cmd_for_each_ref(int argc, const char **argv, const char *prefix)
|
|||||||
error("invalid --count argument: `%d'", maxcount);
|
error("invalid --count argument: `%d'", maxcount);
|
||||||
usage_with_options(for_each_ref_usage, opts);
|
usage_with_options(for_each_ref_usage, opts);
|
||||||
}
|
}
|
||||||
if (quote_shell + quote_perl + quote_python + quote_tcl > 1) {
|
if (HAS_MULTI_BITS(quote_style)) {
|
||||||
error("more than one quoting style ?");
|
error("more than one quoting style ?");
|
||||||
usage_with_options(for_each_ref_usage, opts);
|
usage_with_options(for_each_ref_usage, opts);
|
||||||
}
|
}
|
||||||
if (verify_format(format))
|
if (verify_format(format))
|
||||||
usage_with_options(for_each_ref_usage, opts);
|
usage_with_options(for_each_ref_usage, opts);
|
||||||
|
|
||||||
quote_style = QUOTE_SHELL * quote_shell + QUOTE_PERL * quote_perl +
|
|
||||||
QUOTE_PYTHON * quote_python + QUOTE_TCL * quote_tcl;
|
|
||||||
if (!sort)
|
if (!sort)
|
||||||
sort = default_sort();
|
sort = default_sort();
|
||||||
sort_atom_limit = used_atom_cnt;
|
sort_atom_limit = used_atom_cnt;
|
||||||
|
@ -55,13 +55,13 @@ static void cmd_log_init(int argc, const char **argv, const char *prefix,
|
|||||||
rev->abbrev = DEFAULT_ABBREV;
|
rev->abbrev = DEFAULT_ABBREV;
|
||||||
rev->commit_format = CMIT_FMT_DEFAULT;
|
rev->commit_format = CMIT_FMT_DEFAULT;
|
||||||
rev->verbose_header = 1;
|
rev->verbose_header = 1;
|
||||||
rev->diffopt.recursive = 1;
|
DIFF_OPT_SET(&rev->diffopt, RECURSIVE);
|
||||||
rev->show_root_diff = default_show_root;
|
rev->show_root_diff = default_show_root;
|
||||||
rev->subject_prefix = fmt_patch_subject_prefix;
|
rev->subject_prefix = fmt_patch_subject_prefix;
|
||||||
argc = setup_revisions(argc, argv, rev, "HEAD");
|
argc = setup_revisions(argc, argv, rev, "HEAD");
|
||||||
if (rev->diffopt.pickaxe || rev->diffopt.filter)
|
if (rev->diffopt.pickaxe || rev->diffopt.filter)
|
||||||
rev->always_show_header = 0;
|
rev->always_show_header = 0;
|
||||||
if (rev->diffopt.follow_renames) {
|
if (DIFF_OPT_TST(&rev->diffopt, FOLLOW_RENAMES)) {
|
||||||
rev->always_show_header = 0;
|
rev->always_show_header = 0;
|
||||||
if (rev->diffopt.nr_paths != 1)
|
if (rev->diffopt.nr_paths != 1)
|
||||||
usage("git logs can only follow renames on one pathname at a time");
|
usage("git logs can only follow renames on one pathname at a time");
|
||||||
@ -185,11 +185,9 @@ int cmd_show(int argc, const char **argv, const char *prefix)
|
|||||||
struct tag *t = (struct tag *)o;
|
struct tag *t = (struct tag *)o;
|
||||||
|
|
||||||
printf("%stag %s%s\n\n",
|
printf("%stag %s%s\n\n",
|
||||||
diff_get_color(rev.diffopt.color_diff,
|
diff_get_color_opt(&rev.diffopt, DIFF_COMMIT),
|
||||||
DIFF_COMMIT),
|
|
||||||
t->tag,
|
t->tag,
|
||||||
diff_get_color(rev.diffopt.color_diff,
|
diff_get_color_opt(&rev.diffopt, DIFF_RESET));
|
||||||
DIFF_RESET));
|
|
||||||
ret = show_object(o->sha1, 1);
|
ret = show_object(o->sha1, 1);
|
||||||
objects[i].item = (struct object *)t->tagged;
|
objects[i].item = (struct object *)t->tagged;
|
||||||
i--;
|
i--;
|
||||||
@ -197,11 +195,9 @@ int cmd_show(int argc, const char **argv, const char *prefix)
|
|||||||
}
|
}
|
||||||
case OBJ_TREE:
|
case OBJ_TREE:
|
||||||
printf("%stree %s%s\n\n",
|
printf("%stree %s%s\n\n",
|
||||||
diff_get_color(rev.diffopt.color_diff,
|
diff_get_color_opt(&rev.diffopt, DIFF_COMMIT),
|
||||||
DIFF_COMMIT),
|
|
||||||
name,
|
name,
|
||||||
diff_get_color(rev.diffopt.color_diff,
|
diff_get_color_opt(&rev.diffopt, DIFF_RESET));
|
||||||
DIFF_RESET));
|
|
||||||
read_tree_recursive((struct tree *)o, "", 0, 0, NULL,
|
read_tree_recursive((struct tree *)o, "", 0, 0, NULL,
|
||||||
show_tree_object);
|
show_tree_object);
|
||||||
break;
|
break;
|
||||||
@ -497,7 +493,7 @@ int cmd_format_patch(int argc, const char **argv, const char *prefix)
|
|||||||
rev.combine_merges = 0;
|
rev.combine_merges = 0;
|
||||||
rev.ignore_merges = 1;
|
rev.ignore_merges = 1;
|
||||||
rev.diffopt.msg_sep = "";
|
rev.diffopt.msg_sep = "";
|
||||||
rev.diffopt.recursive = 1;
|
DIFF_OPT_SET(&rev.diffopt, RECURSIVE);
|
||||||
|
|
||||||
rev.subject_prefix = fmt_patch_subject_prefix;
|
rev.subject_prefix = fmt_patch_subject_prefix;
|
||||||
rev.extra_headers = extra_headers;
|
rev.extra_headers = extra_headers;
|
||||||
@ -605,8 +601,8 @@ int cmd_format_patch(int argc, const char **argv, const char *prefix)
|
|||||||
if (!rev.diffopt.output_format)
|
if (!rev.diffopt.output_format)
|
||||||
rev.diffopt.output_format = DIFF_FORMAT_DIFFSTAT | DIFF_FORMAT_SUMMARY | DIFF_FORMAT_PATCH;
|
rev.diffopt.output_format = DIFF_FORMAT_DIFFSTAT | DIFF_FORMAT_SUMMARY | DIFF_FORMAT_PATCH;
|
||||||
|
|
||||||
if (!rev.diffopt.text)
|
if (!DIFF_OPT_TST(&rev.diffopt, TEXT))
|
||||||
rev.diffopt.binary = 1;
|
DIFF_OPT_SET(&rev.diffopt, BINARY);
|
||||||
|
|
||||||
if (!output_directory && !use_stdout)
|
if (!output_directory && !use_stdout)
|
||||||
output_directory = prefix;
|
output_directory = prefix;
|
||||||
@ -764,7 +760,7 @@ int cmd_cherry(int argc, const char **argv, const char *prefix)
|
|||||||
revs.diff = 1;
|
revs.diff = 1;
|
||||||
revs.combine_merges = 0;
|
revs.combine_merges = 0;
|
||||||
revs.ignore_merges = 1;
|
revs.ignore_merges = 1;
|
||||||
revs.diffopt.recursive = 1;
|
DIFF_OPT_SET(&revs.diffopt, RECURSIVE);
|
||||||
|
|
||||||
if (add_pending_commit(head, &revs, 0))
|
if (add_pending_commit(head, &revs, 0))
|
||||||
die("Unknown commit %s", head);
|
die("Unknown commit %s", head);
|
||||||
|
@ -122,19 +122,13 @@ static char const * const pack_refs_usage[] = {
|
|||||||
|
|
||||||
int cmd_pack_refs(int argc, const char **argv, const char *prefix)
|
int cmd_pack_refs(int argc, const char **argv, const char *prefix)
|
||||||
{
|
{
|
||||||
int all = 0, prune = 1;
|
unsigned int flags = PACK_REFS_PRUNE;
|
||||||
unsigned int flags = 0;
|
|
||||||
struct option opts[] = {
|
struct option opts[] = {
|
||||||
OPT_BOOLEAN(0, "all", &all, "pack everything"),
|
OPT_BIT(0, "all", &flags, "pack everything", PACK_REFS_ALL),
|
||||||
OPT_BOOLEAN(0, "prune", &prune, "prune loose refs (default)"),
|
OPT_BIT(0, "prune", &flags, "prune loose refs (default)", PACK_REFS_PRUNE),
|
||||||
OPT_END(),
|
OPT_END(),
|
||||||
};
|
};
|
||||||
|
|
||||||
if (parse_options(argc, argv, opts, pack_refs_usage, 0))
|
if (parse_options(argc, argv, opts, pack_refs_usage, 0))
|
||||||
usage_with_options(pack_refs_usage, opts);
|
usage_with_options(pack_refs_usage, opts);
|
||||||
if (prune)
|
|
||||||
flags |= PACK_REFS_PRUNE;
|
|
||||||
if (all)
|
|
||||||
flags |= PACK_REFS_ALL;
|
|
||||||
return pack_refs(flags);
|
return pack_refs(flags);
|
||||||
}
|
}
|
||||||
|
@ -664,7 +664,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,
|
|||||||
int mode_differs = 0;
|
int mode_differs = 0;
|
||||||
int i, show_hunks;
|
int i, show_hunks;
|
||||||
int working_tree_file = is_null_sha1(elem->sha1);
|
int working_tree_file = is_null_sha1(elem->sha1);
|
||||||
int abbrev = opt->full_index ? 40 : DEFAULT_ABBREV;
|
int abbrev = DIFF_OPT_TST(opt, FULL_INDEX) ? 40 : DEFAULT_ABBREV;
|
||||||
mmfile_t result_file;
|
mmfile_t result_file;
|
||||||
|
|
||||||
context = opt->context;
|
context = opt->context;
|
||||||
@ -784,7 +784,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,
|
|||||||
|
|
||||||
if (show_hunks || mode_differs || working_tree_file) {
|
if (show_hunks || mode_differs || working_tree_file) {
|
||||||
const char *abb;
|
const char *abb;
|
||||||
int use_color = opt->color_diff;
|
int use_color = DIFF_OPT_TST(opt, COLOR_DIFF);
|
||||||
const char *c_meta = diff_get_color(use_color, DIFF_METAINFO);
|
const char *c_meta = diff_get_color(use_color, DIFF_METAINFO);
|
||||||
const char *c_reset = diff_get_color(use_color, DIFF_RESET);
|
const char *c_reset = diff_get_color(use_color, DIFF_RESET);
|
||||||
int added = 0;
|
int added = 0;
|
||||||
@ -836,7 +836,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,
|
|||||||
dump_quoted_path("+++ /dev/", "null", c_meta, c_reset);
|
dump_quoted_path("+++ /dev/", "null", c_meta, c_reset);
|
||||||
else
|
else
|
||||||
dump_quoted_path("+++ b/", elem->path, c_meta, c_reset);
|
dump_quoted_path("+++ b/", elem->path, c_meta, c_reset);
|
||||||
dump_sline(sline, cnt, num_parent, opt->color_diff);
|
dump_sline(sline, cnt, num_parent, DIFF_OPT_TST(opt, COLOR_DIFF));
|
||||||
}
|
}
|
||||||
free(result);
|
free(result);
|
||||||
|
|
||||||
@ -929,8 +929,8 @@ void diff_tree_combined(const unsigned char *sha1,
|
|||||||
|
|
||||||
diffopts = *opt;
|
diffopts = *opt;
|
||||||
diffopts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
diffopts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
||||||
diffopts.recursive = 1;
|
DIFF_OPT_SET(&diffopts, RECURSIVE);
|
||||||
diffopts.allow_external = 0;
|
DIFF_OPT_CLR(&diffopts, ALLOW_EXTERNAL);
|
||||||
|
|
||||||
show_log_first = !!rev->loginfo && !rev->no_commit_id;
|
show_log_first = !!rev->loginfo && !rev->no_commit_id;
|
||||||
needsep = 0;
|
needsep = 0;
|
||||||
|
24
diff-lib.c
24
diff-lib.c
@ -121,7 +121,7 @@ static int queue_diff(struct diff_options *o,
|
|||||||
} else {
|
} else {
|
||||||
struct diff_filespec *d1, *d2;
|
struct diff_filespec *d1, *d2;
|
||||||
|
|
||||||
if (o->reverse_diff) {
|
if (DIFF_OPT_TST(o, REVERSE_DIFF)) {
|
||||||
unsigned tmp;
|
unsigned tmp;
|
||||||
const char *tmp_c;
|
const char *tmp_c;
|
||||||
tmp = mode1; mode1 = mode2; mode2 = tmp;
|
tmp = mode1; mode1 = mode2; mode2 = tmp;
|
||||||
@ -189,8 +189,8 @@ static int handle_diff_files_args(struct rev_info *revs,
|
|||||||
else if (!strcmp(argv[1], "-n") ||
|
else if (!strcmp(argv[1], "-n") ||
|
||||||
!strcmp(argv[1], "--no-index")) {
|
!strcmp(argv[1], "--no-index")) {
|
||||||
revs->max_count = -2;
|
revs->max_count = -2;
|
||||||
revs->diffopt.exit_with_status = 1;
|
DIFF_OPT_SET(&revs->diffopt, EXIT_WITH_STATUS);
|
||||||
revs->diffopt.no_index = 1;
|
DIFF_OPT_SET(&revs->diffopt, NO_INDEX);
|
||||||
}
|
}
|
||||||
else if (!strcmp(argv[1], "-q"))
|
else if (!strcmp(argv[1], "-q"))
|
||||||
*options |= DIFF_SILENT_ON_REMOVED;
|
*options |= DIFF_SILENT_ON_REMOVED;
|
||||||
@ -208,7 +208,7 @@ static int handle_diff_files_args(struct rev_info *revs,
|
|||||||
if (!is_in_index(revs->diffopt.paths[0]) ||
|
if (!is_in_index(revs->diffopt.paths[0]) ||
|
||||||
!is_in_index(revs->diffopt.paths[1])) {
|
!is_in_index(revs->diffopt.paths[1])) {
|
||||||
revs->max_count = -2;
|
revs->max_count = -2;
|
||||||
revs->diffopt.no_index = 1;
|
DIFF_OPT_SET(&revs->diffopt, NO_INDEX);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -259,7 +259,7 @@ int setup_diff_no_index(struct rev_info *revs,
|
|||||||
break;
|
break;
|
||||||
} else if (i < argc - 3 && !strcmp(argv[i], "--no-index")) {
|
} else if (i < argc - 3 && !strcmp(argv[i], "--no-index")) {
|
||||||
i = argc - 3;
|
i = argc - 3;
|
||||||
revs->diffopt.exit_with_status = 1;
|
DIFF_OPT_SET(&revs->diffopt, EXIT_WITH_STATUS);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (argc != i + 2 || (!is_outside_repo(argv[i + 1], nongit, prefix) &&
|
if (argc != i + 2 || (!is_outside_repo(argv[i + 1], nongit, prefix) &&
|
||||||
@ -297,7 +297,7 @@ int setup_diff_no_index(struct rev_info *revs,
|
|||||||
else
|
else
|
||||||
revs->diffopt.paths = argv + argc - 2;
|
revs->diffopt.paths = argv + argc - 2;
|
||||||
revs->diffopt.nr_paths = 2;
|
revs->diffopt.nr_paths = 2;
|
||||||
revs->diffopt.no_index = 1;
|
DIFF_OPT_SET(&revs->diffopt, NO_INDEX);
|
||||||
revs->max_count = -2;
|
revs->max_count = -2;
|
||||||
if (diff_setup_done(&revs->diffopt) < 0)
|
if (diff_setup_done(&revs->diffopt) < 0)
|
||||||
die("diff_setup_done failed");
|
die("diff_setup_done failed");
|
||||||
@ -311,7 +311,7 @@ int run_diff_files_cmd(struct rev_info *revs, int argc, const char **argv)
|
|||||||
if (handle_diff_files_args(revs, argc, argv, &options))
|
if (handle_diff_files_args(revs, argc, argv, &options))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (revs->diffopt.no_index) {
|
if (DIFF_OPT_TST(&revs->diffopt, NO_INDEX)) {
|
||||||
if (revs->diffopt.nr_paths != 2)
|
if (revs->diffopt.nr_paths != 2)
|
||||||
return error("need two files/directories with --no-index");
|
return error("need two files/directories with --no-index");
|
||||||
if (queue_diff(&revs->diffopt, revs->diffopt.paths[0],
|
if (queue_diff(&revs->diffopt, revs->diffopt.paths[0],
|
||||||
@ -350,7 +350,8 @@ int run_diff_files(struct rev_info *revs, unsigned int option)
|
|||||||
struct cache_entry *ce = active_cache[i];
|
struct cache_entry *ce = active_cache[i];
|
||||||
int changed;
|
int changed;
|
||||||
|
|
||||||
if (revs->diffopt.quiet && revs->diffopt.has_changes)
|
if (DIFF_OPT_TST(&revs->diffopt, QUIET) &&
|
||||||
|
DIFF_OPT_TST(&revs->diffopt, HAS_CHANGES))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (!ce_path_match(ce, revs->prune_data))
|
if (!ce_path_match(ce, revs->prune_data))
|
||||||
@ -446,7 +447,7 @@ int run_diff_files(struct rev_info *revs, unsigned int option)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
changed = ce_match_stat(ce, &st, ce_option);
|
changed = ce_match_stat(ce, &st, ce_option);
|
||||||
if (!changed && !revs->diffopt.find_copies_harder)
|
if (!changed && !DIFF_OPT_TST(&revs->diffopt, FIND_COPIES_HARDER))
|
||||||
continue;
|
continue;
|
||||||
oldmode = ntohl(ce->ce_mode);
|
oldmode = ntohl(ce->ce_mode);
|
||||||
newmode = ntohl(ce_mode_from_stat(ce, st.st_mode));
|
newmode = ntohl(ce_mode_from_stat(ce, st.st_mode));
|
||||||
@ -565,7 +566,7 @@ static int show_modified(struct rev_info *revs,
|
|||||||
|
|
||||||
oldmode = old->ce_mode;
|
oldmode = old->ce_mode;
|
||||||
if (mode == oldmode && !hashcmp(sha1, old->sha1) &&
|
if (mode == oldmode && !hashcmp(sha1, old->sha1) &&
|
||||||
!revs->diffopt.find_copies_harder)
|
!DIFF_OPT_TST(&revs->diffopt, FIND_COPIES_HARDER))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
mode = ntohl(mode);
|
mode = ntohl(mode);
|
||||||
@ -585,7 +586,8 @@ static int diff_cache(struct rev_info *revs,
|
|||||||
struct cache_entry *ce = *ac;
|
struct cache_entry *ce = *ac;
|
||||||
int same = (entries > 1) && ce_same_name(ce, ac[1]);
|
int same = (entries > 1) && ce_same_name(ce, ac[1]);
|
||||||
|
|
||||||
if (revs->diffopt.quiet && revs->diffopt.has_changes)
|
if (DIFF_OPT_TST(&revs->diffopt, QUIET) &&
|
||||||
|
DIFF_OPT_TST(&revs->diffopt, HAS_CHANGES))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (!ce_path_match(ce, pathspec))
|
if (!ce_path_match(ce, pathspec))
|
||||||
|
221
diff.c
221
diff.c
@ -814,10 +814,10 @@ static void show_stats(struct diffstat_t* data, struct diff_options *options)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Find the longest filename and max number of changes */
|
/* Find the longest filename and max number of changes */
|
||||||
reset = diff_get_color(options->color_diff, DIFF_RESET);
|
reset = diff_get_color_opt(options, DIFF_RESET);
|
||||||
set = diff_get_color(options->color_diff, DIFF_PLAIN);
|
set = diff_get_color_opt(options, DIFF_PLAIN);
|
||||||
add_c = diff_get_color(options->color_diff, DIFF_FILE_NEW);
|
add_c = diff_get_color_opt(options, DIFF_FILE_NEW);
|
||||||
del_c = diff_get_color(options->color_diff, DIFF_FILE_OLD);
|
del_c = diff_get_color_opt(options, DIFF_FILE_OLD);
|
||||||
|
|
||||||
for (i = 0; i < data->nr; i++) {
|
for (i = 0; i < data->nr; i++) {
|
||||||
struct diffstat_file *file = data->files[i];
|
struct diffstat_file *file = data->files[i];
|
||||||
@ -1243,8 +1243,8 @@ static void builtin_diff(const char *name_a,
|
|||||||
mmfile_t mf1, mf2;
|
mmfile_t mf1, mf2;
|
||||||
const char *lbl[2];
|
const char *lbl[2];
|
||||||
char *a_one, *b_two;
|
char *a_one, *b_two;
|
||||||
const char *set = diff_get_color(o->color_diff, DIFF_METAINFO);
|
const char *set = diff_get_color_opt(o, DIFF_METAINFO);
|
||||||
const char *reset = diff_get_color(o->color_diff, DIFF_RESET);
|
const char *reset = diff_get_color_opt(o, DIFF_RESET);
|
||||||
|
|
||||||
a_one = quote_two("a/", name_a + (*name_a == '/'));
|
a_one = quote_two("a/", name_a + (*name_a == '/'));
|
||||||
b_two = quote_two("b/", name_b + (*name_b == '/'));
|
b_two = quote_two("b/", name_b + (*name_b == '/'));
|
||||||
@ -1277,7 +1277,7 @@ static void builtin_diff(const char *name_a,
|
|||||||
goto free_ab_and_return;
|
goto free_ab_and_return;
|
||||||
if (complete_rewrite) {
|
if (complete_rewrite) {
|
||||||
emit_rewrite_diff(name_a, name_b, one, two,
|
emit_rewrite_diff(name_a, name_b, one, two,
|
||||||
o->color_diff);
|
DIFF_OPT_TST(o, COLOR_DIFF));
|
||||||
o->found_changes = 1;
|
o->found_changes = 1;
|
||||||
goto free_ab_and_return;
|
goto free_ab_and_return;
|
||||||
}
|
}
|
||||||
@ -1286,13 +1286,13 @@ static void builtin_diff(const char *name_a,
|
|||||||
if (fill_mmfile(&mf1, one) < 0 || fill_mmfile(&mf2, two) < 0)
|
if (fill_mmfile(&mf1, one) < 0 || fill_mmfile(&mf2, two) < 0)
|
||||||
die("unable to read files to diff");
|
die("unable to read files to diff");
|
||||||
|
|
||||||
if (!o->text &&
|
if (!DIFF_OPT_TST(o, TEXT) &&
|
||||||
(diff_filespec_is_binary(one) || diff_filespec_is_binary(two))) {
|
(diff_filespec_is_binary(one) || diff_filespec_is_binary(two))) {
|
||||||
/* Quite common confusing case */
|
/* Quite common confusing case */
|
||||||
if (mf1.size == mf2.size &&
|
if (mf1.size == mf2.size &&
|
||||||
!memcmp(mf1.ptr, mf2.ptr, mf1.size))
|
!memcmp(mf1.ptr, mf2.ptr, mf1.size))
|
||||||
goto free_ab_and_return;
|
goto free_ab_and_return;
|
||||||
if (o->binary)
|
if (DIFF_OPT_TST(o, BINARY))
|
||||||
emit_binary_diff(&mf1, &mf2);
|
emit_binary_diff(&mf1, &mf2);
|
||||||
else
|
else
|
||||||
printf("Binary files %s and %s differ\n",
|
printf("Binary files %s and %s differ\n",
|
||||||
@ -1315,7 +1315,7 @@ static void builtin_diff(const char *name_a,
|
|||||||
memset(&xecfg, 0, sizeof(xecfg));
|
memset(&xecfg, 0, sizeof(xecfg));
|
||||||
memset(&ecbdata, 0, sizeof(ecbdata));
|
memset(&ecbdata, 0, sizeof(ecbdata));
|
||||||
ecbdata.label_path = lbl;
|
ecbdata.label_path = lbl;
|
||||||
ecbdata.color_diff = o->color_diff;
|
ecbdata.color_diff = DIFF_OPT_TST(o, COLOR_DIFF);
|
||||||
ecbdata.found_changesp = &o->found_changes;
|
ecbdata.found_changesp = &o->found_changes;
|
||||||
xpp.flags = XDF_NEED_MINIMAL | o->xdl_opts;
|
xpp.flags = XDF_NEED_MINIMAL | o->xdl_opts;
|
||||||
xecfg.ctxlen = o->context;
|
xecfg.ctxlen = o->context;
|
||||||
@ -1331,11 +1331,11 @@ static void builtin_diff(const char *name_a,
|
|||||||
ecb.outf = xdiff_outf;
|
ecb.outf = xdiff_outf;
|
||||||
ecb.priv = &ecbdata;
|
ecb.priv = &ecbdata;
|
||||||
ecbdata.xm.consume = fn_out_consume;
|
ecbdata.xm.consume = fn_out_consume;
|
||||||
if (o->color_diff_words)
|
if (DIFF_OPT_TST(o, COLOR_DIFF_WORDS))
|
||||||
ecbdata.diff_words =
|
ecbdata.diff_words =
|
||||||
xcalloc(1, sizeof(struct diff_words_data));
|
xcalloc(1, sizeof(struct diff_words_data));
|
||||||
xdl_diff(&mf1, &mf2, &xpp, &xecfg, &ecb);
|
xdl_diff(&mf1, &mf2, &xpp, &xecfg, &ecb);
|
||||||
if (o->color_diff_words)
|
if (DIFF_OPT_TST(o, COLOR_DIFF_WORDS))
|
||||||
free_diff_words_data(&ecbdata);
|
free_diff_words_data(&ecbdata);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1409,7 +1409,7 @@ static void builtin_checkdiff(const char *name_a, const char *name_b,
|
|||||||
data.xm.consume = checkdiff_consume;
|
data.xm.consume = checkdiff_consume;
|
||||||
data.filename = name_b ? name_b : name_a;
|
data.filename = name_b ? name_b : name_a;
|
||||||
data.lineno = 0;
|
data.lineno = 0;
|
||||||
data.color_diff = o->color_diff;
|
data.color_diff = DIFF_OPT_TST(o, COLOR_DIFF);
|
||||||
|
|
||||||
if (fill_mmfile(&mf1, one) < 0 || fill_mmfile(&mf2, two) < 0)
|
if (fill_mmfile(&mf1, one) < 0 || fill_mmfile(&mf2, two) < 0)
|
||||||
die("unable to read files to diff");
|
die("unable to read files to diff");
|
||||||
@ -1853,7 +1853,7 @@ static void run_diff_cmd(const char *pgm,
|
|||||||
struct diff_options *o,
|
struct diff_options *o,
|
||||||
int complete_rewrite)
|
int complete_rewrite)
|
||||||
{
|
{
|
||||||
if (!o->allow_external)
|
if (!DIFF_OPT_TST(o, ALLOW_EXTERNAL))
|
||||||
pgm = NULL;
|
pgm = NULL;
|
||||||
else {
|
else {
|
||||||
const char *cmd = external_diff_attr(name);
|
const char *cmd = external_diff_attr(name);
|
||||||
@ -1951,9 +1951,9 @@ static void run_diff(struct diff_filepair *p, struct diff_options *o)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (hashcmp(one->sha1, two->sha1)) {
|
if (hashcmp(one->sha1, two->sha1)) {
|
||||||
int abbrev = o->full_index ? 40 : DEFAULT_ABBREV;
|
int abbrev = DIFF_OPT_TST(o, FULL_INDEX) ? 40 : DEFAULT_ABBREV;
|
||||||
|
|
||||||
if (o->binary) {
|
if (DIFF_OPT_TST(o, BINARY)) {
|
||||||
mmfile_t mf;
|
mmfile_t mf;
|
||||||
if ((!fill_mmfile(&mf, one) && diff_filespec_is_binary(one)) ||
|
if ((!fill_mmfile(&mf, one) && diff_filespec_is_binary(one)) ||
|
||||||
(!fill_mmfile(&mf, two) && diff_filespec_is_binary(two)))
|
(!fill_mmfile(&mf, two) && diff_filespec_is_binary(two)))
|
||||||
@ -2045,7 +2045,10 @@ void diff_setup(struct diff_options *options)
|
|||||||
|
|
||||||
options->change = diff_change;
|
options->change = diff_change;
|
||||||
options->add_remove = diff_addremove;
|
options->add_remove = diff_addremove;
|
||||||
options->color_diff = diff_use_color_default;
|
if (diff_use_color_default)
|
||||||
|
DIFF_OPT_SET(options, COLOR_DIFF);
|
||||||
|
else
|
||||||
|
DIFF_OPT_CLR(options, COLOR_DIFF);
|
||||||
options->detect_rename = diff_detect_rename_default;
|
options->detect_rename = diff_detect_rename_default;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2064,7 +2067,7 @@ int diff_setup_done(struct diff_options *options)
|
|||||||
if (count > 1)
|
if (count > 1)
|
||||||
die("--name-only, --name-status, --check and -s are mutually exclusive");
|
die("--name-only, --name-status, --check and -s are mutually exclusive");
|
||||||
|
|
||||||
if (options->find_copies_harder)
|
if (DIFF_OPT_TST(options, FIND_COPIES_HARDER))
|
||||||
options->detect_rename = DIFF_DETECT_COPY;
|
options->detect_rename = DIFF_DETECT_COPY;
|
||||||
|
|
||||||
if (options->output_format & (DIFF_FORMAT_NAME |
|
if (options->output_format & (DIFF_FORMAT_NAME |
|
||||||
@ -2088,12 +2091,12 @@ int diff_setup_done(struct diff_options *options)
|
|||||||
DIFF_FORMAT_SHORTSTAT |
|
DIFF_FORMAT_SHORTSTAT |
|
||||||
DIFF_FORMAT_SUMMARY |
|
DIFF_FORMAT_SUMMARY |
|
||||||
DIFF_FORMAT_CHECKDIFF))
|
DIFF_FORMAT_CHECKDIFF))
|
||||||
options->recursive = 1;
|
DIFF_OPT_SET(options, RECURSIVE);
|
||||||
/*
|
/*
|
||||||
* Also pickaxe would not work very well if you do not say recursive
|
* Also pickaxe would not work very well if you do not say recursive
|
||||||
*/
|
*/
|
||||||
if (options->pickaxe)
|
if (options->pickaxe)
|
||||||
options->recursive = 1;
|
DIFF_OPT_SET(options, RECURSIVE);
|
||||||
|
|
||||||
if (options->detect_rename && options->rename_limit < 0)
|
if (options->detect_rename && options->rename_limit < 0)
|
||||||
options->rename_limit = diff_rename_limit_default;
|
options->rename_limit = diff_rename_limit_default;
|
||||||
@ -2115,9 +2118,9 @@ int diff_setup_done(struct diff_options *options)
|
|||||||
* to have found. It does not make sense not to return with
|
* to have found. It does not make sense not to return with
|
||||||
* exit code in such a case either.
|
* exit code in such a case either.
|
||||||
*/
|
*/
|
||||||
if (options->quiet) {
|
if (DIFF_OPT_TST(options, QUIET)) {
|
||||||
options->output_format = DIFF_FORMAT_NO_OUTPUT;
|
options->output_format = DIFF_FORMAT_NO_OUTPUT;
|
||||||
options->exit_with_status = 1;
|
DIFF_OPT_SET(options, EXIT_WITH_STATUS);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2125,7 +2128,7 @@ int diff_setup_done(struct diff_options *options)
|
|||||||
* upon the first hit. We need to run diff as usual.
|
* upon the first hit. We need to run diff as usual.
|
||||||
*/
|
*/
|
||||||
if (options->pickaxe || options->filter)
|
if (options->pickaxe || options->filter)
|
||||||
options->quiet = 0;
|
DIFF_OPT_CLR(options, QUIET);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -2182,21 +2185,32 @@ static int diff_scoreopt_parse(const char *opt);
|
|||||||
int diff_opt_parse(struct diff_options *options, const char **av, int ac)
|
int diff_opt_parse(struct diff_options *options, const char **av, int ac)
|
||||||
{
|
{
|
||||||
const char *arg = av[0];
|
const char *arg = av[0];
|
||||||
|
|
||||||
|
/* Output format options */
|
||||||
if (!strcmp(arg, "-p") || !strcmp(arg, "-u"))
|
if (!strcmp(arg, "-p") || !strcmp(arg, "-u"))
|
||||||
options->output_format |= DIFF_FORMAT_PATCH;
|
options->output_format |= DIFF_FORMAT_PATCH;
|
||||||
else if (opt_arg(arg, 'U', "unified", &options->context))
|
else if (opt_arg(arg, 'U', "unified", &options->context))
|
||||||
options->output_format |= DIFF_FORMAT_PATCH;
|
options->output_format |= DIFF_FORMAT_PATCH;
|
||||||
else if (!strcmp(arg, "--raw"))
|
else if (!strcmp(arg, "--raw"))
|
||||||
options->output_format |= DIFF_FORMAT_RAW;
|
options->output_format |= DIFF_FORMAT_RAW;
|
||||||
else if (!strcmp(arg, "--patch-with-raw")) {
|
else if (!strcmp(arg, "--patch-with-raw"))
|
||||||
options->output_format |= DIFF_FORMAT_PATCH | DIFF_FORMAT_RAW;
|
options->output_format |= DIFF_FORMAT_PATCH | DIFF_FORMAT_RAW;
|
||||||
}
|
else if (!strcmp(arg, "--numstat"))
|
||||||
else if (!strcmp(arg, "--numstat")) {
|
|
||||||
options->output_format |= DIFF_FORMAT_NUMSTAT;
|
options->output_format |= DIFF_FORMAT_NUMSTAT;
|
||||||
}
|
else if (!strcmp(arg, "--shortstat"))
|
||||||
else if (!strcmp(arg, "--shortstat")) {
|
|
||||||
options->output_format |= DIFF_FORMAT_SHORTSTAT;
|
options->output_format |= DIFF_FORMAT_SHORTSTAT;
|
||||||
}
|
else if (!strcmp(arg, "--check"))
|
||||||
|
options->output_format |= DIFF_FORMAT_CHECKDIFF;
|
||||||
|
else if (!strcmp(arg, "--summary"))
|
||||||
|
options->output_format |= DIFF_FORMAT_SUMMARY;
|
||||||
|
else if (!strcmp(arg, "--patch-with-stat"))
|
||||||
|
options->output_format |= DIFF_FORMAT_PATCH | DIFF_FORMAT_DIFFSTAT;
|
||||||
|
else if (!strcmp(arg, "--name-only"))
|
||||||
|
options->output_format |= DIFF_FORMAT_NAME;
|
||||||
|
else if (!strcmp(arg, "--name-status"))
|
||||||
|
options->output_format |= DIFF_FORMAT_NAME_STATUS;
|
||||||
|
else if (!strcmp(arg, "-s"))
|
||||||
|
options->output_format |= DIFF_FORMAT_NO_OUTPUT;
|
||||||
else if (!prefixcmp(arg, "--stat")) {
|
else if (!prefixcmp(arg, "--stat")) {
|
||||||
char *end;
|
char *end;
|
||||||
int width = options->stat_width;
|
int width = options->stat_width;
|
||||||
@ -2224,68 +2238,80 @@ int diff_opt_parse(struct diff_options *options, const char **av, int ac)
|
|||||||
options->stat_name_width = name_width;
|
options->stat_name_width = name_width;
|
||||||
options->stat_width = width;
|
options->stat_width = width;
|
||||||
}
|
}
|
||||||
else if (!strcmp(arg, "--check"))
|
|
||||||
options->output_format |= DIFF_FORMAT_CHECKDIFF;
|
/* renames options */
|
||||||
else if (!strcmp(arg, "--summary"))
|
|
||||||
options->output_format |= DIFF_FORMAT_SUMMARY;
|
|
||||||
else if (!strcmp(arg, "--patch-with-stat")) {
|
|
||||||
options->output_format |= DIFF_FORMAT_PATCH | DIFF_FORMAT_DIFFSTAT;
|
|
||||||
}
|
|
||||||
else if (!strcmp(arg, "-z"))
|
|
||||||
options->line_termination = 0;
|
|
||||||
else if (!prefixcmp(arg, "-l"))
|
|
||||||
options->rename_limit = strtoul(arg+2, NULL, 10);
|
|
||||||
else if (!strcmp(arg, "--full-index"))
|
|
||||||
options->full_index = 1;
|
|
||||||
else if (!strcmp(arg, "--binary")) {
|
|
||||||
options->output_format |= DIFF_FORMAT_PATCH;
|
|
||||||
options->binary = 1;
|
|
||||||
}
|
|
||||||
else if (!strcmp(arg, "-a") || !strcmp(arg, "--text")) {
|
|
||||||
options->text = 1;
|
|
||||||
}
|
|
||||||
else if (!strcmp(arg, "--name-only"))
|
|
||||||
options->output_format |= DIFF_FORMAT_NAME;
|
|
||||||
else if (!strcmp(arg, "--name-status"))
|
|
||||||
options->output_format |= DIFF_FORMAT_NAME_STATUS;
|
|
||||||
else if (!strcmp(arg, "-R"))
|
|
||||||
options->reverse_diff = 1;
|
|
||||||
else if (!prefixcmp(arg, "-S"))
|
|
||||||
options->pickaxe = arg + 2;
|
|
||||||
else if (!strcmp(arg, "-s")) {
|
|
||||||
options->output_format |= DIFF_FORMAT_NO_OUTPUT;
|
|
||||||
}
|
|
||||||
else if (!prefixcmp(arg, "-O"))
|
|
||||||
options->orderfile = arg + 2;
|
|
||||||
else if (!prefixcmp(arg, "--diff-filter="))
|
|
||||||
options->filter = arg + 14;
|
|
||||||
else if (!strcmp(arg, "--pickaxe-all"))
|
|
||||||
options->pickaxe_opts = DIFF_PICKAXE_ALL;
|
|
||||||
else if (!strcmp(arg, "--pickaxe-regex"))
|
|
||||||
options->pickaxe_opts = DIFF_PICKAXE_REGEX;
|
|
||||||
else if (!prefixcmp(arg, "-B")) {
|
else if (!prefixcmp(arg, "-B")) {
|
||||||
if ((options->break_opt =
|
if ((options->break_opt = diff_scoreopt_parse(arg)) == -1)
|
||||||
diff_scoreopt_parse(arg)) == -1)
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
else if (!prefixcmp(arg, "-M")) {
|
else if (!prefixcmp(arg, "-M")) {
|
||||||
if ((options->rename_score =
|
if ((options->rename_score = diff_scoreopt_parse(arg)) == -1)
|
||||||
diff_scoreopt_parse(arg)) == -1)
|
|
||||||
return -1;
|
return -1;
|
||||||
options->detect_rename = DIFF_DETECT_RENAME;
|
options->detect_rename = DIFF_DETECT_RENAME;
|
||||||
}
|
}
|
||||||
else if (!prefixcmp(arg, "-C")) {
|
else if (!prefixcmp(arg, "-C")) {
|
||||||
if (options->detect_rename == DIFF_DETECT_COPY)
|
if (options->detect_rename == DIFF_DETECT_COPY)
|
||||||
options->find_copies_harder = 1;
|
DIFF_OPT_SET(options, FIND_COPIES_HARDER);
|
||||||
if ((options->rename_score =
|
if ((options->rename_score = diff_scoreopt_parse(arg)) == -1)
|
||||||
diff_scoreopt_parse(arg)) == -1)
|
|
||||||
return -1;
|
return -1;
|
||||||
options->detect_rename = DIFF_DETECT_COPY;
|
options->detect_rename = DIFF_DETECT_COPY;
|
||||||
}
|
}
|
||||||
|
else if (!strcmp(arg, "--no-renames"))
|
||||||
|
options->detect_rename = 0;
|
||||||
|
|
||||||
|
/* xdiff options */
|
||||||
|
else if (!strcmp(arg, "-w") || !strcmp(arg, "--ignore-all-space"))
|
||||||
|
options->xdl_opts |= XDF_IGNORE_WHITESPACE;
|
||||||
|
else if (!strcmp(arg, "-b") || !strcmp(arg, "--ignore-space-change"))
|
||||||
|
options->xdl_opts |= XDF_IGNORE_WHITESPACE_CHANGE;
|
||||||
|
else if (!strcmp(arg, "--ignore-space-at-eol"))
|
||||||
|
options->xdl_opts |= XDF_IGNORE_WHITESPACE_AT_EOL;
|
||||||
|
|
||||||
|
/* flags options */
|
||||||
|
else if (!strcmp(arg, "--binary")) {
|
||||||
|
options->output_format |= DIFF_FORMAT_PATCH;
|
||||||
|
DIFF_OPT_SET(options, BINARY);
|
||||||
|
}
|
||||||
|
else if (!strcmp(arg, "--full-index"))
|
||||||
|
DIFF_OPT_SET(options, FULL_INDEX);
|
||||||
|
else if (!strcmp(arg, "-a") || !strcmp(arg, "--text"))
|
||||||
|
DIFF_OPT_SET(options, TEXT);
|
||||||
|
else if (!strcmp(arg, "-R"))
|
||||||
|
DIFF_OPT_SET(options, REVERSE_DIFF);
|
||||||
else if (!strcmp(arg, "--find-copies-harder"))
|
else if (!strcmp(arg, "--find-copies-harder"))
|
||||||
options->find_copies_harder = 1;
|
DIFF_OPT_SET(options, FIND_COPIES_HARDER);
|
||||||
else if (!strcmp(arg, "--follow"))
|
else if (!strcmp(arg, "--follow"))
|
||||||
options->follow_renames = 1;
|
DIFF_OPT_SET(options, FOLLOW_RENAMES);
|
||||||
|
else if (!strcmp(arg, "--color"))
|
||||||
|
DIFF_OPT_SET(options, COLOR_DIFF);
|
||||||
|
else if (!strcmp(arg, "--no-color"))
|
||||||
|
DIFF_OPT_CLR(options, COLOR_DIFF);
|
||||||
|
else if (!strcmp(arg, "--color-words"))
|
||||||
|
options->flags |= DIFF_OPT_COLOR_DIFF | DIFF_OPT_COLOR_DIFF_WORDS;
|
||||||
|
else if (!strcmp(arg, "--exit-code"))
|
||||||
|
DIFF_OPT_SET(options, EXIT_WITH_STATUS);
|
||||||
|
else if (!strcmp(arg, "--quiet"))
|
||||||
|
DIFF_OPT_SET(options, QUIET);
|
||||||
|
else if (!strcmp(arg, "--ext-diff"))
|
||||||
|
DIFF_OPT_SET(options, ALLOW_EXTERNAL);
|
||||||
|
else if (!strcmp(arg, "--no-ext-diff"))
|
||||||
|
DIFF_OPT_CLR(options, ALLOW_EXTERNAL);
|
||||||
|
|
||||||
|
/* misc options */
|
||||||
|
else if (!strcmp(arg, "-z"))
|
||||||
|
options->line_termination = 0;
|
||||||
|
else if (!prefixcmp(arg, "-l"))
|
||||||
|
options->rename_limit = strtoul(arg+2, NULL, 10);
|
||||||
|
else if (!prefixcmp(arg, "-S"))
|
||||||
|
options->pickaxe = arg + 2;
|
||||||
|
else if (!strcmp(arg, "--pickaxe-all"))
|
||||||
|
options->pickaxe_opts = DIFF_PICKAXE_ALL;
|
||||||
|
else if (!strcmp(arg, "--pickaxe-regex"))
|
||||||
|
options->pickaxe_opts = DIFF_PICKAXE_REGEX;
|
||||||
|
else if (!prefixcmp(arg, "-O"))
|
||||||
|
options->orderfile = arg + 2;
|
||||||
|
else if (!prefixcmp(arg, "--diff-filter="))
|
||||||
|
options->filter = arg + 14;
|
||||||
else if (!strcmp(arg, "--abbrev"))
|
else if (!strcmp(arg, "--abbrev"))
|
||||||
options->abbrev = DEFAULT_ABBREV;
|
options->abbrev = DEFAULT_ABBREV;
|
||||||
else if (!prefixcmp(arg, "--abbrev=")) {
|
else if (!prefixcmp(arg, "--abbrev=")) {
|
||||||
@ -2295,28 +2321,6 @@ int diff_opt_parse(struct diff_options *options, const char **av, int ac)
|
|||||||
else if (40 < options->abbrev)
|
else if (40 < options->abbrev)
|
||||||
options->abbrev = 40;
|
options->abbrev = 40;
|
||||||
}
|
}
|
||||||
else if (!strcmp(arg, "--color"))
|
|
||||||
options->color_diff = 1;
|
|
||||||
else if (!strcmp(arg, "--no-color"))
|
|
||||||
options->color_diff = 0;
|
|
||||||
else if (!strcmp(arg, "-w") || !strcmp(arg, "--ignore-all-space"))
|
|
||||||
options->xdl_opts |= XDF_IGNORE_WHITESPACE;
|
|
||||||
else if (!strcmp(arg, "-b") || !strcmp(arg, "--ignore-space-change"))
|
|
||||||
options->xdl_opts |= XDF_IGNORE_WHITESPACE_CHANGE;
|
|
||||||
else if (!strcmp(arg, "--ignore-space-at-eol"))
|
|
||||||
options->xdl_opts |= XDF_IGNORE_WHITESPACE_AT_EOL;
|
|
||||||
else if (!strcmp(arg, "--color-words"))
|
|
||||||
options->color_diff = options->color_diff_words = 1;
|
|
||||||
else if (!strcmp(arg, "--no-renames"))
|
|
||||||
options->detect_rename = 0;
|
|
||||||
else if (!strcmp(arg, "--exit-code"))
|
|
||||||
options->exit_with_status = 1;
|
|
||||||
else if (!strcmp(arg, "--quiet"))
|
|
||||||
options->quiet = 1;
|
|
||||||
else if (!strcmp(arg, "--ext-diff"))
|
|
||||||
options->allow_external = 1;
|
|
||||||
else if (!strcmp(arg, "--no-ext-diff"))
|
|
||||||
options->allow_external = 0;
|
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
return 1;
|
return 1;
|
||||||
@ -3071,7 +3075,7 @@ static void diffcore_skip_stat_unmatch(struct diff_options *diffopt)
|
|||||||
* to determine how many paths were dirty only
|
* to determine how many paths were dirty only
|
||||||
* due to stat info mismatch.
|
* due to stat info mismatch.
|
||||||
*/
|
*/
|
||||||
if (!diffopt->no_index)
|
if (!DIFF_OPT_TST(diffopt, NO_INDEX))
|
||||||
diffopt->skip_stat_unmatch++;
|
diffopt->skip_stat_unmatch++;
|
||||||
diff_free_filepair(p);
|
diff_free_filepair(p);
|
||||||
}
|
}
|
||||||
@ -3082,10 +3086,10 @@ static void diffcore_skip_stat_unmatch(struct diff_options *diffopt)
|
|||||||
|
|
||||||
void diffcore_std(struct diff_options *options)
|
void diffcore_std(struct diff_options *options)
|
||||||
{
|
{
|
||||||
if (options->quiet)
|
if (DIFF_OPT_TST(options, QUIET))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (options->skip_stat_unmatch && !options->find_copies_harder)
|
if (options->skip_stat_unmatch && !DIFF_OPT_TST(options, FIND_COPIES_HARDER))
|
||||||
diffcore_skip_stat_unmatch(options);
|
diffcore_skip_stat_unmatch(options);
|
||||||
if (options->break_opt != -1)
|
if (options->break_opt != -1)
|
||||||
diffcore_break(options->break_opt);
|
diffcore_break(options->break_opt);
|
||||||
@ -3100,7 +3104,10 @@ void diffcore_std(struct diff_options *options)
|
|||||||
diff_resolve_rename_copy();
|
diff_resolve_rename_copy();
|
||||||
diffcore_apply_filter(options->filter);
|
diffcore_apply_filter(options->filter);
|
||||||
|
|
||||||
options->has_changes = !!diff_queued_diff.nr;
|
if (diff_queued_diff.nr)
|
||||||
|
DIFF_OPT_SET(options, HAS_CHANGES);
|
||||||
|
else
|
||||||
|
DIFF_OPT_CLR(options, HAS_CHANGES);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -3124,7 +3131,7 @@ void diff_addremove(struct diff_options *options,
|
|||||||
* Before the final output happens, they are pruned after
|
* Before the final output happens, they are pruned after
|
||||||
* merged into rename/copy pairs as appropriate.
|
* merged into rename/copy pairs as appropriate.
|
||||||
*/
|
*/
|
||||||
if (options->reverse_diff)
|
if (DIFF_OPT_TST(options, REVERSE_DIFF))
|
||||||
addremove = (addremove == '+' ? '-' :
|
addremove = (addremove == '+' ? '-' :
|
||||||
addremove == '-' ? '+' : addremove);
|
addremove == '-' ? '+' : addremove);
|
||||||
|
|
||||||
@ -3139,7 +3146,7 @@ void diff_addremove(struct diff_options *options,
|
|||||||
fill_filespec(two, sha1, mode);
|
fill_filespec(two, sha1, mode);
|
||||||
|
|
||||||
diff_queue(&diff_queued_diff, one, two);
|
diff_queue(&diff_queued_diff, one, two);
|
||||||
options->has_changes = 1;
|
DIFF_OPT_SET(options, HAS_CHANGES);
|
||||||
}
|
}
|
||||||
|
|
||||||
void diff_change(struct diff_options *options,
|
void diff_change(struct diff_options *options,
|
||||||
@ -3151,7 +3158,7 @@ void diff_change(struct diff_options *options,
|
|||||||
char concatpath[PATH_MAX];
|
char concatpath[PATH_MAX];
|
||||||
struct diff_filespec *one, *two;
|
struct diff_filespec *one, *two;
|
||||||
|
|
||||||
if (options->reverse_diff) {
|
if (DIFF_OPT_TST(options, REVERSE_DIFF)) {
|
||||||
unsigned tmp;
|
unsigned tmp;
|
||||||
const unsigned char *tmp_c;
|
const unsigned char *tmp_c;
|
||||||
tmp = old_mode; old_mode = new_mode; new_mode = tmp;
|
tmp = old_mode; old_mode = new_mode; new_mode = tmp;
|
||||||
@ -3165,7 +3172,7 @@ void diff_change(struct diff_options *options,
|
|||||||
fill_filespec(two, new_sha1, new_mode);
|
fill_filespec(two, new_sha1, new_mode);
|
||||||
|
|
||||||
diff_queue(&diff_queued_diff, one, two);
|
diff_queue(&diff_queued_diff, one, two);
|
||||||
options->has_changes = 1;
|
DIFF_OPT_SET(options, HAS_CHANGES);
|
||||||
}
|
}
|
||||||
|
|
||||||
void diff_unmerge(struct diff_options *options,
|
void diff_unmerge(struct diff_options *options,
|
||||||
|
40
diff.h
40
diff.h
@ -43,26 +43,32 @@ typedef void (*diff_format_fn_t)(struct diff_queue_struct *q,
|
|||||||
|
|
||||||
#define DIFF_FORMAT_CALLBACK 0x1000
|
#define DIFF_FORMAT_CALLBACK 0x1000
|
||||||
|
|
||||||
|
#define DIFF_OPT_RECURSIVE (1 << 0)
|
||||||
|
#define DIFF_OPT_TREE_IN_RECURSIVE (1 << 1)
|
||||||
|
#define DIFF_OPT_BINARY (1 << 2)
|
||||||
|
#define DIFF_OPT_TEXT (1 << 3)
|
||||||
|
#define DIFF_OPT_FULL_INDEX (1 << 4)
|
||||||
|
#define DIFF_OPT_SILENT_ON_REMOVE (1 << 5)
|
||||||
|
#define DIFF_OPT_FIND_COPIES_HARDER (1 << 6)
|
||||||
|
#define DIFF_OPT_FOLLOW_RENAMES (1 << 7)
|
||||||
|
#define DIFF_OPT_COLOR_DIFF (1 << 8)
|
||||||
|
#define DIFF_OPT_COLOR_DIFF_WORDS (1 << 9)
|
||||||
|
#define DIFF_OPT_HAS_CHANGES (1 << 10)
|
||||||
|
#define DIFF_OPT_QUIET (1 << 11)
|
||||||
|
#define DIFF_OPT_NO_INDEX (1 << 12)
|
||||||
|
#define DIFF_OPT_ALLOW_EXTERNAL (1 << 13)
|
||||||
|
#define DIFF_OPT_EXIT_WITH_STATUS (1 << 14)
|
||||||
|
#define DIFF_OPT_REVERSE_DIFF (1 << 15)
|
||||||
|
#define DIFF_OPT_TST(opts, flag) ((opts)->flags & DIFF_OPT_##flag)
|
||||||
|
#define DIFF_OPT_SET(opts, flag) ((opts)->flags |= DIFF_OPT_##flag)
|
||||||
|
#define DIFF_OPT_CLR(opts, flag) ((opts)->flags &= ~DIFF_OPT_##flag)
|
||||||
|
|
||||||
struct diff_options {
|
struct diff_options {
|
||||||
const char *filter;
|
const char *filter;
|
||||||
const char *orderfile;
|
const char *orderfile;
|
||||||
const char *pickaxe;
|
const char *pickaxe;
|
||||||
const char *single_follow;
|
const char *single_follow;
|
||||||
unsigned recursive:1,
|
unsigned flags;
|
||||||
tree_in_recursive:1,
|
|
||||||
binary:1,
|
|
||||||
text:1,
|
|
||||||
full_index:1,
|
|
||||||
silent_on_remove:1,
|
|
||||||
find_copies_harder:1,
|
|
||||||
follow_renames:1,
|
|
||||||
color_diff:1,
|
|
||||||
color_diff_words:1,
|
|
||||||
has_changes:1,
|
|
||||||
quiet:1,
|
|
||||||
no_index:1,
|
|
||||||
allow_external:1,
|
|
||||||
exit_with_status:1;
|
|
||||||
int context;
|
int context;
|
||||||
int break_opt;
|
int break_opt;
|
||||||
int detect_rename;
|
int detect_rename;
|
||||||
@ -71,7 +77,6 @@ struct diff_options {
|
|||||||
int output_format;
|
int output_format;
|
||||||
int pickaxe_opts;
|
int pickaxe_opts;
|
||||||
int rename_score;
|
int rename_score;
|
||||||
int reverse_diff;
|
|
||||||
int rename_limit;
|
int rename_limit;
|
||||||
int setup;
|
int setup;
|
||||||
int abbrev;
|
int abbrev;
|
||||||
@ -105,6 +110,9 @@ enum color_diff {
|
|||||||
DIFF_WHITESPACE = 7,
|
DIFF_WHITESPACE = 7,
|
||||||
};
|
};
|
||||||
const char *diff_get_color(int diff_use_color, enum color_diff ix);
|
const char *diff_get_color(int diff_use_color, enum color_diff ix);
|
||||||
|
#define diff_get_color_opt(o, ix) \
|
||||||
|
diff_get_color(DIFF_OPT_TST((o), COLOR_DIFF), ix)
|
||||||
|
|
||||||
|
|
||||||
extern const char mime_boundary_leader[];
|
extern const char mime_boundary_leader[];
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define MSB(x, bits) ((x) & TYPEOF(x)(~0ULL << (sizeof(x) * 8 - (bits))))
|
#define MSB(x, bits) ((x) & TYPEOF(x)(~0ULL << (sizeof(x) * 8 - (bits))))
|
||||||
|
#define HAS_MULTI_BITS(i) ((i) & ((i) - 1)) /* checks if an integer has more than 1 bit set */
|
||||||
|
|
||||||
/* Approximation of the length of the decimal representation of this type. */
|
/* Approximation of the length of the decimal representation of this type. */
|
||||||
#define decimal_length(x) ((int)(sizeof(x) * 2.56 + 0.5) + 1)
|
#define decimal_length(x) ((int)(sizeof(x) * 2.56 + 0.5) + 1)
|
||||||
|
@ -245,8 +245,7 @@ void show_log(struct rev_info *opt, const char *sep)
|
|||||||
opt->diffopt.stat_sep = buffer;
|
opt->diffopt.stat_sep = buffer;
|
||||||
}
|
}
|
||||||
} else if (opt->commit_format != CMIT_FMT_USERFORMAT) {
|
} else if (opt->commit_format != CMIT_FMT_USERFORMAT) {
|
||||||
fputs(diff_get_color(opt->diffopt.color_diff, DIFF_COMMIT),
|
fputs(diff_get_color_opt(&opt->diffopt, DIFF_COMMIT), stdout);
|
||||||
stdout);
|
|
||||||
if (opt->commit_format != CMIT_FMT_ONELINE)
|
if (opt->commit_format != CMIT_FMT_ONELINE)
|
||||||
fputs("commit ", stdout);
|
fputs("commit ", stdout);
|
||||||
if (commit->object.flags & BOUNDARY)
|
if (commit->object.flags & BOUNDARY)
|
||||||
@ -266,8 +265,7 @@ void show_log(struct rev_info *opt, const char *sep)
|
|||||||
diff_unique_abbrev(parent->object.sha1,
|
diff_unique_abbrev(parent->object.sha1,
|
||||||
abbrev_commit));
|
abbrev_commit));
|
||||||
show_decorations(commit);
|
show_decorations(commit);
|
||||||
printf("%s",
|
printf("%s", diff_get_color_opt(&opt->diffopt, DIFF_RESET));
|
||||||
diff_get_color(opt->diffopt.color_diff, DIFF_RESET));
|
|
||||||
putchar(opt->commit_format == CMIT_FMT_ONELINE ? ' ' : '\n');
|
putchar(opt->commit_format == CMIT_FMT_ONELINE ? ' ' : '\n');
|
||||||
if (opt->reflog_info) {
|
if (opt->reflog_info) {
|
||||||
show_reflog_message(opt->reflog_info,
|
show_reflog_message(opt->reflog_info,
|
||||||
|
@ -366,7 +366,7 @@ static struct path_list *get_renames(struct tree *tree,
|
|||||||
|
|
||||||
renames = xcalloc(1, sizeof(struct path_list));
|
renames = xcalloc(1, sizeof(struct path_list));
|
||||||
diff_setup(&opts);
|
diff_setup(&opts);
|
||||||
opts.recursive = 1;
|
DIFF_OPT_SET(&opts, RECURSIVE);
|
||||||
opts.detect_rename = DIFF_DETECT_RENAME;
|
opts.detect_rename = DIFF_DETECT_RENAME;
|
||||||
opts.rename_limit = rename_limit;
|
opts.rename_limit = rename_limit;
|
||||||
opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
||||||
|
@ -40,24 +40,53 @@ static int get_value(struct optparse_t *p,
|
|||||||
const struct option *opt, int flags)
|
const struct option *opt, int flags)
|
||||||
{
|
{
|
||||||
const char *s, *arg;
|
const char *s, *arg;
|
||||||
arg = p->opt ? p->opt : (p->argc > 1 ? p->argv[1] : NULL);
|
const int unset = flags & OPT_UNSET;
|
||||||
|
|
||||||
if (p->opt && (flags & OPT_UNSET))
|
if (unset && p->opt)
|
||||||
return opterror(opt, "takes no value", flags);
|
return opterror(opt, "takes no value", flags);
|
||||||
|
if (unset && (opt->flags & PARSE_OPT_NONEG))
|
||||||
|
return opterror(opt, "isn't available", flags);
|
||||||
|
|
||||||
|
if (!(flags & OPT_SHORT) && p->opt) {
|
||||||
switch (opt->type) {
|
switch (opt->type) {
|
||||||
|
case OPTION_CALLBACK:
|
||||||
|
if (!(opt->flags & PARSE_OPT_NOARG))
|
||||||
|
break;
|
||||||
|
/* FALLTHROUGH */
|
||||||
case OPTION_BOOLEAN:
|
case OPTION_BOOLEAN:
|
||||||
if (!(flags & OPT_SHORT) && p->opt)
|
case OPTION_BIT:
|
||||||
|
case OPTION_SET_INT:
|
||||||
|
case OPTION_SET_PTR:
|
||||||
return opterror(opt, "takes no value", flags);
|
return opterror(opt, "takes no value", flags);
|
||||||
if (flags & OPT_UNSET)
|
default:
|
||||||
*(int *)opt->value = 0;
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
arg = p->opt ? p->opt : (p->argc > 1 ? p->argv[1] : NULL);
|
||||||
|
switch (opt->type) {
|
||||||
|
case OPTION_BIT:
|
||||||
|
if (unset)
|
||||||
|
*(int *)opt->value &= ~opt->defval;
|
||||||
else
|
else
|
||||||
(*(int *)opt->value)++;
|
*(int *)opt->value |= opt->defval;
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
case OPTION_BOOLEAN:
|
||||||
|
*(int *)opt->value = unset ? 0 : *(int *)opt->value + 1;
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
case OPTION_SET_INT:
|
||||||
|
*(int *)opt->value = unset ? 0 : opt->defval;
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
case OPTION_SET_PTR:
|
||||||
|
*(void **)opt->value = unset ? NULL : (void *)opt->defval;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case OPTION_STRING:
|
case OPTION_STRING:
|
||||||
if (flags & OPT_UNSET) {
|
if (unset) {
|
||||||
*(const char **)opt->value = (const char *)NULL;
|
*(const char **)opt->value = NULL;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (opt->flags & PARSE_OPT_OPTARG && (!arg || *arg == '-')) {
|
if (opt->flags & PARSE_OPT_OPTARG && (!arg || *arg == '-')) {
|
||||||
@ -70,13 +99,10 @@ static int get_value(struct optparse_t *p,
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case OPTION_CALLBACK:
|
case OPTION_CALLBACK:
|
||||||
if (flags & OPT_UNSET)
|
if (unset)
|
||||||
return (*opt->callback)(opt, NULL, 1);
|
return (*opt->callback)(opt, NULL, 1);
|
||||||
if (opt->flags & PARSE_OPT_NOARG) {
|
if (opt->flags & PARSE_OPT_NOARG)
|
||||||
if (p->opt && !(flags & OPT_SHORT))
|
|
||||||
return opterror(opt, "takes no value", flags);
|
|
||||||
return (*opt->callback)(opt, NULL, 0);
|
return (*opt->callback)(opt, NULL, 0);
|
||||||
}
|
|
||||||
if (opt->flags & PARSE_OPT_OPTARG && (!arg || *arg == '-'))
|
if (opt->flags & PARSE_OPT_OPTARG && (!arg || *arg == '-'))
|
||||||
return (*opt->callback)(opt, NULL, 0);
|
return (*opt->callback)(opt, NULL, 0);
|
||||||
if (!arg)
|
if (!arg)
|
||||||
@ -84,7 +110,7 @@ static int get_value(struct optparse_t *p,
|
|||||||
return (*opt->callback)(opt, get_arg(p), 0);
|
return (*opt->callback)(opt, get_arg(p), 0);
|
||||||
|
|
||||||
case OPTION_INTEGER:
|
case OPTION_INTEGER:
|
||||||
if (flags & OPT_UNSET) {
|
if (unset) {
|
||||||
*(int *)opt->value = 0;
|
*(int *)opt->value = 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -292,7 +318,7 @@ void usage_with_options(const char * const *usagestr,
|
|||||||
pos += fprintf(stderr, " ...");
|
pos += fprintf(stderr, " ...");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default: /* OPTION_{BIT,BOOLEAN,SET_INT,SET_PTR} */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -311,6 +337,7 @@ void usage_with_options(const char * const *usagestr,
|
|||||||
|
|
||||||
/*----- some often used options -----*/
|
/*----- some often used options -----*/
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
|
|
||||||
int parse_opt_abbrev_cb(const struct option *opt, const char *arg, int unset)
|
int parse_opt_abbrev_cb(const struct option *opt, const char *arg, int unset)
|
||||||
{
|
{
|
||||||
int v;
|
int v;
|
||||||
|
@ -2,9 +2,15 @@
|
|||||||
#define PARSE_OPTIONS_H
|
#define PARSE_OPTIONS_H
|
||||||
|
|
||||||
enum parse_opt_type {
|
enum parse_opt_type {
|
||||||
|
/* special types */
|
||||||
OPTION_END,
|
OPTION_END,
|
||||||
OPTION_GROUP,
|
OPTION_GROUP,
|
||||||
OPTION_BOOLEAN,
|
/* options with no arguments */
|
||||||
|
OPTION_BIT,
|
||||||
|
OPTION_BOOLEAN, /* _INCR would have been a better name */
|
||||||
|
OPTION_SET_INT,
|
||||||
|
OPTION_SET_PTR,
|
||||||
|
/* options with arguments (usually) */
|
||||||
OPTION_STRING,
|
OPTION_STRING,
|
||||||
OPTION_INTEGER,
|
OPTION_INTEGER,
|
||||||
OPTION_CALLBACK,
|
OPTION_CALLBACK,
|
||||||
@ -17,6 +23,7 @@ enum parse_opt_flags {
|
|||||||
enum parse_opt_option_flags {
|
enum parse_opt_option_flags {
|
||||||
PARSE_OPT_OPTARG = 1,
|
PARSE_OPT_OPTARG = 1,
|
||||||
PARSE_OPT_NOARG = 2,
|
PARSE_OPT_NOARG = 2,
|
||||||
|
PARSE_OPT_NONEG = 4,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct option;
|
struct option;
|
||||||
@ -49,12 +56,15 @@ typedef int parse_opt_cb(const struct option *, const char *arg, int unset);
|
|||||||
* mask of parse_opt_option_flags.
|
* mask of parse_opt_option_flags.
|
||||||
* PARSE_OPT_OPTARG: says that the argument is optionnal (not for BOOLEANs)
|
* PARSE_OPT_OPTARG: says that the argument is optionnal (not for BOOLEANs)
|
||||||
* PARSE_OPT_NOARG: says that this option takes no argument, for CALLBACKs
|
* PARSE_OPT_NOARG: says that this option takes no argument, for CALLBACKs
|
||||||
|
* PARSE_OPT_NONEG: says that this option cannot be negated
|
||||||
*
|
*
|
||||||
* `callback`::
|
* `callback`::
|
||||||
* pointer to the callback to use for OPTION_CALLBACK.
|
* pointer to the callback to use for OPTION_CALLBACK.
|
||||||
*
|
*
|
||||||
* `defval`::
|
* `defval`::
|
||||||
* default value to fill (*->value) with for PARSE_OPT_OPTARG.
|
* default value to fill (*->value) with for PARSE_OPT_OPTARG.
|
||||||
|
* OPTION_{BIT,SET_INT,SET_PTR} store the {mask,integer,pointer} to put in
|
||||||
|
* the value when met.
|
||||||
* CALLBACKS can use it like they want.
|
* CALLBACKS can use it like they want.
|
||||||
*/
|
*/
|
||||||
struct option {
|
struct option {
|
||||||
@ -72,7 +82,10 @@ struct option {
|
|||||||
|
|
||||||
#define OPT_END() { OPTION_END }
|
#define OPT_END() { OPTION_END }
|
||||||
#define OPT_GROUP(h) { OPTION_GROUP, 0, NULL, NULL, NULL, (h) }
|
#define OPT_GROUP(h) { OPTION_GROUP, 0, NULL, NULL, NULL, (h) }
|
||||||
|
#define OPT_BIT(s, l, v, h, b) { OPTION_BIT, (s), (l), (v), NULL, (h), 0, NULL, (b) }
|
||||||
#define OPT_BOOLEAN(s, l, v, h) { OPTION_BOOLEAN, (s), (l), (v), NULL, (h) }
|
#define OPT_BOOLEAN(s, l, v, h) { OPTION_BOOLEAN, (s), (l), (v), NULL, (h) }
|
||||||
|
#define OPT_SET_INT(s, l, v, h, i) { OPTION_SET_INT, (s), (l), (v), NULL, (h), 0, NULL, (i) }
|
||||||
|
#define OPT_SET_PTR(s, l, v, h, p) { OPTION_SET_PTR, (s), (l), (v), NULL, (h), 0, NULL, (p) }
|
||||||
#define OPT_INTEGER(s, l, v, h) { OPTION_INTEGER, (s), (l), (v), NULL, (h) }
|
#define OPT_INTEGER(s, l, v, h) { OPTION_INTEGER, (s), (l), (v), NULL, (h) }
|
||||||
#define OPT_STRING(s, l, v, a, h) { OPTION_STRING, (s), (l), (v), (a), (h) }
|
#define OPT_STRING(s, l, v, a, h) { OPTION_STRING, (s), (l), (v), (a), (h) }
|
||||||
#define OPT_CALLBACK(s, l, v, a, h, f) \
|
#define OPT_CALLBACK(s, l, v, a, h, f) \
|
||||||
|
@ -121,7 +121,7 @@ int init_patch_ids(struct patch_ids *ids)
|
|||||||
{
|
{
|
||||||
memset(ids, 0, sizeof(*ids));
|
memset(ids, 0, sizeof(*ids));
|
||||||
diff_setup(&ids->diffopts);
|
diff_setup(&ids->diffopts);
|
||||||
ids->diffopts.recursive = 1;
|
DIFF_OPT_SET(&ids->diffopts, RECURSIVE);
|
||||||
if (diff_setup_done(&ids->diffopts) < 0)
|
if (diff_setup_done(&ids->diffopts) < 0)
|
||||||
return error("diff_setup_done failed");
|
return error("diff_setup_done failed");
|
||||||
return 0;
|
return 0;
|
||||||
|
22
revision.c
22
revision.c
@ -250,7 +250,7 @@ static void file_add_remove(struct diff_options *options,
|
|||||||
}
|
}
|
||||||
tree_difference = diff;
|
tree_difference = diff;
|
||||||
if (tree_difference == REV_TREE_DIFFERENT)
|
if (tree_difference == REV_TREE_DIFFERENT)
|
||||||
options->has_changes = 1;
|
DIFF_OPT_SET(options, HAS_CHANGES);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void file_change(struct diff_options *options,
|
static void file_change(struct diff_options *options,
|
||||||
@ -260,7 +260,7 @@ static void file_change(struct diff_options *options,
|
|||||||
const char *base, const char *path)
|
const char *base, const char *path)
|
||||||
{
|
{
|
||||||
tree_difference = REV_TREE_DIFFERENT;
|
tree_difference = REV_TREE_DIFFERENT;
|
||||||
options->has_changes = 1;
|
DIFF_OPT_SET(options, HAS_CHANGES);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rev_compare_tree(struct rev_info *revs, struct tree *t1, struct tree *t2)
|
static int rev_compare_tree(struct rev_info *revs, struct tree *t1, struct tree *t2)
|
||||||
@ -270,7 +270,7 @@ static int rev_compare_tree(struct rev_info *revs, struct tree *t1, struct tree
|
|||||||
if (!t2)
|
if (!t2)
|
||||||
return REV_TREE_DIFFERENT;
|
return REV_TREE_DIFFERENT;
|
||||||
tree_difference = REV_TREE_SAME;
|
tree_difference = REV_TREE_SAME;
|
||||||
revs->pruning.has_changes = 0;
|
DIFF_OPT_CLR(&revs->pruning, HAS_CHANGES);
|
||||||
if (diff_tree_sha1(t1->object.sha1, t2->object.sha1, "",
|
if (diff_tree_sha1(t1->object.sha1, t2->object.sha1, "",
|
||||||
&revs->pruning) < 0)
|
&revs->pruning) < 0)
|
||||||
return REV_TREE_DIFFERENT;
|
return REV_TREE_DIFFERENT;
|
||||||
@ -294,7 +294,7 @@ static int rev_same_tree_as_empty(struct rev_info *revs, struct tree *t1)
|
|||||||
init_tree_desc(&empty, "", 0);
|
init_tree_desc(&empty, "", 0);
|
||||||
|
|
||||||
tree_difference = REV_TREE_SAME;
|
tree_difference = REV_TREE_SAME;
|
||||||
revs->pruning.has_changes = 0;
|
DIFF_OPT_CLR(&revs->pruning, HAS_CHANGES);
|
||||||
retval = diff_tree(&empty, &real, "", &revs->pruning);
|
retval = diff_tree(&empty, &real, "", &revs->pruning);
|
||||||
free(tree);
|
free(tree);
|
||||||
|
|
||||||
@ -662,8 +662,8 @@ void init_revisions(struct rev_info *revs, const char *prefix)
|
|||||||
revs->abbrev = DEFAULT_ABBREV;
|
revs->abbrev = DEFAULT_ABBREV;
|
||||||
revs->ignore_merges = 1;
|
revs->ignore_merges = 1;
|
||||||
revs->simplify_history = 1;
|
revs->simplify_history = 1;
|
||||||
revs->pruning.recursive = 1;
|
DIFF_OPT_SET(&revs->pruning, RECURSIVE);
|
||||||
revs->pruning.quiet = 1;
|
DIFF_OPT_SET(&revs->pruning, QUIET);
|
||||||
revs->pruning.add_remove = file_add_remove;
|
revs->pruning.add_remove = file_add_remove;
|
||||||
revs->pruning.change = file_change;
|
revs->pruning.change = file_change;
|
||||||
revs->lifo = 1;
|
revs->lifo = 1;
|
||||||
@ -1054,13 +1054,13 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch
|
|||||||
}
|
}
|
||||||
if (!strcmp(arg, "-r")) {
|
if (!strcmp(arg, "-r")) {
|
||||||
revs->diff = 1;
|
revs->diff = 1;
|
||||||
revs->diffopt.recursive = 1;
|
DIFF_OPT_SET(&revs->diffopt, RECURSIVE);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!strcmp(arg, "-t")) {
|
if (!strcmp(arg, "-t")) {
|
||||||
revs->diff = 1;
|
revs->diff = 1;
|
||||||
revs->diffopt.recursive = 1;
|
DIFF_OPT_SET(&revs->diffopt, RECURSIVE);
|
||||||
revs->diffopt.tree_in_recursive = 1;
|
DIFF_OPT_SET(&revs->diffopt, TREE_IN_RECURSIVE);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!strcmp(arg, "-m")) {
|
if (!strcmp(arg, "-m")) {
|
||||||
@ -1242,7 +1242,7 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch
|
|||||||
revs->diff = 1;
|
revs->diff = 1;
|
||||||
|
|
||||||
/* Pickaxe and rename following needs diffs */
|
/* Pickaxe and rename following needs diffs */
|
||||||
if (revs->diffopt.pickaxe || revs->diffopt.follow_renames)
|
if (revs->diffopt.pickaxe || DIFF_OPT_TST(&revs->diffopt, FOLLOW_RENAMES))
|
||||||
revs->diff = 1;
|
revs->diff = 1;
|
||||||
|
|
||||||
if (revs->topo_order)
|
if (revs->topo_order)
|
||||||
@ -1251,7 +1251,7 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch
|
|||||||
if (revs->prune_data) {
|
if (revs->prune_data) {
|
||||||
diff_tree_setup_paths(revs->prune_data, &revs->pruning);
|
diff_tree_setup_paths(revs->prune_data, &revs->pruning);
|
||||||
/* Can't prune commits with rename following: the paths change.. */
|
/* Can't prune commits with rename following: the paths change.. */
|
||||||
if (!revs->diffopt.follow_renames)
|
if (!DIFF_OPT_TST(&revs->diffopt, FOLLOW_RENAMES))
|
||||||
revs->prune_fn = try_to_simplify_commit;
|
revs->prune_fn = try_to_simplify_commit;
|
||||||
if (!revs->full_diff)
|
if (!revs->full_diff)
|
||||||
diff_tree_setup_paths(revs->prune_data, &revs->diffopt);
|
diff_tree_setup_paths(revs->prune_data, &revs->diffopt);
|
||||||
|
14
tree-diff.c
14
tree-diff.c
@ -39,7 +39,7 @@ static int compare_tree_entry(struct tree_desc *t1, struct tree_desc *t2, const
|
|||||||
show_entry(opt, "+", t2, base, baselen);
|
show_entry(opt, "+", t2, base, baselen);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (!opt->find_copies_harder && !hashcmp(sha1, sha2) && mode1 == mode2)
|
if (!DIFF_OPT_TST(opt, FIND_COPIES_HARDER) && !hashcmp(sha1, sha2) && mode1 == mode2)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -52,10 +52,10 @@ static int compare_tree_entry(struct tree_desc *t1, struct tree_desc *t2, const
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (opt->recursive && S_ISDIR(mode1)) {
|
if (DIFF_OPT_TST(opt, RECURSIVE) && S_ISDIR(mode1)) {
|
||||||
int retval;
|
int retval;
|
||||||
char *newbase = malloc_base(base, baselen, path1, pathlen1);
|
char *newbase = malloc_base(base, baselen, path1, pathlen1);
|
||||||
if (opt->tree_in_recursive)
|
if (DIFF_OPT_TST(opt, TREE_IN_RECURSIVE))
|
||||||
opt->change(opt, mode1, mode2,
|
opt->change(opt, mode1, mode2,
|
||||||
sha1, sha2, base, path1);
|
sha1, sha2, base, path1);
|
||||||
retval = diff_tree_sha1(sha1, sha2, newbase, opt);
|
retval = diff_tree_sha1(sha1, sha2, newbase, opt);
|
||||||
@ -206,7 +206,7 @@ static void show_entry(struct diff_options *opt, const char *prefix, struct tree
|
|||||||
const char *path;
|
const char *path;
|
||||||
const unsigned char *sha1 = tree_entry_extract(desc, &path, &mode);
|
const unsigned char *sha1 = tree_entry_extract(desc, &path, &mode);
|
||||||
|
|
||||||
if (opt->recursive && S_ISDIR(mode)) {
|
if (DIFF_OPT_TST(opt, RECURSIVE) && S_ISDIR(mode)) {
|
||||||
enum object_type type;
|
enum object_type type;
|
||||||
int pathlen = tree_entry_len(path, sha1);
|
int pathlen = tree_entry_len(path, sha1);
|
||||||
char *newbase = malloc_base(base, baselen, path, pathlen);
|
char *newbase = malloc_base(base, baselen, path, pathlen);
|
||||||
@ -257,7 +257,7 @@ int diff_tree(struct tree_desc *t1, struct tree_desc *t2, const char *base, stru
|
|||||||
int baselen = strlen(base);
|
int baselen = strlen(base);
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (opt->quiet && opt->has_changes)
|
if (DIFF_OPT_TST(opt, QUIET) && DIFF_OPT_TST(opt, HAS_CHANGES))
|
||||||
break;
|
break;
|
||||||
if (opt->nr_paths) {
|
if (opt->nr_paths) {
|
||||||
skip_uninteresting(t1, base, baselen, opt);
|
skip_uninteresting(t1, base, baselen, opt);
|
||||||
@ -315,7 +315,7 @@ static void try_to_follow_renames(struct tree_desc *t1, struct tree_desc *t2, co
|
|||||||
q->nr = 0;
|
q->nr = 0;
|
||||||
|
|
||||||
diff_setup(&diff_opts);
|
diff_setup(&diff_opts);
|
||||||
diff_opts.recursive = 1;
|
DIFF_OPT_SET(&diff_opts, RECURSIVE);
|
||||||
diff_opts.detect_rename = DIFF_DETECT_RENAME;
|
diff_opts.detect_rename = DIFF_DETECT_RENAME;
|
||||||
diff_opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
diff_opts.output_format = DIFF_FORMAT_NO_OUTPUT;
|
||||||
diff_opts.single_follow = opt->paths[0];
|
diff_opts.single_follow = opt->paths[0];
|
||||||
@ -380,7 +380,7 @@ int diff_tree_sha1(const unsigned char *old, const unsigned char *new, const cha
|
|||||||
init_tree_desc(&t1, tree1, size1);
|
init_tree_desc(&t1, tree1, size1);
|
||||||
init_tree_desc(&t2, tree2, size2);
|
init_tree_desc(&t2, tree2, size2);
|
||||||
retval = diff_tree(&t1, &t2, base, opt);
|
retval = diff_tree(&t1, &t2, base, opt);
|
||||||
if (opt->follow_renames && diff_might_be_rename()) {
|
if (DIFF_OPT_TST(opt, FOLLOW_RENAMES) && diff_might_be_rename()) {
|
||||||
init_tree_desc(&t1, tree1, size1);
|
init_tree_desc(&t1, tree1, size1);
|
||||||
init_tree_desc(&t2, tree2, size2);
|
init_tree_desc(&t2, tree2, size2);
|
||||||
try_to_follow_renames(&t1, &t2, base, opt);
|
try_to_follow_renames(&t1, &t2, base, opt);
|
||||||
|
Loading…
Reference in New Issue
Block a user