Re: Make copyObject work in C++

From: Peter Eisentraut <peter(at)eisentraut(dot)org>
To: Jelte Fennema-Nio <postgres(at)jeltef(dot)nl>
Cc: PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>, Thomas Munro <thomas(dot)munro(at)gmail(dot)com>, Andres Freund <andres(at)anarazel(dot)de>
Subject: Re: Make copyObject work in C++
Date: 2026-03-27 11:23:24
Message-ID: 6dff90f6-2afb-44a3-9524-b017924d71da@eisentraut.org
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On 23.03.26 10:58, Jelte Fennema-Nio wrote:
> On Mon, 23 Mar 2026 at 10:27, Peter Eisentraut <peter(at)eisentraut(dot)org> wrote:
>> I think we should commit the pg_list.h changes, since the C-style
>> compound literals are not a C++ feature at all, and so without this MSVC
>> would never get supported. (Or you couldn't use PostgreSQL lists, which
>> would be very limiting.)
>
> Sounds good to me.

This has been committed.

>> The other changes deal with designated initializers and flexible array
>> members. These are not a blocker, since extension authors could deal
>> with them themselves by adding appropriate compiler options or similar.
>
> I think we should add these flags to CXXFLAGS for MSVC by default,
> similar to how we add -std=gnu++11/-std=c++11 for other compilers. We
> can then document on the C++ extension docs page, that MSVC compilers
> require C++20 support.

Here is another tidied up patch set for this. I didn't go quite as far
as enabling C++20 by default in meson.build, this would just take more
time to work out and test all the different combinations, but I added
the flag to the Cirrus CI task, since there we know what compiler we have.

Attachment Content-Type Size
v11-0001-meson-Make-room-for-C-only-warning-flags-for-MSV.patch text/plain 2.2 KB
v11-0002-Disable-some-C-warnings-in-MSVC.patch text/plain 900 bytes
v11-0003-Enable-test_cplusplusext-with-MSVC.patch text/plain 3.6 KB

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message Maksim.Melnikov 2026-03-27 11:31:52 Fix race with LLVM and bison.
Previous Message Ajit Awekar 2026-03-27 10:59:57 Re: [OAuth2] Infrastructure for tracking token expiry time