From: Jim Meyering Date: Thu, 17 Mar 2005 15:30:00 +0000 (+0000) Subject: (parse_tab_stops, main): Use DECIMAL_DIGIT_ACCUMULATE macro in X-Git-Tag: CPPI-1_12~1290 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=b90c3e46097a222eaeac27941b11968d6933fe47;p=thirdparty%2Fcoreutils.git (parse_tab_stops, main): Use DECIMAL_DIGIT_ACCUMULATE macro in place of nearly-equivalent code. --- diff --git a/src/expand.c b/src/expand.c index 5ea16c07e8..4f57c6071f 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;