Re: Change copyObject() to use typeof_unqual - Mailing list pgsql-hackers

From Peter Eisentraut
Subject Re: Change copyObject() to use typeof_unqual
Date
Msg-id b136156d-11d1-4db9-84db-28fd8c0aa756@eisentraut.org
Whole thread Raw
In response to Re: Change copyObject() to use typeof_unqual  (Peter Eisentraut <peter@eisentraut.org>)
Responses Re: Change copyObject() to use typeof_unqual
List pgsql-hackers
On 04.02.26 11:46, Peter Eisentraut wrote:
> On 20.01.26 10:37, Peter Eisentraut wrote:
>> Currently, when the argument of copyObject() is const-qualified, the 
>> return type is also, because the use of typeof carries over all the 
>> qualifiers.  This is incorrect, since the point of copyObject() is to 
>>   make a copy to mutate.  But apparently no code ran into it.
>>
>> The new implementation uses typeof_unqual, which drops the qualifiers, 
>> making this work correctly.
>>
>> typeof_unqual is standardized in C23, but all recent versions of all 
>> the usual compilers support it even in non-C23 mode, at least as 
>> __typeof_unqual__.  We add a configure/meson test for typeof_unqual 
>> and __typeof_unqual__ and use it if it's available, else we use the 
>> existing fallback of just returning void *.
> 
> I committed this first part, but it ran into some trouble on the buildfarm:
> 
> https://buildfarm.postgresql.org/cgi-bin/show_log.pl? 
> nm=taipan&dt=2026-02-04%2008%3A39%3A34
> 
> The problem is that configure detected that gcc supports typeof_unqual, 
> but the clang used to produce the .bc files does not.

Here is a new version, after the previous one was reverted.

This is rebased over commit 1887d822f14 and now also provides a C++ 
implementation, corresponding to the C++ typeof implementation added by 
that commit.

This revealed an insufficiency in that commit, which I fix in the first 
patch.

I have addressed the above problem by swapping the order of the probes 
(putting the underscore variant first), as discussed.

There was also an issue that newer MSVC versions claimed to support 
typeof_unqual but it didn't work correctly.  I have enhanced the 
configure probes to detect this problem.
Attachment

pgsql-hackers by date:

Previous
From: Robert Haas
Date:
Subject: Re: pg_combinebackup: incorrect size of VM fork after combine
Next
From: Andres Freund
Date:
Subject: Re: Reduce timing overhead of EXPLAIN ANALYZE using rdtsc?