Re: pg_dump assertion failure with "-n pg_catalog"

From: Peter Eisentraut <peter(at)eisentraut(dot)org>
To: Jeff Davis <pgsql(at)j-davis(dot)com>, Michael Paquier <michael(at)paquier(dot)xyz>
Cc: pgsql-bugs(at)postgresql(dot)org
Subject: Re: pg_dump assertion failure with "-n pg_catalog"
Date: 2023-09-05 09:45:33
Message-ID: be43b547-3e28-769f-47d8-5b44f95facae@eisentraut.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

On 16.06.23 00:47, Jeff Davis wrote:
> else
> {
> appendPQExpBufferStr(q, ", lc_collate = ");
> - appendStringLiteralAH(q, collcollate, fout);
> + appendStringLiteralAH(q, collcollate ? collcollate : "", fout);
> appendPQExpBufferStr(q, ", lc_ctype = ");
> - appendStringLiteralAH(q, collctype, fout);
> + appendStringLiteralAH(q, collctype ? collctype : "", fout);
> }
>

This new code replaces an (unexpected) null value with an empty string.
Is that correct? Empty locale strings have specific behaviors under the
libc and icu providers. It seems to me it would be better to error out
or don't print a CREATE COLLATION command at all rather than
substituting a value that is not a correct substitute.

Alternatively, a more correct way to produce a null value would be to
not issue the assignment at all (omit the " lc_collation = " etc.).
Then we can leave it up to the backend to accept the command or not, but
at least the dump closely reflects the original catalog state.

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Navadvipa Chandra das 2023-09-05 09:52:09 Re: BUG #18083: not compile PostgreSQL module in Qt with GCC 11.2 compiler
Previous Message PG Bug reporting form 2023-09-05 09:32:53 BUG #18085: Error in documentation