From: Darrick J. Wong <darrick.wong@xxxxxxxxxx> Refactor the competing numlen implementations into a single library function. Signed-off-by: Darrick J. Wong <darrick.wong@xxxxxxxxxx> --- include/input.h | 1 + io/bmap.c | 19 ++++--------------- io/fiemap.c | 14 +------------- libxcmd/input.c | 13 +++++++++++++ 4 files changed, 19 insertions(+), 28 deletions(-) diff --git a/include/input.h b/include/input.h index 221678e..82cd2f4 100644 --- a/include/input.h +++ b/include/input.h @@ -28,6 +28,7 @@ extern char **breakline(char *input, int *count); extern void doneline(char *input, char **vec); extern char *fetchline(void); +extern size_t numlen(uint64_t val, size_t base); extern long long cvtnum(size_t blocksize, size_t sectorsize, char *s); extern void cvtstr(double value, char *str, size_t sz); extern unsigned long cvttime(char *s); diff --git a/io/bmap.c b/io/bmap.c index 2333244..2e4ff7b 100644 --- a/io/bmap.c +++ b/io/bmap.c @@ -18,6 +18,7 @@ #include "platform_defs.h" #include "command.h" +#include "input.h" #include "init.h" #include "io.h" @@ -53,18 +54,6 @@ bmap_help(void) "\n")); } -static int -numlen( - off64_t val) -{ - off64_t tmp; - int len; - - for (len = 0, tmp = val; tmp > 0; tmp = tmp/10) - len++; - return (len == 0 ? 1 : len); -} - int bmap_f( int argc, @@ -323,7 +312,7 @@ bmap_f( if (map[i + 1].bmv_block == -1) { foff_w = max(foff_w, strlen(rbuf)); tot_w = max(tot_w, - numlen(map[i+1].bmv_length)); + numlen(map[i+1].bmv_length, 10)); } else { snprintf(bbuf, sizeof(bbuf), "%lld..%lld", (long long) map[i + 1].bmv_block, @@ -344,10 +333,10 @@ bmap_f( aoff_w = 0; foff_w = max(foff_w, strlen(rbuf)); tot_w = max(tot_w, - numlen(map[i+1].bmv_length)); + numlen(map[i+1].bmv_length, 10)); } } - agno_w = is_rt ? 0 : max(MINAG_WIDTH, numlen(fsgeo.agcount)); + agno_w = is_rt ? 0 : max(MINAG_WIDTH, numlen(fsgeo.agcount, 10)); printf("%4s: %-*s %-*s %*s %-*s %*s%s\n", _("EXT"), foff_w, _("FILE-OFFSET"), diff --git a/io/fiemap.c b/io/fiemap.c index bcbae49..75e8820 100644 --- a/io/fiemap.c +++ b/io/fiemap.c @@ -18,6 +18,7 @@ #include "platform_defs.h" #include "command.h" +#include "input.h" #include <linux/fiemap.h> #include "init.h" #include "io.h" @@ -48,19 +49,6 @@ fiemap_help(void) "\n")); } -static int -numlen( - __u64 val, - int base) -{ - __u64 tmp; - int len; - - for (len = 0, tmp = val; tmp > 0; tmp = tmp/base) - len++; - return (len == 0 ? 1 : len); -} - static void print_verbose( struct fiemap_extent *extent, diff --git a/libxcmd/input.c b/libxcmd/input.c index 8aeb3b0..9437be3 100644 --- a/libxcmd/input.c +++ b/libxcmd/input.c @@ -136,6 +136,19 @@ doneline( free(vec); } +size_t +numlen( + uint64_t val, + size_t base) +{ + uint64_t tmp; + size_t len; + + for (len = 0, tmp = val; tmp > 0; tmp = tmp / base) + len++; + return len == 0 ? 1 : len; +} + #define EXABYTES(x) ((long long)(x) << 60) #define PETABYTES(x) ((long long)(x) << 50) #define TERABYTES(x) ((long long)(x) << 40) -- To unsubscribe from this list: send the line "unsubscribe linux-xfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html