Re: Removing obsolete configure checks

From: Peter Eisentraut <peter(dot)eisentraut(at)2ndquadrant(dot)com>
To: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, pgsql-hackers(at)lists(dot)postgresql(dot)org
Subject: Re: Removing obsolete configure checks
Date: 2020-02-21 19:40:13
Message-ID: 0c7ff8ae-70d4-0ba5-f58c-16d76c0545b3@2ndquadrant.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On 2020-02-20 19:00, Tom Lane wrote:
> I think we can just remove these tests, and the corresponding
> src/port/ files where there is one:
>
> fseeko
> isinf
> memmove
> rint
> signed types
> utime
> utime.h
> wchar.h

makes sense

> I believe that we can also get rid of these tests:
>
> flexible array members
> cbrt
> intptr_t
> uintptr_t
>
> as these features are likewise required by C99. Solution.pm thinks that
> MSVC does not have the above, but I suspect its information is out of
> date. We could soon find out from the buildfarm, of course.

The flexible array members test on Solution.pm looks correct to me
(define to empty if supported, else define to 1). cbrt is probably a
mistake or outdated. The intptr_t/uintptr_t results are inconsistent:
It correctly defines intptr_t to empty, so that it will use the existing
typedef, but it does not define HAVE_INTPTR_T, but nothing uses that
anyway. But these are gone now anyway.

> I also noted that these header checks are passing everywhere,
> which is unsurprising because they're required by C99 and/or POSIX:
>
> ANSI C header files
> inttypes.h
> memory.h
> stdlib.h
> string.h
> strings.h
> sys/stat.h
> sys/types.h
> unistd.h
>
> Unfortunately we're not actually asking for any of those to be probed
> for --- it looks like Autoconf just up and does that of its own accord.
> So we can't get rid of the tests and save configure cycles thereby.
> But we can skip testing the HAVE_FOO_H symbols for them. We mostly
> were already, but there's one or two exceptions.

Autoconf git master seems to have modernized that a little bit. For
instance, HAVE_STDLIB_H and HAVE_STRING_H are always defined to 1, just
for backward compatibility. If we wanted to fiddle with this, I'd
consider importing the updated macro. Not sure if it's worth it though.

> There are a few other tests that are getting the same results in
> all buildfarm configure checks, but Solution.pm is injecting different
> results for Windows, such as what to expand "inline" to.

MSVC indeed does not appear to support plain inline.

> Conceivably
> we could hard-code that based on the WIN32 #define and remove the
> configure probes, but I'm inclined to think it's not worth the
> trouble and possible loss of flexibility.

Right, better to leave it.

--
Peter Eisentraut http://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Tom Lane 2020-02-21 19:46:11 Re: Removing obsolete configure checks
Previous Message Peter Eisentraut 2020-02-21 19:10:02 Re: Fix compiler warnings on 64-bit Windows