unpack-objects: add --max-input-size=<size> option

When receiving a pack-file, it can be useful to abort the
`git unpack-objects`, if the pack-file is too big.

Signed-off-by: Christian Couder <chriscool@tuxfamily.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Christian Couder 2016-08-24 20:41:56 +02:00 committed by Junio C Hamano
parent 411481be6f
commit 5ad2186733
2 changed files with 10 additions and 0 deletions

View File

@ -44,6 +44,9 @@ OPTIONS
--strict:: --strict::
Don't write objects with broken content or links. Don't write objects with broken content or links.
--max-input-size=<size>::
Die, if the pack is larger than <size>.
GIT GIT
--- ---
Part of the linkgit:git[1] suite Part of the linkgit:git[1] suite

View File

@ -19,6 +19,7 @@ static const char unpack_usage[] = "git unpack-objects [-n] [-q] [-r] [--strict]
static unsigned char buffer[4096]; static unsigned char buffer[4096];
static unsigned int offset, len; static unsigned int offset, len;
static off_t consumed_bytes; static off_t consumed_bytes;
static off_t max_input_size;
static git_SHA_CTX ctx; static git_SHA_CTX ctx;
static struct fsck_options fsck_options = FSCK_OPTIONS_STRICT; static struct fsck_options fsck_options = FSCK_OPTIONS_STRICT;
@ -87,6 +88,8 @@ static void use(int bytes)
if (signed_add_overflows(consumed_bytes, bytes)) if (signed_add_overflows(consumed_bytes, bytes))
die("pack too large for current definition of off_t"); die("pack too large for current definition of off_t");
consumed_bytes += bytes; consumed_bytes += bytes;
if (max_input_size && consumed_bytes > max_input_size)
die(_("pack exceeds maximum allowed size"));
} }
static void *get_data(unsigned long size) static void *get_data(unsigned long size)
@ -550,6 +553,10 @@ int cmd_unpack_objects(int argc, const char **argv, const char *prefix)
len = sizeof(*hdr); len = sizeof(*hdr);
continue; continue;
} }
if (skip_prefix(arg, "--max-input-size=", &arg)) {
max_input_size = strtoumax(arg, NULL, 10);
continue;
}
usage(unpack_usage); usage(unpack_usage);
} }