X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=builtin-prune.c;h=44df59e4a70f84cdebac94f2591765ada8d4b92d;hb=f57882505efe05990102a0d96b37c09baadae03d;hp=6f0ba0d04d789f17e3f0136a3591a9465af7e71d;hpb=b4d2b04c9b6dc42c0bcf0513b9d8f731ec26db82;p=git.git diff --git a/builtin-prune.c b/builtin-prune.c index 6f0ba0d04..44df59e4a 100644 --- a/builtin-prune.c +++ b/builtin-prune.c @@ -10,19 +10,12 @@ static int show_only; static int prune_object(char *path, const char *filename, const unsigned char *sha1) { - char buf[20]; - const char *type; - if (show_only) { - if (sha1_object_info(sha1, buf, NULL)) - type = "unknown"; - else - type = buf; - printf("%s %s\n", sha1_to_hex(sha1), type); - return 0; - } - unlink(mkpath("%s/%s", path, filename)); - rmdir(path); + enum object_type type = sha1_object_info(sha1, NULL); + printf("%s %s\n", sha1_to_hex(sha1), + (type > 0) ? typename(type) : "unknown"); + } else + unlink(mkpath("%s/%s", path, filename)); return 0; } @@ -65,6 +58,8 @@ static int prune_dir(int i, char *path) } fprintf(stderr, "bad sha1 file: %s/%s\n", path, de->d_name); } + if (!show_only) + rmdir(path); closedir(dir); return 0; }