sbase

suckless unix tools
git clone git://git.2f30.org/sbase
Log | Files | Refs | README | LICENSE

commit 63d863ae53f625d973ef5596b90f3a0ba969963a
parent 2deb40290e3f8248846f8e5390b88b1a2f0dd5f2
Author: sin <sin@2f30.org>
Date:   Wed, 29 Apr 2015 12:12:18 +0100

du: Use off_t instead of uintmax_t

Diffstat:
Mdu.c | 12++++++------
1 file changed, 6 insertions(+), 6 deletions(-)

diff --git a/du.c b/du.c @@ -4,9 +4,9 @@ #include <errno.h> #include <limits.h> -#include <stdint.h> #include <stdlib.h> #include <stdio.h> +#include <unistd.h> #include "fs.h" #include "util.h" @@ -19,7 +19,7 @@ static int sflag = 0; static int hflag = 0; static void -printpath(uintmax_t n, const char *path) +printpath(off_t n, const char *path) { if (hflag) printf("%s\t%s\n", humansize(n * blksize), path); @@ -27,7 +27,7 @@ printpath(uintmax_t n, const char *path) printf("%ju\t%s\n", n, path); } -static uintmax_t +static off_t nblks(blkcnt_t blocks) { return (512 * blocks + blksize - 1) / blksize; @@ -36,11 +36,11 @@ nblks(blkcnt_t blocks) static void du(const char *path, struct stat *st, void *total, struct recursor *r) { - uintmax_t subtotal = 0; + off_t subtotal = 0; if (st && S_ISDIR(st->st_mode)) recurse(path, &subtotal, r); - *((uintmax_t *)total) += subtotal + nblks(st ? st->st_blocks : 0); + *((off_t *)total) += subtotal + nblks(st ? st->st_blocks : 0); if (!sflag && r->depth <= maxdepth && r->depth && st && (S_ISDIR(st->st_mode) || aflag)) printpath(subtotal + nblks(st->st_blocks), path); @@ -57,7 +57,7 @@ main(int argc, char *argv[]) { struct recursor r = { .fn = du, .hist = NULL, .depth = 0, .maxdepth = 0, .follow = 'P', .flags = 0 }; - uintmax_t n = 0; + off_t n = 0; int kflag = 0, dflag = 0; char *bsize;