* src/data.c (arith_driver): Remove unnecessary runtime test,
since integer overflow is impossible on division of fixnums,
given that the worst case is MOST_NEGATIVE_FIXNUM / -1 which is
representable as an EMACS_INT (albeit not as a fixnum).
/* Set ACCUM to the next operation's result if it fits,
else exit the loop. */
bool overflow = false;
- intmax_t a UNINIT;
+ intmax_t a;
switch (code)
{
case Aadd : overflow = INT_ADD_WRAPV (accum, next, &a); break;
case Adiv:
if (next == 0)
xsignal0 (Qarith_error);
- overflow = INT_DIVIDE_OVERFLOW (accum, next);
- if (!overflow)
- a = accum / next;
+ eassert (! INT_DIVIDE_OVERFLOW (accum, next));
+ a = accum / next;
break;
case Alogand: accum &= next; continue;
case Alogior: accum |= next; continue;