FreeBSD Bugzilla – Attachment 255048 Details for
Bug 282645
graphics/povray37: fix build with libc++ 19
Home
|
New
|
Browse
|
Search
|
[?]
|
Reports
|
Help
|
New Account
|
Log In
Remember
[x]
|
Forgot Password
Login:
[x]
[patch]
graphics/povray37: fix build with libc++ 19
graphics__povray37-fix-libcxx19-build-1.diff (text/plain), 5.01 KB, created by
Dimitry Andric
on 2024-11-09 12:05:44 UTC
(
hide
)
Description:
graphics/povray37: fix build with libc++ 19
Filename:
MIME Type:
Creator:
Dimitry Andric
Created:
2024-11-09 12:05:44 UTC
Size:
5.01 KB
patch
obsolete
>commit 9248aeb3be7802f3d0a5114f37671f3f5cd42dba >Author: Dimitry Andric <dim@FreeBSD.org> >Date: 2024-11-09T13:04:23+01:00 > > graphics/povray37: fix build with libc++ 19 > > As noted in the libc++ 19 release notes [1], std::char_traits<> is now > only provided for char, char8_t, char16_t, char32_t and wchar_t, and any > instantiation for other types will fail. > > This causes graphics/povray37 to fail to compile with clang 19 and > libc++ 19, resulting in errors similar to: > > /usr/include/c++/v1/string:820:42: error: implicit instantiation of undefined template 'std::char_traits<unsigned short>' > 820 | static_assert(is_same<_CharT, typename traits_type::char_type>::value, > | ^ > ./base/configbase.h:159:19: note: in instantiation of template class 'std::basic_string<unsigned short>' requested here > 159 | inline UCS2String ASCIItoUCS2String(const char *s) > | ^ > /usr/include/c++/v1/__fwd/string.h:23:29: note: template is declared here > 23 | struct _LIBCPP_TEMPLATE_VIS char_traits; > | ^ > > This can be fixed by defining `POVMSUCS2` as `char16_t` instead of > `unsigned short`, `UCS2` as `char16_t` instead of `unsigned short`, and > `UCS4` as `char32_t` instead of `unsigned int` in the passed-in > `CPPFLAGS` variable. > > Also, patch up `vfe.cpp` and `vfeconf.h` to use `char16_t` and > `u16string` instead of the non-standard types. > > [1] https://libcxx.llvm.org/ReleaseNotes/19.html#deprecations-and-removals > > PR: 282645 > MFH: 2024Q4 > >diff --git a/graphics/povray37/Makefile b/graphics/povray37/Makefile >index 5b3329b1a545..e23e696f934a 100644 >--- a/graphics/povray37/Makefile >+++ b/graphics/povray37/Makefile >@@ -24,6 +24,9 @@ GNU_CONFIGURE_MANPREFIX=${PREFIX}/share > CONFIGURE_ARGS= COMPILED_BY=${HOSTARCH}-portbld-${OPSYS:tl}-${OSREL:R} \ > --program-transform-name='s/povray/${PKGBASE}/' \ > --disable-optimiz >+CPPFLAGS+= -D POVMSUCS2="char16_t" >+CPPFLAGS+= -D UCS2="char16_t" >+CPPFLAGS+= -D UCS4="char32_t" > > VERSION_BASE= ${PORTVERSION:C/([0-9]+\.[0-9]+).*/\1/} > ETCDIR= ${PREFIX}/etc/${PORTNAME}/${VERSION_BASE} >diff --git a/graphics/povray37/files/patch-vfe_vfe.cpp b/graphics/povray37/files/patch-vfe_vfe.cpp >new file mode 100644 >index 000000000000..f4c8e56714ef >--- /dev/null >+++ b/graphics/povray37/files/patch-vfe_vfe.cpp >@@ -0,0 +1,26 @@ >+--- vfe/vfe.cpp.orig 2021-07-08 09:56:01 UTC >++++ vfe/vfe.cpp >+@@ -1372,7 +1372,7 @@ int Allow_File_Write (const char *Filename, const unsi >+ return (vfeSession::GetSessionFromThreadID()->TestAccessAllowed(Filename, true)); >+ } >+ >+-int Allow_File_Write (const unsigned short *Filename, const unsigned int FileType) >++int Allow_File_Write (const char16_t *Filename, const unsigned int FileType) >+ { >+ if (strcmp(UCS2toASCIIString(Filename).c_str(), "stdout") == 0 || strcmp(UCS2toASCIIString(Filename).c_str(), "stderr") == 0) >+ return true; >+@@ -1384,12 +1384,12 @@ int Allow_File_Read (const char *Filename, const unsig >+ return (vfeSession::GetSessionFromThreadID()->TestAccessAllowed(Filename, false)); >+ } >+ >+-int Allow_File_Read (const unsigned short *Filename, const unsigned int FileType) >++int Allow_File_Read (const char16_t *Filename, const unsigned int FileType) >+ { >+ return (vfeSession::GetSessionFromThreadID()->TestAccessAllowed(Filename, false)); >+ } >+ >+-FILE *vfeFOpen (const std::basic_string<unsigned short>& name, const char *mode) >++FILE *vfeFOpen (const UCS2String& name, const char *mode) >+ { >+ return (fopen (UCS2toASCIIString (name).c_str(), mode)) ; >+ } >diff --git a/graphics/povray37/files/patch-vfe_vfeconf.h b/graphics/povray37/files/patch-vfe_vfeconf.h >new file mode 100644 >index 000000000000..e0761680ed1f >--- /dev/null >+++ b/graphics/povray37/files/patch-vfe_vfeconf.h >@@ -0,0 +1,19 @@ >+--- vfe/vfeconf.h.orig 2021-07-08 09:56:01 UTC >++++ vfe/vfeconf.h >+@@ -61,12 +61,12 @@ namespace vfe >+ int vfe_POVMS_Sys_QueueSend(POVMS_Sys_QueueNode *q, void *p, int l) ; >+ int Allow_File_Write (const char *Filename, const unsigned int FileType); >+ int Allow_File_Read (const char *Filename, const unsigned int FileType); >+- int Allow_File_Read (const unsigned short *Filename, const unsigned int FileType); >+- int Allow_File_Write (const unsigned short *Filename, const unsigned int FileType); >++ int Allow_File_Read (const char16_t *Filename, const unsigned int FileType); >++ int Allow_File_Write (const char16_t *Filename, const unsigned int FileType); >+ POVMS_Sys_Thread_Type POVMS_GetCurrentThread(); >+ void vfeAssert (const char *message, const char *filename, int line) ; >+- FILE *vfeFOpen (const std::basic_string<unsigned short>& name, const char *mode); >+- bool vfeRemove (const std::basic_string<unsigned short>& name); >++ FILE *vfeFOpen (const std::u16string& name, const char *mode); >++ bool vfeRemove (const std::u16string& name); >+ >+ #if defined _DEBUG >+ void *vfe_POVMS_Sys_Malloc(size_t size, const char *func, const char *file, int line) ;
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Diff
View Attachment As Raw
Actions:
View
|
Diff
Attachments on
bug 282645
: 255048