Обсуждение: Re: [COMMITTERS] pgsql: Put back ERANGE test in dpow().

Поиск
Список
Период
Сортировка

Re: [COMMITTERS] pgsql: Put back ERANGE test in dpow().

От
Bruce Momjian
Дата:
Tom Lane wrote:
> Log Message:
> -----------
> Put back ERANGE test in dpow().  There are platforms that need this,
> like my HPPA ...

It ERANGE's only on Inf, not underflow?  I would prefer:

    else if (errno == ERANGE && !isinf(result))

because the sign computation isn't 100%, think pow(-1e300, 2) == Inf,
not -Inf.  But of course, that is going throw an error anyway, so either
we care about the sign of the Inf and try to get it right using isinf(),
or we just ignore it and use +Inf always.

--
  Bruce Momjian   bruce@momjian.us
  EnterpriseDB    http://www.enterprisedb.com

  + If your life is a hard drive, Christ can be your backup. +

Re: [COMMITTERS] pgsql: Put back ERANGE test in dpow().

От
Tom Lane
Дата:
Bruce Momjian <bruce@momjian.us> writes:
> It ERANGE's only on Inf, not underflow?  I would prefer:
>     else if (errno == ERANGE && !isinf(result))

No objection to that, just don't take out the ERANGE test altogether
again ;-)

            regards, tom lane

Re: [COMMITTERS] pgsql: Put back ERANGE test in

От
Bruce Momjian
Дата:
Tom Lane wrote:
> Bruce Momjian <bruce@momjian.us> writes:
> > It ERANGE's only on Inf, not underflow?  I would prefer:
> >     else if (errno == ERANGE && !isinf(result))
>
> No objection to that, just don't take out the ERANGE test altogether
> again ;-)

Actually, when you return ERANGE, what is 'result'?  Nan?  Inf?  finite?

--
  Bruce Momjian   bruce@momjian.us
  EnterpriseDB    http://www.enterprisedb.com

  + If your life is a hard drive, Christ can be your backup. +

Re: [COMMITTERS] pgsql: Put back ERANGE test in dpow().

От
Tom Lane
Дата:
Bruce Momjian <bruce@momjian.us> writes:
> Actually, when you return ERANGE, what is 'result'?  Nan?  Inf?  finite?

I believe it's HUGE_VAL (the largest finite value) ... which is
something I don't want to explicitly test for, any more than I liked
the explicit use of min/max values before.  Your isinf test is OK
because the point is that we want to replace any non-Inf result with Inf
if the result overflowed.

            regards, tom lane