Summary: | graphics/darktable: Fails to build with GCC 13: error: expected identifier before '__is_convertible' | ||
---|---|---|---|
Product: | Ports & Packages | Reporter: | Lorenzo Salvadore <salvadore> |
Component: | Individual Port(s) | Assignee: | Jean-Sébastien Pédron <dumbbell> |
Status: | Closed FIXED | ||
Severity: | Affects Only Me | CC: | salvadore |
Priority: | --- | Flags: | dumbbell:
maintainer-feedback+
|
Version: | Latest | ||
Hardware: | Any | ||
OS: | Any |
Description
Lorenzo Salvadore
2023-09-10 07:40:37 UTC
For the record, I'm discussing the possible solutions to this problem in the parent bug 273397, in case it can help other people working on similarily affected ports. A commit in branch main references this bug: URL: https://cgit.FreeBSD.org/ports/commit/?id=01cc6a27117a38079dd3b57e69455d7a191ca54a commit 01cc6a27117a38079dd3b57e69455d7a191ca54a Author: Jean-Sébastien Pédron <dumbbell@FreeBSD.org> AuthorDate: 2023-10-01 20:30:13 +0000 Commit: Jean-Sébastien Pédron <dumbbell@FreeBSD.org> CommitDate: 2023-10-01 20:37:57 +0000 graphics/darktable: Build explicitly with GCC 12.x on FreeBSD 12.x On FreeBSD 12.x, it looks like GCC 13+ is incompatible with the version of libcxx. In the case of darktable, this leads to the following compile time error: In file included from /usr/include/c++/v1/__functional/weak_result_type.h:16, from /usr/include/c++/v1/__functional/invoke.h:14, from /usr/include/c++/v1/__functional_base:15, from /usr/include/c++/v1/string:520, from .../work/darktable-4.4.2/src/external/rawspeed/src/librawspeed/common/ChecksumFile.h:23, from .../work/darktable-4.4.2/src/external/rawspeed/src/librawspeed/common/ChecksumFile.cpp:21: /usr/include/c++/v1/type_traits:1770:8: error: expected identifier before '__is_convertible' 1770 | struct __is_convertible | ^~~~~~~~~~~~~~~~ I have no idea if it is possible to fix or work around this problem in darktable itself. Thus, on FreeBSD 12.x, we pin the version of GCC to 12. This way, once GCC 13+ bescomes the default version, darktable can still be built on FreeBSD 12.x, even though the user may have to install two versions of GCC. For FreeBSD 13.x and onward, the version of GCC remains unpinned in the port and the default one will be used. This solution was discussed with salvadore@ in the following exp-run request: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=273397 PR: 273681 graphics/darktable/Makefile | 28 ++++++++++++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) Closing this bug because a fix has been committed and the switch to make GCC 13 the default will go in after FreeBSD 12.x reaches EOL. Sorry, but I need to re-open this bug report. Apparently, the issue is still there: https://pkg-status.freebsd.org/package22/data/132amd64-default-foo/2023-11-10_07h48m13s/logs/errors/darktable-4.4.2_4.log Please note that this test has been run on FreeBSD 13.2. A commit in branch main references this bug: URL: https://cgit.FreeBSD.org/ports/commit/?id=c97005f74a5b93654b81c249c7ef6e06ca1a1cf4 commit c97005f74a5b93654b81c249c7ef6e06ca1a1cf4 Author: Lorenzo Salvadore <salvadore@FreeBSD.org> AuthorDate: 2024-01-23 10:25:50 +0000 Commit: Lorenzo Salvadore <salvadore@FreeBSD.org> CommitDate: 2024-01-23 10:30:25 +0000 graphics/darktable: Set USE_GCC=12 This is to allow the update of GCC_DEFAULT to version 13 until a better solution is found. PR: 273681 Approved by: portmgr (blanket) graphics/darktable/Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) Sorry, this should not have been closed since the bug is still there. Only the block for the GCC 13 as default version should have been removed. Opening again. Re-adding the block for GCC default version update: the commit in comment #5 did not work, GCC 13 is still being used. https://pkg-status.freebsd.org/package18/data/140amd64-default-foo/2024-01-29_17h34m15s/logs/errors/darktable-4.6.0.log A commit in branch main references this bug: URL: https://cgit.FreeBSD.org/ports/commit/?id=b1b2712440d93ea3c636266309bf9c1b518c595b commit b1b2712440d93ea3c636266309bf9c1b518c595b Author: Lorenzo Salvadore <salvadore@FreeBSD.org> AuthorDate: 2024-02-24 08:45:25 +0000 Commit: Lorenzo Salvadore <salvadore@FreeBSD.org> CommitDate: 2024-02-24 09:34:52 +0000 graphics/darktable: Force building with GCC 12 Second attempt to set USE_GCC=12 properly, so that the GCC_DEFAULT update can get forward. PR: 273681 Approved by: portmgr (blanket) Fixes: c97005f74a5b graphics/darktable: Set USE_GCC=12 graphics/darktable/Makefile | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) This time GCC 12 should be enforced properly, so I remove the block again. |