Re: Built-in CTYPE provider - Mailing list pgsql-hackers

From Laurenz Albe
Subject Re: Built-in CTYPE provider
Date
Msg-id 7204200c9c456e55dbbb80726d9373631786503b.camel@cybertec.at
Whole thread Raw
In response to Re: Built-in CTYPE provider  (Tom Lane <tgl@sss.pgh.pa.us>)
Responses Re: Built-in CTYPE provider
List pgsql-hackers
On Thu, 2024-07-18 at 13:03 -0400, Tom Lane wrote:
> In the second place, I cannot understand why pg_c_utf8 is being
> held to a mutability standard that we have never applied to any
> other locale-related functionality --- and indeed could not do
> so, since in most cases that functionality has been buried in
> libraries we don't control.

I believe that we should hold it to a higher standard *precisely
because* the previous way that we handled mutability in locale-related
functionality was a problem.

> It seems to me to be already a
> great step forward that with pg_c_utf8, at least we can guarantee
> that the behavior won't change without us knowing about it.

+1

But the greatness of the step depends on our readiness to be careful
with such changes.

> Noah's desire to revert the feature makes the mutability situation
> strictly worse, because people will have to continue to rely on
> OS-provided functionality that can change at any time.

I think everybody agrees that we don't want to expose users to data
corruption after an upgrade.

It understand Noah to take the position that anything less than
strict immutability would be worse than the current state, because
currently a packager can choose to keep shipping the same old
version of libicu and avoid the problem completely.

I don't buy that.  First, the only binary distribution I have heard
of that does that is EDB's Windows installer.  Both the RPM and
Debian packages don't.

And until PostgreSQL defaults to using ICU, most people will use
C library collations, and a packager cannot choose not to upgrade
the C library.

I believe the built-in CTYPE provider is a good thing and a step
forward.  But to make it a big step forward, we should be extremely
careful with any changes in major releases that might require
rebuilding indexes.
This is where I side with Noah.

Yours,
Laurenz Albe



pgsql-hackers by date:

Previous
From: Hao Zhang
Date:
Subject: Can we use parallel workers to create index without active/transaction snapshot?
Next
From: Heikki Linnakangas
Date:
Subject: Re: Should we move the resowner field from JitContext to LLVMJitContext?