<pre style='margin:0'>
Ken (kencu) pushed a commit to branch master
in repository macports-ports.

</pre>
<p><a href="https://github.com/macports/macports-ports/commit/1c1282262ee807a0819c679c58dae0f98241fb75">https://github.com/macports/macports-ports/commit/1c1282262ee807a0819c679c58dae0f98241fb75</a></p>
<pre style="white-space: pre; background: #F8F8F8">The following commit(s) were added to refs/heads/master by this push:
<span style='display:block; white-space:pre;color:#404040;'>     new 1c1282262ee webkit2-gtk: fix build with XCode 12
</span>1c1282262ee is described below

<span style='display:block; white-space:pre;color:#808000;'>commit 1c1282262ee807a0819c679c58dae0f98241fb75
</span>Author: Michael Lass <michael.lass@uni-paderborn.de>
AuthorDate: Mon Sep 21 12:19:56 2020 +0200

<span style='display:block; white-space:pre;color:#404040;'>    webkit2-gtk: fix build with XCode 12
</span><span style='display:block; white-space:pre;color:#404040;'>    
</span><span style='display:block; white-space:pre;color:#404040;'>    Compilation fails with the following error:
</span><span style='display:block; white-space:pre;color:#404040;'>    
</span><span style='display:block; white-space:pre;color:#404040;'>    DerivedSources/ForwardingHeaders/wtf/PointerPreparations.h:37:53: error: cannot initialize return object of type 'void *' with an rvalue of type 'const void *'
</span><span style='display:block; white-space:pre;color:#404040;'>    ALWAYS_INLINE void* getVTablePointer(T* o) { return __builtin_get_vtable_pointer(o); }
</span><span style='display:block; white-space:pre;color:#404040;'>                                                        ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
</span><span style='display:block; white-space:pre;color:#404040;'>    
</span><span style='display:block; white-space:pre;color:#404040;'>    This issue has been fixed in version 2.30.0. Until the package is
</span><span style='display:block; white-space:pre;color:#404040;'>    updated, it can be fixed with a simple patch obtained from
</span><span style='display:block; white-space:pre;color:#404040;'>    https://bugs.webkit.org/show_bug.cgi?id=207871
</span><span style='display:block; white-space:pre;color:#404040;'>    
</span><span style='display:block; white-space:pre;color:#404040;'>    Fixes https://trac.macports.org/ticket/61650
</span>---
 www/webkit2-gtk/Portfile                           |  4 +++
 .../files/patch-WTF-wtf-getVTablePointer.diff      | 37 ++++++++++++++++++++++
 2 files changed, 41 insertions(+)

<span style='display:block; white-space:pre;color:#808080;'>diff --git a/www/webkit2-gtk/Portfile b/www/webkit2-gtk/Portfile
</span><span style='display:block; white-space:pre;color:#808080;'>index 743c9b66d94..2ce77ddf1a7 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/www/webkit2-gtk/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/www/webkit2-gtk/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -98,6 +98,10 @@ patchfiles-append    patch-enable-plugin-architecture-unix.diff
</span> # runs without this patch.
 patchfiles-append    patch-bundle-link-webcore.diff
 
<span style='display:block; white-space:pre;background:#e0ffe0;'>+# Fix incompatibility with XCode 12:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://bugs.webkit.org/show_bug.cgi?id=207871
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+patchfiles-append    patch-WTF-wtf-getVTablePointer.diff
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span> # it is preferred to use the WebKit built in bmalloc if it builds on a given os.
 # it has improved security features, but not all systems can build it at present.
 
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/www/webkit2-gtk/files/patch-WTF-wtf-getVTablePointer.diff b/www/webkit2-gtk/files/patch-WTF-wtf-getVTablePointer.diff
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..1aae3e8c964
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/www/webkit2-gtk/files/patch-WTF-wtf-getVTablePointer.diff
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,37 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git Source/WTF/wtf/PointerPreparations.h Source/WTF/wtf/PointerPreparations.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index ef20a5e48512..ef9495169ff4 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- Source/WTF/wtf/PointerPreparations.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ Source/WTF/wtf/PointerPreparations.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -34,16 +34,16 @@ namespace WTF {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #if COMPILER_HAS_CLANG_BUILTIN(__builtin_get_vtable_pointer)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ template<typename T>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+-ALWAYS_INLINE void* getVTablePointer(T* o) { return __builtin_get_vtable_pointer(o); }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ALWAYS_INLINE const void* getVTablePointer(T* o) { return __builtin_get_vtable_pointer(o); }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #else // not COMPILER_HAS_CLANG_BUILTIN(__builtin_get_vtable_pointer)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #if CPU(ARM64E)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ template<typename T>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+-ALWAYS_INLINE void* getVTablePointer(T* o) { return __builtin_ptrauth_auth(*(reinterpret_cast<void**>(o)), ptrauth_key_cxx_vtable_pointer, 0); }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ALWAYS_INLINE const void* getVTablePointer(T* o) { return __builtin_ptrauth_auth(*(reinterpret_cast<void**>(o)), ptrauth_key_cxx_vtable_pointer, 0); }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #else // not CPU(ARM64E)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ template<typename T>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+-ALWAYS_INLINE void* getVTablePointer(T* o) { return (*(reinterpret_cast<void**>(o))); }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ALWAYS_INLINE const void* getVTablePointer(T* o) { return (*(reinterpret_cast<void**>(o))); }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #endif // not CPU(ARM64E)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #endif // not COMPILER_HAS_CLANG_BUILTIN(__builtin_get_vtable_pointer)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git Source/WebCore/bindings/scripts/CodeGeneratorJS.pm Source/WebCore/bindings/scripts/CodeGeneratorJS.pm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index 35db4d28ccd6..03dd9c161a83 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- Source/WebCore/bindings/scripts/CodeGeneratorJS.pm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ Source/WebCore/bindings/scripts/CodeGeneratorJS.pm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -4881,7 +4881,7 @@ END
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+         push(@implContent, <<END) if $vtableNameGnu;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #if ENABLE(BINDING_INTEGRITY)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+-    void* actualVTablePointer = getVTablePointer(impl.ptr());
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++    const void* actualVTablePointer = getVTablePointer(impl.ptr());
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #if PLATFORM(WIN)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+     void* expectedVTablePointer = ${vtableRefWin};
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #else
</span></pre><pre style='margin:0'>

</pre>