count-objects: do not use xsize_t when counting object size

The point of xsize_t is to safely cast an off_t into a size_t
(because we are about to mmap). But in count-objects, we are
summing the sizes in an off_t. Using xsize_t means that
count-objects could fail on a 32-bit system with a 4G
object (not likely, as other parts of git would fail, but
we should at least be correct here).

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2014-10-15 18:40:58 -04:00 committed by Junio C Hamano
parent 0d3b729680
commit cac05d4dfd

View File

@ -53,7 +53,7 @@ static void count_objects(DIR *d, char *path, int len, int verbose,
if (lstat(path, &st) || !S_ISREG(st.st_mode)) if (lstat(path, &st) || !S_ISREG(st.st_mode))
bad = 1; bad = 1;
else else
(*loose_size) += xsize_t(on_disk_bytes(st)); (*loose_size) += on_disk_bytes(st);
} }
if (bad) { if (bad) {
if (verbose) { if (verbose) {