| From: | Jeff Davis <pgsql(at)j-davis(dot)com> |
|---|---|
| To: | Chao Li <li(dot)evan(dot)chao(at)gmail(dot)com> |
| Cc: | Peter Eisentraut <peter(at)eisentraut(dot)org>, Thomas Munro <thomas(dot)munro(at)gmail(dot)com>, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, pgsql-hackers(at)postgresql(dot)org |
| Subject: | Re: Remaining dependency on setlocale() |
| Date: | 2025-12-15 19:34:01 |
| Message-ID: | 5f70ee8a3f73df753285f8928c01dd32f14d7fcb.camel@j-davis.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-hackers |
On Sat, 2025-12-13 at 17:48 +0800, Chao Li wrote:
> 1 - 0001
> ```
> + int match_mblen pg_attribute_unused();
> ```
>
> Why this variable is marked unused? It’s actually used.
Fixed and committed.
I originally marked it unused because I just had an:
Assert(match[match_mblen] == '\0');
but I changed it to just set it:
match[match_mblen] = '\0';
for clarity, even though I think the underlying API guarantees NUL-
termination.
> 2 - 0002
>
> I did a search and found one place that you missed at line 181 in
> pg_locale.h
> ```
> extern bool char_is_cased(char ch, pg_locale_t locale);
> ```
Thank you, fixed and committed.
I'll continue committing v12 0003-0005. Note that I'm planning to
backport 0003.
I'm also inclined to move forward with 0006. It's not a long-term
solution, but it solves an instance of the problem under discussion in
this thread (removes setlocale() dependency) and is a narrow fix.
After that, remaining loose ends:
* 0007: Can we just rip out the non-ASCII support? If it's gone all
this time without UTF8 support, and there's no suggestion about what
the non-ASCII behavior should be (in docs or source code), then it's
probably not terribly important.
* Use of pg_strncasecmp() in the backend, which uses tolower() to do
case-insensitive matching of command options, e.g. "if
(pg_strcasecmp(a, "plain") == 0)" to check for PLAIN storage in CREATE
TYPE.
* strerror(): either consider an lc_ctype GUC, or the approach over
here[1].
* Daniel suggests that we need some way to set LC_COLLATE for
extensions/dependencies.
* address calls to pg_tolower in datetime.c and tzparser.c -- can those
just be pg_ascii_tolower()?
* examine remaining isalpha(), etc., calls in the backend
Regards,
Jeff Davis
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Thomas Munro | 2025-12-15 19:43:40 | Re: PRI?64 vs Visual Studio (2022) |
| Previous Message | Peter Eisentraut | 2025-12-15 19:33:42 | Re: Get rid of "Section.N.N.N" on DOCs |