From b90c3e46097a222eaeac27941b11968d6933fe47 Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Thu, 17 Mar 2005 15:30:00 +0000 Subject: [PATCH] (parse_tab_stops, main): Use DECIMAL_DIGIT_ACCUMULATE macro in place of nearly-equivalent code. --- src/expand.c | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/src/expand.c b/src/expand.c index 5ea16c07e..4f57c6071 100644 --- a/src/expand.c +++ b/src/expand.c @@ -172,8 +172,7 @@ parse_tab_stops (char const *stops) } { /* Detect overflow. */ - uintmax_t new_t = 10 * tabval + *stops - '0'; - if (UINTMAX_MAX / 10 < tabval || new_t < tabval * 10) + if (DECIMAL_DIGIT_ACCUMULATE (tabval, *stops - '0', UINTMAX_MAX)) { size_t len = strspn (num_start, "0123456789"); char *bad_num = xstrndup (num_start, len); @@ -182,7 +181,6 @@ parse_tab_stops (char const *stops) ok = false; stops = num_start + len - 1; } - tabval = new_t; } } else @@ -421,10 +419,8 @@ main (int argc, char **argv) have_tabval = true; } { - uintmax_t new_t = tabval * 10 + c - '0'; - if (UINTMAX_MAX / 10 < tabval || new_t < tabval * 10) + if (DECIMAL_DIGIT_ACCUMULATE (tabval, c - '0', UINTMAX_MAX)) error (EXIT_FAILURE, 0, _("tab stop value is too large")); - tabval = new_t; } obsolete_tablist = true; break; -- 2.34.1