X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=unpack-objects.c;h=19874d004a03531b12922f1bd48a28f18e8d2897;hb=0b124bb4bf8eafae8a4eae9c1fc44bf63da2e62e;hp=6383db94acc26ed3dc7f1c55abeef06db866d2c7;hpb=291ec0f2d2ce65e5ccb876b46d6468af49ddb82e;p=git.git diff --git a/unpack-objects.c b/unpack-objects.c index 6383db94..19874d00 100644 --- a/unpack-objects.c +++ b/unpack-objects.c @@ -3,7 +3,9 @@ #include "delta.h" #include "pack.h" -static int dry_run; +#include + +static int dry_run, quiet; static const char unpack_usage[] = "git-unpack-objects < pack-file"; /* We always read in 4kB chunks. */ @@ -185,7 +187,7 @@ static int unpack_delta_entry(unsigned long delta_size) return resolve_delta(type, base, base_size, delta_data, delta_size); } -static void unpack_one(void) +static void unpack_one(unsigned nr, unsigned total) { unsigned shift; unsigned char *pack, c; @@ -205,6 +207,19 @@ static void unpack_one(void) size += (c & 0x7f) << shift; shift += 7; } + if (!quiet) { + static unsigned long last_sec; + static unsigned last_percent; + struct timeval now; + unsigned percentage = (nr * 100) / total; + + gettimeofday(&now, NULL); + if (percentage != last_percent || now.tv_sec != last_sec) { + last_sec = now.tv_sec; + last_percent = percentage; + fprintf(stderr, "%4u%% (%u/%u) done\r", percentage, nr, total); + } + } switch (type) { case OBJ_COMMIT: case OBJ_TREE: @@ -240,7 +255,7 @@ static void unpack_all(void) use(sizeof(struct pack_header)); for (i = 0; i < nr_objects; i++) - unpack_one(); + unpack_one(i+1, nr_objects); if (delta_list) die("unresolved deltas left after unpacking"); } @@ -258,6 +273,10 @@ int main(int argc, char **argv) dry_run = 1; continue; } + if (!strcmp(arg, "-q")) { + quiet = 1; + continue; + } usage(unpack_usage); } @@ -287,5 +306,7 @@ int main(int argc, char **argv) } /* All done */ + if (!quiet) + fprintf(stderr, "\n"); return 0; }