From: Paul Eggert Date: Sun, 19 Aug 2018 03:47:24 +0000 (-0700) Subject: Simplify float_arith_driver X-Git-Tag: emacs-27.0.90~4542 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=a1b79567a8253a8e8a1ceed02145a64b87a4768d;p=emacs.git Simplify float_arith_driver * src/data.c (float_arith_driver): Simplify, as we needn’t worry about that 30-year-old compiler bug any more. --- diff --git a/src/data.c b/src/data.c index 7a8179ed38d..5ef0ef85571 100644 --- a/src/data.c +++ b/src/data.c @@ -2966,26 +2966,14 @@ static Lisp_Object float_arith_driver (double accum, ptrdiff_t argnum, enum arithop code, ptrdiff_t nargs, Lisp_Object *args) { - register Lisp_Object val; - double next; - for (; argnum < nargs; argnum++) { - /* using args[argnum] as argument to CHECK_NUMBER_... */ - val = args[argnum]; + Lisp_Object val = args[argnum]; CHECK_NUMBER_COERCE_MARKER (val); + double next = (FIXNUMP (val) ? XFIXNUM (val) + : FLOATP (val) ? XFLOAT_DATA (val) + : mpz_get_d (XBIGNUM (val)->value)); - if (FLOATP (val)) - { - next = XFLOAT_DATA (val); - } - else if (BIGNUMP (val)) - next = mpz_get_d (XBIGNUM (val)->value); - else - { - args[argnum] = val; /* runs into a compiler bug. */ - next = XFIXNUM (args[argnum]); - } switch (code) { case Aadd: