Re: Make copyObject work in C++
| От | Jelte Fennema-Nio |
|---|---|
| Тема | Re: Make copyObject work in C++ |
| Дата | |
| Msg-id | DFQYWIJD4L1J.3HQFOWSWKLFOR@jeltef.nl обсуждение исходный текст |
| Ответ на | Re: Make copyObject work in C++ (Peter Eisentraut <peter@eisentraut.org>) |
| Ответы |
Re: Make copyObject work in C++
|
| Список | pgsql-hackers |
On Wed, 14 Jan 2026 at 16:59, Peter Eisentraut <peter@eisentraut.org> wrote: > I think this module should have a runtime test, too. Otherwise you > don't know that you got the linkage correct, or whether this works at > all. It doesn't have to do much, like it could literally be a + b, and > it could evolve in the future to test hooks, _PG_init, etc. Done > Let's put a README file in the module's directory instead of putting the > explanation into the Makefile/meson.build. Done > I wonder if the module's build integration would work correctly in the > autoconf/makefile case if no C++ is available. AFAICT, it would fail to > build with g++ not found or similar. Changed this to check that if CXX is g++, the command is also actually available before including the module for the build. > AFAICT, the minimum changes to get a minimum test module to work are > > - fix for "restrict", recently committed > - disable warning about zero-length arrays, seems trivial > - named designated initializers Correct, I've now restructured the commits to have the module introduction as the first one. Then all the other commits, both fix a macro to work in C++ and add some usage of those macros as coverage to the previously added module. > I learned that named designated initializers in C++ are not allowed to > be specified out of order, so they are not a full equivalent to the C > syntax. This could be a problem for example if someone wanted in the > future to have something like > > PG_MODULE_MAGIC_EXT(.threads_supported = true) > > (while not specifying the leading .name and .version fields). This would still work fine, because fields are left out. The problem occurs when defining values for fields, but in a different order than the fields are specified in the struct (so e.g. by putting .version before .name). The reason for that is related to destructor ordering. > I think for now the easiest fix would be to just not use the named > initializers in the definition of PG_MODULE_MAGIC_DATA. Then we don't > need to require C++20 and have that additional code. In the future, we > might need a different solution more suitable for C++. There is a small problem with this though. Using both designated an non-designated initializers, is not valid standard C++. I even get a warning (but no error) about that with clang: ../src/test/modules/test_cplusplusext/test_cplusplusext.cpp:24:2: warning: mixture of designated and non-designated initializersin the same initializer list is a C99 extension [-Wc99-designator] In C mixing them is allowed just fine. Sadly that means that C++ extensions (even when compiled for C++20) shouldn't use PG_MODULE_MAGIC_EXT with designated initializers at all. I've updated the documentation to reflect that. I agree that it's better to avoid requiring C++20 on MSVC (at least for now). > The use of -std=c++11 for CI is a valid idea; I have often wanted that > for C as well. But conversely we also want to allow testing optional > extension and future C standard features. So we need a comprehensive > solution there that covers both ends and both languages. Let's leave > that out for now and think about it separately. Removed
Вложения
В списке pgsql-hackers по дате отправления: