Re: Preventing abort() and exit() calls in libpq

Поиск
Список
Период
Сортировка
От Noah Misch
Тема Re: Preventing abort() and exit() calls in libpq
Дата
Msg-id 20210703214658.GA2421985@rfd.leadboat.com
обсуждение исходный текст
Ответ на Re: Preventing abort() and exit() calls in libpq  (Tom Lane <tgl@sss.pgh.pa.us>)
Ответы Re: Preventing abort() and exit() calls in libpq
Список pgsql-hackers
On Sat, Jul 03, 2021 at 10:45:59AM -0400, Tom Lane wrote:
> I'd imagined leaving, e.g., psprintf.c out of libpgcommon_shlib.a.
> But if someone mistakenly introduced a psprintf call into libpq,
> it'd still compile just fine; the symbol would be resolved against
> psprintf in the calling application's code.

I think that would fail to compile on Windows, where such references need
exported symbols.  We don't make an exports file for applications other than
postgres.exe.  So the strategy that inspired this may work.

> What I'm now thinking about is restricting the test to only be run on
> platforms where use of foo.a libraries is deprecated, so that we can
> be pretty sure that we won't hit this situation.  Even if we only
> run the test on Linux, that'd be plenty to catch any mistakes.

Hmm.  Static libraries are the rarer case on both AIX and Linux, but I'm not
aware of a relevant deprecation on either platform.  If it comes this to, I'd
be more inclined to control the Makefile rule with an environment variable
(e.g. ENFORCE_LIBC_CALL_RESTRICTIONS) instead of reacting to the platform.



В списке pgsql-hackers по дате отправления:

Предыдущее
От: Daniel Gustafsson
Дата:
Сообщение: Re: Unbounded %s in sscanf
Следующее
От: Tom Lane
Дата:
Сообщение: Re: Preventing abort() and exit() calls in libpq