X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=show-diff.c;h=fdd7dd4b0cc8c92a18ddaf0bcf8c9675fcab303b;hb=3a663fd9842aaa9e232ab43a811d11f1d7f0b7bc;hp=a73e8e883efd39d3ad9a4318c17a1f661a259c94;hpb=0a7668e99f513bd481ef6c4bc69995c434b91cb1;p=git.git diff --git a/show-diff.c b/show-diff.c index a73e8e88..fdd7dd4b 100644 --- a/show-diff.c +++ b/show-diff.c @@ -4,13 +4,14 @@ * Copyright (C) Linus Torvalds, 2005 */ #include "cache.h" +#include "diff.h" -static const char *show_diff_usage = "show-diff [-q] [-s] [-z] [paths...]"; +static const char *show_diff_usage = +"show-diff [-p] [-q] [-r] [-z] [paths...]"; -static int recursive = 0; +static int generate_patch = 0; static int line_termination = '\n'; static int silent = 0; -static int silent_on_nonexisting_files = 0; static int matches_pathspec(struct cache_entry *ce, char **spec, int cnt) { @@ -27,27 +28,57 @@ static int matches_pathspec(struct cache_entry *ce, char **spec, int cnt) return 0; } -static void show_file(const char *prefix, struct cache_entry *ce) +static void show_unmerge(const char *path) { - printf("%s%o\t%s\t%s\t%s%c", prefix, ntohl(ce->ce_mode), "blob", - sha1_to_hex(ce->sha1), ce->name, line_termination); + if (generate_patch) + diff_unmerge(path); + else + printf("U %s%c", path, line_termination); +} + +static void show_file(int pfx, struct cache_entry *ce) +{ + if (generate_patch) + diff_addremove(pfx, ntohl(ce->ce_mode), ce->sha1, + ce->name, NULL); + else + printf("%c%06o\t%s\t%s\t%s%c", + pfx, ntohl(ce->ce_mode), "blob", + sha1_to_hex(ce->sha1), ce->name, line_termination); +} + +static void show_modified(int oldmode, int mode, + const char *old_sha1, const char *sha1, + char *path) +{ + char old_sha1_hex[41]; + strcpy(old_sha1_hex, sha1_to_hex(old_sha1)); + + if (generate_patch) + diff_change(oldmode, mode, old_sha1, sha1, path, NULL); + else + printf("*%06o->%06o\tblob\t%s->%s\t%s%c", + oldmode, mode, old_sha1_hex, sha1_to_hex(sha1), path, + line_termination); } int main(int argc, char **argv) { - static const char null_sha1_hex[] = "0000000000000000000000000000000000000000"; + static const char null_sha1[20] = { 0, }; int entries = read_cache(); int i; while (1 < argc && argv[1][0] == '-') { - if (!strcmp(argv[1], "-s")) - silent_on_nonexisting_files = silent = 1; + if (!strcmp(argv[1], "-p")) + generate_patch = 1; else if (!strcmp(argv[1], "-q")) - silent_on_nonexisting_files = 1; + silent = 1; + else if (!strcmp(argv[1], "-r")) + ; /* no-op */ + else if (!strcmp(argv[1], "-s")) + ; /* no-op */ else if (!strcmp(argv[1], "-z")) line_termination = 0; - else if (!strcmp(argv[1], "-r")) - recursive = 1; /* No-op */ else usage(show_diff_usage); argv++; argc--; @@ -72,8 +103,7 @@ int main(int argc, char **argv) continue; if (ce_stage(ce)) { - show_file("U", ce); - + show_unmerge(ce->name); while (i < entries && !strcmp(ce->name, active_cache[i]->name)) i++; @@ -86,9 +116,9 @@ int main(int argc, char **argv) perror(ce->name); continue; } - if (silent_on_nonexisting_files) + if (silent) continue; - show_file("-", ce); + show_file('-', ce); continue; } changed = cache_match_stat(ce, &st); @@ -98,10 +128,8 @@ int main(int argc, char **argv) oldmode = ntohl(ce->ce_mode); mode = S_IFREG | ce_permissions(st.st_mode); - printf("*%o->%o\t%s\t%s->%s\t%s%c", - oldmode, mode, "blob", - sha1_to_hex(ce->sha1), null_sha1_hex, - ce->name, line_termination); + show_modified(oldmode, mode, ce->sha1, null_sha1, + ce->name); } return 0; }