X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=diff-files.c;h=38599b5b755df431e3e061df8a304698cc4496fc;hb=650e4be59b9f385f56e5829d97d09e8440f174b8;hp=96d2c7f19f03aed937d325e12a2d397634a92e1e;hpb=17712991a59824a8d22d5115c0c154d3122fc17b;p=git.git diff --git a/diff-files.c b/diff-files.c index 96d2c7f1..38599b5b 100644 --- a/diff-files.c +++ b/diff-files.c @@ -38,9 +38,14 @@ int main(int argc, const char **argv) const char *prefix = setup_git_directory(); int entries, i; - git_config(git_default_config); + git_config(git_diff_config); diff_setup(&diff_options); while (1 < argc && argv[1][0] == '-') { + if (!strcmp(argv[1], "--")) { + argv++; + argc--; + break; + } if (!strcmp(argv[1], "-q")) silent = 1; else if (!strcmp(argv[1], "-r")) @@ -81,7 +86,7 @@ int main(int argc, const char **argv) for (i = 0; i < entries; i++) { struct stat st; - unsigned int oldmode; + unsigned int oldmode, newmode; struct cache_entry *ce = active_cache[i]; int changed; @@ -111,7 +116,13 @@ int main(int argc, const char **argv) if (!changed && !diff_options.find_copies_harder) continue; oldmode = ntohl(ce->ce_mode); - show_modified(oldmode, DIFF_FILE_CANON_MODE(st.st_mode), + + newmode = DIFF_FILE_CANON_MODE(st.st_mode); + if (!trust_executable_bit && + S_ISREG(newmode) && S_ISREG(oldmode) && + ((newmode ^ oldmode) == 0111)) + newmode = oldmode; + show_modified(oldmode, newmode, ce->sha1, (changed ? null_sha1 : ce->sha1), ce->name); }