commit:     f9cb21a5eb447b7897fa4111598838c914265c75
Author:     Gilles Dartiguelongue <eva <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 21 10:36:42 2014 +0000
Commit:     Gilles Dartiguelongue <eva <AT> gentoo <DOT> org>
CommitDate: Mon Apr 21 13:20:04 2014 +0000
URL:        
http://git.overlays.gentoo.org/gitweb/?p=proj/gnome.git;a=commit;h=f9cb21a5

net-libs/webkit-gtk: 2.2.6 → 2.4.1

---
 net-libs/webkit-gtk/files/gir-paxctl-lt-wrapper    |  33 ---
 .../webkit-gtk-1.6.3-paxctl-introspection.patch    |  21 --
 ...webkit-gtk-1.7.90-test_garbage_collection.patch |  18 --
 .../files/webkit-gtk-2.2.2-unittests-build.patch   |  45 ----
 .../files/webkit-gtk-2.2.4-unittests-build.patch   | 103 ++++++++
 .../files/webkit-gtk-2.2.5-gir-nvidia-hangs.patch  |  95 +++++++
 .../files/webkit-gtk-2.2.5-hppa-platform.patch     |  20 ++
 .../files/webkit-gtk-2.2.5-ia64-platform.patch     |  12 +
 .../files/webkit-gtk-2.2.5-sparc64-build.patch     |  23 ++
 .../files/webkit-gtk-2.4.1-ia64-malloc.patch       |  20 ++
 net-libs/webkit-gtk/webkit-gtk-2.4.1-r200.ebuild   | 269 ++++++++++++++++++++
 net-libs/webkit-gtk/webkit-gtk-2.4.1.ebuild        | 272 +++++++++++++++++++++
 12 files changed, 814 insertions(+), 117 deletions(-)

diff --git a/net-libs/webkit-gtk/files/gir-paxctl-lt-wrapper 
b/net-libs/webkit-gtk/files/gir-paxctl-lt-wrapper
deleted file mode 100755
index d4f270c..0000000
--- a/net-libs/webkit-gtk/files/gir-paxctl-lt-wrapper
+++ /dev/null
@@ -1,33 +0,0 @@
-#!/bin/bash
-# Wrapper for $(LIBTOOL) that performs PaX marking on the dumper binary
-# generated by g-ir-scanner.
-# PaX marking code stolen from pax-utils.eclass
-
-flags=${1//-}; shift
-
-echo ${LIBTOOL} "$@"
-${LIBTOOL} "$@"
-
-retval=$?
-
-files=$(find . -path "*tmp-introspect*/.libs/*")
-
-if type -p paxctl > /dev/null; then
-       echo "PT PaX marking -${flags} ${files}"
-       for f in ${files}; do
-               # First, try modifying the existing PAX_FLAGS header
-               paxctl -q${flags} "${f}" && continue
-               # Second, try stealing the (unused under PaX) PT_GNU_STACK 
header
-               paxctl -qc${flags} "${f}" && continue
-               # Third, try pulling the base down a page, to create space and
-               # insert a PT_GNU_STACK header (works on ET_EXEC)
-               paxctl -qC${flags} "${f}" && continue
-       done
-elif type -p scanelf > /dev/null; then
-       # Try scanelf, the Gentoo swiss-army knife ELF utility
-       # Currently this sets PT if it can, no option to control what it does.
-       echo "Fallback PaX marking -${flags} ${files}"
-       scanelf -Xxz ${flags} ${files}
-fi
-
-exit ${retval}

diff --git 
a/net-libs/webkit-gtk/files/webkit-gtk-1.6.3-paxctl-introspection.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-1.6.3-paxctl-introspection.patch
deleted file mode 100644
index c34cc40..0000000
--- a/net-libs/webkit-gtk/files/webkit-gtk-1.6.3-paxctl-introspection.patch
+++ /dev/null
@@ -1,21 +0,0 @@
-diff -ru a/Source/WebKit/gtk/GNUmakefile.am b/Source/WebKit/gtk/GNUmakefile.am
---- a/Source/WebKit/gtk/GNUmakefile.am
-+++ b/Source/WebKit/gtk/GNUmakefile.am
-@@ -269,7 +269,7 @@
- WEBKIT_GIRSOURCES += WebKit-@[email protected]
- 
- $(WEBKIT_GIRSOURCES): $(G_IR_SCANNER) $(JSCORE_GIRSOURCES) 
libwebkitgtk-@WEBKITGTK_API_MAJOR_VERSION@.@[email protected]
--      $(AM_V_GEN)$(G_IR_SCANNER) -v --warn-all \
-+      $(AM_V_GEN)LIBTOOL="$(LIBTOOL)" $(G_IR_SCANNER) -v --warn-all \
-            --symbol-prefix=webkit \
-            --identifier-prefix=WebKit \
-            --namespace=WebKit \
-@@ -280,7 +280,7 @@
-            --include=Soup-2.4 \
-            --library=webkitgtk-@WEBKITGTK_API_VERSION@ \
-            --library=javascriptcoregtk-@WEBKITGTK_API_VERSION@ \
--           --libtool="$(LIBTOOL)" \
-+           --libtool="bash $(top_srcdir)/gir-paxctl-lt-wrapper m" \
-            --pkg=gobject-2.0 \
-            --pkg=gtk+-@GTK_API_VERSION@ \
-            --pkg=libsoup-2.4 \

diff --git 
a/net-libs/webkit-gtk/files/webkit-gtk-1.7.90-test_garbage_collection.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-1.7.90-test_garbage_collection.patch
deleted file mode 100644
index 577c249..0000000
--- a/net-libs/webkit-gtk/files/webkit-gtk-1.7.90-test_garbage_collection.patch
+++ /dev/null
@@ -1,18 +0,0 @@
-Garbage collection test fails intermittently if icedtea browser plugin is
-installed.
-
---- a/Source/WebKit/gtk/tests/testdomdocument.c
-+++ b/Source/WebKit/gtk/tests/testdomdocument.c
-@@ -353,12 +353,6 @@
-                test_dom_document_get_links,
-                dom_document_fixture_teardown);
- 
--    g_test_add("/webkit/domdocument/test_garbage_collection",
--               DomDocumentFixture, HTML_DOCUMENT_LINKS,
--               dom_document_fixture_setup,
--               test_dom_document_garbage_collection,
--               dom_document_fixture_teardown);
--
-     return g_test_run();
- }
- 

diff --git a/net-libs/webkit-gtk/files/webkit-gtk-2.2.2-unittests-build.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-2.2.2-unittests-build.patch
deleted file mode 100644
index 14fa30f..0000000
--- a/net-libs/webkit-gtk/files/webkit-gtk-2.2.2-unittests-build.patch
+++ /dev/null
@@ -1,45 +0,0 @@
-From: Gilles Dartiguelongue <[email protected]>
-Date: Wed, 27 Nov 2013 23:36:41 +0100
-Subject: [PATCH] Build unittests on demand
-
---- a/GNUmakefile.am   2013-11-27 23:52:56.148735433 +0100
-+++ b/GNUmakefile.am   2013-11-27 23:51:25.551590806 +0100
-@@ -51,6 +51,7 @@
- # Libraries and support components
- bin_PROGRAMS :=
- noinst_PROGRAMS :=
-+check_PROGRAMS :=
- libexec_PROGRAMS :=
- noinst_DATA :=
- noinst_HEADERS :=
---- a/Source/WebKit/gtk/GNUmakefile.am
-+++ b/Source/WebKit/gtk/GNUmakefile.am
-@@ -446,7 +446,7 @@ webkit_tests_ldflags = \
-       -no-fast-install
- 
- if ENABLE_WEBKIT1
--noinst_PROGRAMS += \
-+check_PROGRAMS += \
-       Programs/unittests/testapplicationcache \
-       Programs/unittests/testcontextmenu \
-       Programs/unittests/testdomdocument \
---- a/Source/WebKit2/UIProcess/API/gtk/tests/GNUmakefile.am
-+++ b/Source/WebKit2/UIProcess/API/gtk/tests/GNUmakefile.am
-@@ -25,12 +25,12 @@ TEST_PROGS += \
-       Programs/WebKit2APITests/TestWebKitWebViewGroup \
-       Programs/WebKit2APITests/TestWebViewEditor
- 
--noinst_PROGRAMS += $(TEST_PROGS)
-+check_PROGRAMS += $(TEST_PROGS)
- 
- if HAVE_ATSPI2
- TEST_PROGS += Programs/WebKit2APITests/TestWebKitAccessibility
- 
--noinst_PROGRAMS += Programs/WebKit2APITests/AccessibilityTestServer
-+check_PROGRAMS += Programs/WebKit2APITests/AccessibilityTestServer
- endif
- 
- webkit2_tests_cppflags = \
--- 
-1.8.3.2
-

diff --git a/net-libs/webkit-gtk/files/webkit-gtk-2.2.4-unittests-build.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-2.2.4-unittests-build.patch
new file mode 100644
index 0000000..a6077b4
--- /dev/null
+++ b/net-libs/webkit-gtk/files/webkit-gtk-2.2.4-unittests-build.patch
@@ -0,0 +1,103 @@
+From: Gilles Dartiguelongue <[email protected]>
+Date: Wed, 03 Feb 2014 23:47:39 +0100
+Subject: [PATCH] Build unittests on demand
+
+--- a/GNUmakefile.am   2013-11-27 23:52:56.148735433 +0100
++++ b/GNUmakefile.am   2013-11-27 23:51:25.551590806 +0100
+@@ -51,6 +51,9 @@
+ # Libraries and support components
+ bin_PROGRAMS :=
+ noinst_PROGRAMS :=
++check_PROGRAMS :=
++check_LTLIBRARIES :=
++check_DATA :=
+ libexec_PROGRAMS :=
+ noinst_DATA :=
+ noinst_HEADERS :=
+--- a/Tools/TestWebKitAPI/GNUmakefile.am       2014-02-03 23:44:52.534272572 
+0100
++++ b/Tools/TestWebKitAPI/GNUmakefile.am       2014-02-03 23:45:41.711783299 
+0100
+@@ -1,8 +1,8 @@
+-noinst_LTLIBRARIES += \
++check_LTLIBRARIES += \
+       Libraries/libTestWebKitAPIMain.la
+ 
+ if ENABLE_WEBKIT2
+-noinst_LTLIBRARIES += \
++check_LTLIBRARIES += \
+       Libraries/libTestWebKit2GtkAPI.la
+ endif
+ 
+@@ -111,14 +111,14 @@
+ Libraries_libTestWebKit2GtkAPI_la_CPPFLAGS = $(webkit2gtk_tests_cppflags)
+ 
+ 
+-noinst_PROGRAMS += \
++check_PROGRAMS += \
+       Programs/TestWebKitAPI/WTF/TestWTF \
+       Programs/TestWebKitAPI/JavaScriptCore/TestJavaScriptCore \
+       Programs/TestWebKitAPI/WebCore/TestWebCore \
+       Programs/TestWebKitAPI/WebCoreGtk/TestWebCoreGtk
+ 
+ if ENABLE_WEBKIT1
+-noinst_PROGRAMS += \
++check_PROGRAMS += \
+       Programs/TestWebKitAPI/WebKitGtk/testapplicationcache \
+       Programs/TestWebKitAPI/WebKitGtk/testcontextmenu \
+       Programs/TestWebKitAPI/WebKitGtk/testdomdocument \
+@@ -150,7 +150,7 @@
+ endif
+ 
+ if ENABLE_WEBKIT2
+-noinst_PROGRAMS += \
++check_PROGRAMS += \
+       Programs/TestWebKitAPI/WebKit2/TestWebKit2 \
+       Programs/TestWebKitAPI/WebKit2Gtk/InspectorTestServer \
+       Programs/TestWebKitAPI/WebKit2Gtk/TestAuthentication \
+@@ -179,7 +179,7 @@
+       Programs/TestWebKitAPI/WebKit2Gtk/TestWebViewEditor
+ 
+ if HAVE_ATSPI2
+-noinst_PROGRAMS += \
++check_PROGRAMS += \
+       Programs/TestWebKitAPI/WebKit2Gtk/AccessibilityTestServer \
+       Programs/TestWebKitAPI/WebKit2Gtk/TestWebKitAccessibility
+ endif
+@@ -627,7 +627,7 @@
+       Tools/TestWebKitAPI/Tests/WebKit2/WKURL.cpp
+ 
+ if ENABLE_WEBKIT2
+-noinst_LTLIBRARIES += \
++check_LTLIBRARIES += \
+       Libraries/libTestWebKitAPIInjectedBundle.la
+ endif # ENABLE_WEBKIT2
+ 
+@@ -684,7 +684,7 @@
+ 
+ 
+ if ENABLE_WEBKIT2
+-noinst_LTLIBRARIES += Libraries/WebExtensions/libWebExtensionTest.la
++check_LTLIBRARIES += Libraries/WebExtensions/libWebExtensionTest.la
+ endif
+ 
+ Libraries_WebExtensions_libWebExtensionTest_la_SOURCES = \
+@@ -711,7 +711,7 @@
+ 
+ 
+ if ENABLE_WEBKIT2
+-noinst_LTLIBRARIES += Libraries/WebExtensions/libWebProcessTest.la
++check_LTLIBRARIES += Libraries/WebExtensions/libWebProcessTest.la
+ endif
+ 
+ Libraries_WebExtensions_libWebProcessTest_la_SOURCES = \
+@@ -747,7 +747,7 @@
+ DISTCLEANFILES += \
+       
Programs/TestWebKitAPI/WebKit2Gtk/resources/webkit2gtk-tests-resources.gresource
+ 
+-noinst_DATA += \
++check_DATA += \
+       
Programs/TestWebKitAPI/WebKit2Gtk/resources/webkit2gtk-tests-resources.gresource
+ 
+ 
+-- 
+1.8.3.2
+

diff --git a/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-gir-nvidia-hangs.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-gir-nvidia-hangs.patch
new file mode 100644
index 0000000..854a112
--- /dev/null
+++ b/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-gir-nvidia-hangs.patch
@@ -0,0 +1,95 @@
+Description: deadlock in gobject introspection
+Bug-Dyson: http://osdyson.org/issues/161
+Bug-Gentoo: https://bugs.gentoo.org/show_bug.cgi?id=463960
+Stack:
+25849:  /home/pashev/packaging/webkitgtk/webkitgtk-2.0.4/build-2.0/tmp-introsp
+-----------------  lwp# 1 / thread# 1  --------------------
+ fffffd7ffeeaf957 lwp_park (0, 0, 0)
+ fffffd7ffeea8036 mutex_lock_impl () + 156
+ fffffd7ffeea810b mutex_lock () + b
+ fffffd7ffee340fa _preexec_atfork_unload () + 3a
+ fffffd7ffee343ab _preexec_exit_handlers () + bb
+ fffffd7fff5ccf0d purge_exit_handlers () + 10d
+ fffffd7fff5cec18 remove_hdl () + ce8
+ fffffd7fff5c8895 dlclose_core () + c5
+ fffffd7fff5c88e5 dlclose_intn () + 15
+ fffffd7fff5c89bb dlclose_check () + 7b
+ fffffd7fff5c8a21 dlclose () + 41
+ fffffd7ffaa03c41 px_module_manager_load () + 191
+ fffffd7ffaa03cf6 px_module_manager_load_dir () + 66
+ fffffd7ffaa050d7 px_proxy_factory_new () + 107
+ fffffd7ffb201671 ???????? ()
+ fffffd7feca30eca g_type_create_instance () + 16a
+ fffffd7feca1597c ???????? ()
+ fffffd7feca17472 g_object_newv () + 792
+ fffffd7feca17aec g_object_new () + ec
+ fffffd7fece5d052 ???????? ()
+ fffffd7fece5d1d8 ???????? ()
+ fffffd7fc98659a5 ???????? ()
+ fffffd7feca173f6 g_object_newv () + 716
+ fffffd7feca17aec g_object_new () + ec
+ fffffd7fc986da24 soup_session_add_feature_by_type () + e4
+ fffffd7fc986fb43 ???????? ()
+ fffffd7feca17e00 g_object_set_valist () + 300
+ fffffd7feca186d7 g_object_set () + e7
+ fffffd7fc5724f87 WebCore::ResourceHandle::defaultSession() () + a7
+ fffffd7fc48da299 webkitExit() () + 9
+ fffffd7ffee33f56 _exithandle () + 66
+ fffffd7ffee1e191 exit () + 11
+ 00000000004086af ???????? ()
+ 000000000040724c _start () + 6c
+-----------------  lwp# 2 / thread# 2  --------------------
+ fffffd7ffeeaf957 lwp_park (0, 0, 0)
+ fffffd7ffeea94bf cond_wait_queue () + 4f
+ fffffd7ffeea9b12 __cond_wait () + b2
+ fffffd7ffeea9b42 cond_wait () + 22
+ fffffd7ffeea9b79 pthread_cond_wait () + 9
+ fffffd7fc4eed04b WebCore::IconDatabase::syncThreadMainLoop() () + 12b
+ fffffd7fc4eed278 WebCore::IconDatabase::iconDatabaseSyncThread() () + 138
+ fffffd7fc3b2bc59 WTF::wtfThreadEntryPoint(void*) () + 19
+ fffffd7ffeeaf617 _thrp_setup () + 77
+ fffffd7ffeeaf910 _lwp_start ()
+-----------------  lwp# 3 / thread# 3  --------------------
+ fffffd7ffeeaf957 lwp_park (0, 0, 0)
+ fffffd7ffeea8036 mutex_lock_impl () + 156
+ fffffd7ffeea810b mutex_lock () + b
+ fffffd7ffee33e17 atexit_locks () + 17
+ fffffd7ffee58ce9 libc_prepare_atfork () + 9
+ fffffd7ffee34533 _prefork_handler () + 33
+ fffffd7ffee9fc85 forkx () + 275
+ fffffd7ffee9fcab fork () + b
+ fffffd7fec68aacb ???????? ()
+ fffffd7fec68b2a7 g_spawn_sync () + 167
+ fffffd7fec68b994 g_spawn_command_line_sync () + 74
+ fffffd7feceb2748 ???????? ()
+ fffffd7feceb4019 g_dbus_address_get_for_bus_sync () + 2c9
+ fffffd7fecebd11e ???????? ()
+ fffffd7fecec4643 g_bus_get_sync () + 63
+ fffffd7ffc60700b ???????? ()
+ fffffd7ffc60714f ???????? ()
+ fffffd7fec648ad0 g_main_context_dispatch () + 130
+ fffffd7fec648e40 ???????? ()
+ fffffd7fec648f08 g_main_context_iteration () + 38
+ fffffd7ffc606f65 ???????? ()
+ fffffd7fec66d50d ???????? ()
+ fffffd7ffeeaf617 _thrp_setup () + 77
+ fffffd7ffeeaf910 _lwp_start ()
+Index: webkit/Source/WebKit/gtk/webkit/webkitglobals.cpp
+===================================================================
+--- webkit.orig/Source/WebKit/gtk/webkit/webkitglobals.cpp     2013-12-02 
00:06:10.504150531 +0400
++++ webkit/Source/WebKit/gtk/webkit/webkitglobals.cpp  2013-12-03 
14:08:05.956932011 +0400
+@@ -564,6 +564,14 @@
+ 
+     WebCore::SchemeRegistry::registerURLSchemeAsLocal("resource");
+ 
++    // http://osdyson.org/issues/161
++    // WebKitGTK FTBFS when building GObject introspection due to deadlock.
++    // When gobject introspection is done, a simple program call exit()
++    // exit() -> webkitExit() -> g_object_unref() -> 
webkit_get_default_session()
++    // -> ResourceHandle::defaultSession() => default session doesn't exist! 
AND
++    // we try to create it! Thus deadlock. So, create default session earlier:
++    (void) webkit_get_default_session();
++
+     atexit(webkitExit);
+ }
+ 

diff --git a/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-hppa-platform.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-hppa-platform.patch
new file mode 100644
index 0000000..8aee778
--- /dev/null
+++ b/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-hppa-platform.patch
@@ -0,0 +1,20 @@
+Index: webkitgtk/Source/WTF/wtf/Platform.h
+===================================================================
+--- webkitgtk.orig/Source/WTF/wtf/Platform.h
++++ webkitgtk/Source/WTF/wtf/Platform.h
+@@ -72,6 +72,15 @@
+ #define WTF_CPU_BIG_ENDIAN 1
+ #endif
+ 
++/* CPU(HPPA) - HP PARISC */
++#if defined(__hppa__)
++#define WTF_CPU_HPPA 1
++#define WTF_CPU_BIG_ENDIAN 1
++#define ENABLE_JIT 0
++#define ENABLE_YARR_JIT 0
++#define ENABLE_ASSEMBLER 0
++#endif
++
+ /* CPU(IA64) - Itanium / IA-64 */
+ #if defined(__ia64__)
+ #define WTF_CPU_IA64 1

diff --git a/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-ia64-platform.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-ia64-platform.patch
new file mode 100644
index 0000000..a63e9e8
--- /dev/null
+++ b/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-ia64-platform.patch
@@ -0,0 +1,12 @@
+--- a/Source/WTF/wtf/Platform.h        2014-02-25 00:33:16.561606810 +0100
++++ b/Source/WTF/wtf/Platform.h        2014-02-25 00:49:52.895512955 +0100
+@@ -79,6 +79,9 @@
+ #if !defined(__LP64__)
+ #define WTF_CPU_IA64_32 1
+ #endif
++#define ENABLE_JIT 0
++#define ENABLE_YARR_JIT 0
++#define ENABLE_ASSEMBLER 0
+ #endif
+ 
+ /* CPU(MIPS) - MIPS 32-bit */

diff --git a/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-sparc64-build.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-sparc64-build.patch
new file mode 100644
index 0000000..691b528
--- /dev/null
+++ b/net-libs/webkit-gtk/files/webkit-gtk-2.2.5-sparc64-build.patch
@@ -0,0 +1,23 @@
+$OpenBSD: patch-Source_WTF_wtf_Atomics_h,v 1.3 2013/10/20 09:07:57 landry Exp $
+
+https://bugs.webkit.org/show_bug.cgi?id=86835
+Fix build failure on sparc64 since 1.8.1, provide atomic{In,De}crement implems 
based on __sync_fetch_and_add builtin
+
+--- Source/WTF/wtf/Atomics.h.orig      Sat Aug  3 18:10:38 2013
++++ Source/WTF/wtf/Atomics.h   Sun Oct 20 11:06:14 2013
+@@ -112,6 +112,15 @@ inline int atomicDecrement(int volatile* addend) { ret
+ inline int64_t atomicIncrement(int64_t volatile* addend) { return 
__sync_add_and_fetch(addend, 1); }
+ inline int64_t atomicDecrement(int64_t volatile* addend) { return 
__sync_sub_and_fetch(addend, 1); }
+ 
++#elif COMPILER(GCC) && CPU(SPARC64)
++#define WTF_USE_LOCKFREE_THREADSAFEREFCOUNTED 1
++
++inline int atomicIncrement(int volatile* addend) { return 
__sync_fetch_and_add(addend, 1) + 1; }
++inline int atomicDecrement(int volatile* addend) { return 
__sync_fetch_and_add(addend, -1) - 1; }
++
++inline int64_t atomicIncrement(int64_t volatile* addend) { return 
__sync_fetch_and_add(addend, 1) + 1; }
++inline int64_t atomicDecrement(int64_t volatile* addend) { return 
__sync_fetch_and_add(addend, -1) - 1; }
++
+ #endif
+ 
+ #if OS(WINDOWS)

diff --git a/net-libs/webkit-gtk/files/webkit-gtk-2.4.1-ia64-malloc.patch 
b/net-libs/webkit-gtk/files/webkit-gtk-2.4.1-ia64-malloc.patch
new file mode 100644
index 0000000..8c387ff
--- /dev/null
+++ b/net-libs/webkit-gtk/files/webkit-gtk-2.4.1-ia64-malloc.patch
@@ -0,0 +1,20 @@
+Description: Fix wide pointer issues on ia64 (closes: #642750).
+Author: Stephan Schreiber <[email protected]>
+Index: webkitgtk/Source/WTF/wtf/Platform.h
+===================================================================
+--- webkitgtk.orig/Source/WTF/wtf/Platform.h
++++ webkitgtk/Source/WTF/wtf/Platform.h
+@@ -705,6 +705,13 @@
+ #define ENABLE_JIT 1
+ #endif
+ 
++/* FIXME: The fast malloc implementation is broken on Itanium / IA64 because
++   some memory barriers are missing in the thread-unsafe code around the
++   pagemap_cache_ object. */
++#if CPU(IA64) || CPU(IA64_32)
++#define USE_SYSTEM_MALLOC 1
++#endif
++
+ /* The JIT is enabled by default on all x86, x86-64, ARM & MIPS platforms 
except Win64. */
+ #if !defined(ENABLE_JIT) \
+     && (CPU(X86) || CPU(X86_64) || CPU(ARM) || CPU(ARM64) || CPU(MIPS)) \

diff --git a/net-libs/webkit-gtk/webkit-gtk-2.4.1-r200.ebuild 
b/net-libs/webkit-gtk/webkit-gtk-2.4.1-r200.ebuild
new file mode 100644
index 0000000..7fe38de
--- /dev/null
+++ b/net-libs/webkit-gtk/webkit-gtk-2.4.1-r200.ebuild
@@ -0,0 +1,269 @@
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+EAPI="5"
+GCONF_DEBUG="no"
+PYTHON_COMPAT=( python{2_6,2_7} )
+
+inherit autotools check-reqs eutils flag-o-matic gnome2 pax-utils 
python-any-r1 toolchain-funcs versionator virtualx
+
+MY_P="webkitgtk-${PV}"
+DESCRIPTION="Open source web browser engine"
+HOMEPAGE="http://www.webkitgtk.org/";
+SRC_URI="http://www.webkitgtk.org/releases/${MY_P}.tar.xz";
+
+LICENSE="LGPL-2+ BSD"
+SLOT="2" # no usable subslot
+KEYWORDS="~alpha ~amd64 ~arm ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86 ~amd64-fbsd 
~x86-fbsd ~x86-freebsd ~amd64-linux ~ia64-linux ~x86-linux ~x86-macos"
+IUSE="aqua coverage debug +egl +geoloc gles2 +gstreamer +introspection +jit 
libsecret +opengl spell +webgl +X"
+# bugs 372493, 416331
+REQUIRED_USE="
+       geoloc? ( introspection )
+       introspection? ( gstreamer )
+       gles2? ( egl )
+       webgl? ( ^^ ( gles2 opengl ) )
+       !webgl? ( ?? ( gles2 opengl ) )
+       || ( aqua X )
+"
+
+# use sqlite, svg by default
+RDEPEND="
+       dev-libs/libxml2:2
+       dev-libs/libxslt
+       media-libs/harfbuzz:=[icu(+)]
+       media-libs/libwebp:=
+       virtual/jpeg:0=
+       >=media-libs/libpng-1.4:0=
+       >=x11-libs/cairo-1.10:=[X]
+       >=dev-libs/glib-2.36.0:2
+       >=dev-libs/icu-3.8.1-r1:=
+       >=net-libs/libsoup-2.42.0:2.4[introspection?]
+       dev-db/sqlite:3=
+       >=x11-libs/pango-1.30.0.0
+       x11-libs/libXrender
+       x11-libs/libXt
+       >=x11-libs/gtk+-2.24.10:2
+
+       egl? ( media-libs/mesa[egl] )
+       geoloc? ( >=app-misc/geoclue-2.1.5:2.0 )
+       gles2? ( media-libs/mesa[gles2] )
+       gstreamer? (
+               >=media-libs/gstreamer-1.2:1.0
+               >=media-libs/gst-plugins-base-1.2:1.0 )
+       introspection? ( >=dev-libs/gobject-introspection-1.32.0 )
+       libsecret? ( app-crypt/libsecret )
+       opengl? ( virtual/opengl )
+       spell? ( >=app-text/enchant-0.22:= )
+       webgl? (
+               x11-libs/cairo[opengl]
+               x11-libs/libXcomposite
+               x11-libs/libXdamage )
+"
+
+# paxctl needed for bug #407085
+# Need real bison, not yacc
+DEPEND="${RDEPEND}
+       ${PYTHON_DEPS}
+       dev-lang/perl
+       || (
+               virtual/rubygems[ruby_targets_ruby20]
+               virtual/rubygems[ruby_targets_ruby21]
+               virtual/rubygems[ruby_targets_ruby19]
+       )
+       >=dev-libs/atk-2.8.0
+       >=dev-util/gtk-doc-am-1.10
+       dev-util/gperf
+       >=sys-devel/bison-2.4.3
+       >=sys-devel/flex-2.5.33
+       || ( >=sys-devel/gcc-4.7 >=sys-devel/clang-3.3 )
+       sys-devel/gettext
+       >=sys-devel/make-3.82-r4
+       virtual/pkgconfig
+
+       introspection? ( jit? ( sys-apps/paxctl ) )
+       test? (
+               dev-lang/python:2.7
+               dev-python/pygobject:3[python_targets_python2_7]
+               x11-themes/hicolor-icon-theme
+               jit? ( sys-apps/paxctl ) )
+"
+
+S="${WORKDIR}/${MY_P}"
+
+CHECKREQS_DISK_BUILD="18G" # and even this might not be enough, bug #417307
+
+pkg_pretend() {
+       if [[ ${MERGE_TYPE} != "binary" ]] && is-flagq "-g*" && ! is-flagq 
"-g*0" ; then
+               einfo "Checking for sufficient disk space to build ${PN} with 
debugging CFLAGS"
+               check-reqs_pkg_pretend
+       fi
+
+       if ! test-flag-CXX -std=c++11; then
+               die "You need at least GCC 4.7.x or Clang >= 3.3 for 
C++11-specific compiler flags"
+       fi
+}
+
+pkg_setup() {
+       # Check whether any of the debugging flags is enabled
+       if [[ ${MERGE_TYPE} != "binary" ]] && is-flagq "-g*" && ! is-flagq 
"-g*0" ; then
+               if is-flagq "-ggdb" && [[ ${WEBKIT_GTK_GGDB} != "yes" ]]; then
+                       replace-flags -ggdb -g
+                       ewarn "Replacing \"-ggdb\" with \"-g\" in your CFLAGS."
+                       ewarn "Building ${PN} with \"-ggdb\" produces binaries 
which are too"
+                       ewarn "large for current binutils releases (bug 
#432784) and has very"
+                       ewarn "high temporary build space and memory 
requirements."
+                       ewarn "If you really want to build ${PN} with 
\"-ggdb\", add"
+                       ewarn "WEBKIT_GTK_GGDB=yes"
+                       ewarn "to your make.conf file."
+               fi
+               einfo "You need to have at least 18GB of temporary build space 
available"
+               einfo "to build ${PN} with debugging CFLAGS. Note that it might 
still"
+               einfo "not be enough, as the total space requirements depend on 
the flags"
+               einfo "(-ggdb vs -g1) and enabled features."
+               check-reqs_pkg_setup
+       fi
+
+       [[ ${MERGE_TYPE} = "binary" ]] || python-any-r1_pkg_setup
+}
+
+src_prepare() {
+       # intermediate MacPorts hack while upstream bug is not fixed properly
+       # https://bugs.webkit.org/show_bug.cgi?id=28727
+       use aqua && epatch "${FILESDIR}"/${PN}-1.6.1-darwin-quartz.patch
+
+       # Leave optimization level to user CFLAGS
+       # FORTIFY_SOURCE is enabled by default in Gentoo
+       sed -e 's/-O[012]//g' \
+               -e 's/-D_FORTIFY_SOURCE=2//g' \
+               -i Source/autotools/SetupCompilerFlags.m4 || die
+
+       # Failing tests
+       # * webinspector -> https://bugs.webkit.org/show_bug.cgi?id=50744
+       # * keyevents is interactive
+       # * mimehandling test sometimes fails under Xvfb (works fine manually), 
bug #???
+       # * webdatasource test needs a network connection and intermittently 
fails with icedtea-web
+       # * webplugindatabase intermittently fails with icedtea-web, bug #????
+       sed -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testwebinspector/ d' \
+               -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testkeyevents/ d' \
+               -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testmimehandling/ d' \
+               -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testwebdatasource/ d' \
+               -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testwebplugindatabase/ 
d' \
+               -i Tools/TestWebKitAPI/GNUmakefile.am || die
+
+       # bug #459978, upstream bug #113397
+       epatch "${FILESDIR}/${PN}-1.11.90-gtk-docize-fix.patch"
+
+       # Do not build unittests unless requested, upstream bug #128163
+       epatch "${FILESDIR}"/${PN}-2.2.4-unittests-build.patch
+
+       # Deadlock causing infinite compilations with nvidia-drivers:
+       # https://bugs.gentoo.org/show_bug.cgi?id=463960
+       # http://osdyson.org/issues/161
+       # https://bugs.webkit.org/show_bug.cgi?id=125651
+       epatch "${FILESDIR}"/${PN}-2.2.5-gir-nvidia-hangs.patch
+
+       # Debian patches to fix support for some arches
+       # https://bugs.webkit.org/show_bug.cgi?id=129540
+       epatch "${FILESDIR}"/${PN}-2.2.5-{hppa,ia64}-platform.patch
+       # https://bugs.webkit.org/show_bug.cgi?id=129542
+       epatch "${FILESDIR}"/${PN}-2.4.1-ia64-malloc.patch
+
+       AT_M4DIR=Source/autotools eautoreconf
+
+       gnome2_src_prepare
+}
+
+src_configure() {
+       # Respect CC, otherwise fails on prefix #395875
+       tc-export CC
+
+       # Arches without JIT support also need this to really disable it in all 
places
+       use jit || append-cppflags -DENABLE_JIT=0 -DENABLE_YARR_JIT=0 
-DENABLE_ASSEMBLER=0
+
+       # It doesn't compile on alpha without this in LDFLAGS, bug #???
+       use alpha && append-ldflags "-Wl,--no-relax"
+
+       # Sigbuses on SPARC with mcpu and co., bug #???
+       use sparc && filter-flags "-mvis"
+
+       # https://bugs.webkit.org/show_bug.cgi?id=42070 , #301634
+       use ppc64 && append-flags "-mminimal-toc"
+
+       # Try to use less memory, bug #469942 (see Fedora .spec for reference)
+       # --no-keep-memory doesn't work on ia64, bug #502492
+       if ! use ia64; then
+               append-ldflags "-Wl,--no-keep-memory"
+       fi
+       if ! $(tc-getLD) --version | grep -q "GNU gold"; then
+               append-ldflags "-Wl,--reduce-memory-overheads"
+       fi
+
+       local myconf=""
+
+       if has_version "virtual/rubygems[ruby_targets_ruby21]"; then
+               myconf="${myconf} RUBY=$(type -P ruby21)"
+       elif has_version "virtual/rubygems[ruby_targets_ruby20]"; then
+               myconf="${myconf} RUBY=$(type -P ruby20)"
+       else
+               myconf="${myconf} RUBY=$(type -P ruby19)"
+       fi
+
+       # TODO: Check Web Audio support
+       # should somehow let user select between them?
+       #
+       # * dependency-tracking is required so parallel builds won't fail
+       gnome2_src_configure \
+               $(use_enable aqua quartz-target) \
+               $(use_enable coverage) \
+               $(use_enable debug) \
+               $(use_enable egl) \
+               $(use_enable geoloc geolocation) \
+               $(use_enable gles2) \
+               $(use_enable gstreamer video) \
+               $(use_enable gstreamer web-audio) \
+               $(use_enable introspection) \
+               $(use_enable jit) \
+               $(use_enable libsecret credential_storage) \
+               $(use_enable opengl glx) \
+               $(use_enable spell spellcheck) \
+               $(use_enable webgl) \
+               $(use_enable webgl accelerated-compositing) \
+               $(use_enable X x11-target) \
+               --with-gtk=2.0 \
+               --disable-webkit2 \
+               --enable-dependency-tracking \
+               --disable-gtk-doc \
+               ${myconf}
+}
+
+src_test() {
+       # Tests expect an out-of-source build in WebKitBuild
+       ln -s . WebKitBuild || die "ln failed"
+
+       # Prevents test failures on PaX systems
+       use jit && pax-mark m $(list-paxables Programs/*[Tt]ests/*) # 
Programs/unittests/.libs/test*
+
+       unset DISPLAY
+       # Tests need virtualx, bug #294691, bug #310695
+       # Parallel tests sometimes fail
+       Xemake -j1 check
+}
+
+src_install() {
+       DOCS="ChangeLog NEWS" # other ChangeLog files handled by src_install
+
+       # https://bugs.webkit.org/show_bug.cgi?id=129242
+       MAKEOPTS="${MAKEOPTS} -j1" gnome2_src_install
+
+       newdoc Source/WebKit/gtk/ChangeLog ChangeLog.gtk
+       newdoc Source/JavaScriptCore/ChangeLog ChangeLog.JavaScriptCore
+       newdoc Source/WebCore/ChangeLog ChangeLog.WebCore
+
+       # Prevents crashes on PaX systems
+       use jit && pax-mark m "${ED}usr/bin/jsc-1"
+
+       # File collisions with slot 3
+       # bug #402699, https://bugs.webkit.org/show_bug.cgi?id=78134
+       rm -rf "${ED}usr/share/gtk-doc" || die
+}

diff --git a/net-libs/webkit-gtk/webkit-gtk-2.4.1.ebuild 
b/net-libs/webkit-gtk/webkit-gtk-2.4.1.ebuild
new file mode 100644
index 0000000..9f43613
--- /dev/null
+++ b/net-libs/webkit-gtk/webkit-gtk-2.4.1.ebuild
@@ -0,0 +1,272 @@
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+EAPI="5"
+GCONF_DEBUG="no"
+PYTHON_COMPAT=( python{2_6,2_7} )
+
+inherit autotools check-reqs eutils flag-o-matic gnome2 pax-utils 
python-any-r1 toolchain-funcs versionator virtualx
+
+MY_P="webkitgtk-${PV}"
+DESCRIPTION="Open source web browser engine"
+HOMEPAGE="http://www.webkitgtk.org/";
+SRC_URI="http://www.webkitgtk.org/releases/${MY_P}.tar.xz";
+
+LICENSE="LGPL-2+ BSD"
+SLOT="3/25" # soname version of libwebkit2gtk-3.0
+KEYWORDS="~alpha ~amd64 ~arm ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86 ~amd64-fbsd 
~x86-fbsd ~x86-freebsd ~amd64-linux ~ia64-linux ~x86-linux ~x86-macos"
+IUSE="aqua coverage debug +egl +geoloc gles2 +gstreamer +introspection +jit 
libsecret +opengl spell wayland +webgl +X"
+# bugs 372493, 416331
+REQUIRED_USE="
+       geoloc? ( introspection )
+       introspection? ( gstreamer )
+       gles2? ( egl )
+       webgl? ( ^^ ( gles2 opengl ) )
+       !webgl? ( ?? ( gles2 opengl ) )
+       || ( aqua wayland X )
+"
+
+# use sqlite, svg by default
+# Aqua support in gtk3 is untested
+# gtk2 is needed for plugin process support
+# gtk3-3.10 required for wayland
+RDEPEND="
+       dev-libs/libxml2:2
+       dev-libs/libxslt
+       media-libs/harfbuzz:=[icu(+)]
+       media-libs/libwebp:=
+       virtual/jpeg:0=
+       >=media-libs/libpng-1.4:0=
+       >=x11-libs/cairo-1.10:=[X]
+       >=dev-libs/glib-2.36.0:2
+       >=x11-libs/gtk+-3.6.0:3[aqua=,introspection?]
+       >=dev-libs/icu-3.8.1-r1:=
+       >=net-libs/libsoup-2.42.0:2.4[introspection?]
+       dev-db/sqlite:3=
+       >=x11-libs/pango-1.30.0.0
+       x11-libs/libXrender
+       x11-libs/libXt
+       >=x11-libs/gtk+-2.24.10:2
+
+       egl? ( media-libs/mesa[egl] )
+       geoloc? ( >=app-misc/geoclue-2.1.5:2.0 )
+       gles2? ( media-libs/mesa[gles2] )
+       gstreamer? (
+               >=media-libs/gstreamer-1.2:1.0
+               >=media-libs/gst-plugins-base-1.2:1.0 )
+       introspection? ( >=dev-libs/gobject-introspection-1.32.0 )
+       libsecret? ( app-crypt/libsecret )
+       opengl? ( virtual/opengl )
+       spell? ( >=app-text/enchant-0.22:= )
+       wayland? ( >=x11-libs/gtk+-3.10:3[wayland] )
+       webgl? (
+               x11-libs/cairo[opengl]
+               x11-libs/libXcomposite
+               x11-libs/libXdamage )
+"
+
+# paxctl needed for bug #407085
+# Need real bison, not yacc
+DEPEND="${RDEPEND}
+       ${PYTHON_DEPS}
+       dev-lang/perl
+       || (
+               virtual/rubygems[ruby_targets_ruby20]
+               virtual/rubygems[ruby_targets_ruby21]
+               virtual/rubygems[ruby_targets_ruby19]
+       )
+       >=app-accessibility/at-spi2-core-2.5.3
+       >=dev-libs/atk-2.8.0
+       >=dev-util/gtk-doc-am-1.10
+       dev-util/gperf
+       >=sys-devel/bison-2.4.3
+       >=sys-devel/flex-2.5.33
+       || ( >=sys-devel/gcc-4.7 >=sys-devel/clang-3.3 )
+       sys-devel/gettext
+       >=sys-devel/make-3.82-r4
+       virtual/pkgconfig
+
+       introspection? ( jit? ( sys-apps/paxctl ) )
+       test? (
+               dev-lang/python:2.7
+               dev-python/pygobject:3[python_targets_python2_7]
+               x11-themes/hicolor-icon-theme
+               jit? ( sys-apps/paxctl ) )
+"
+
+S="${WORKDIR}/${MY_P}"
+
+CHECKREQS_DISK_BUILD="18G" # and even this might not be enough, bug #417307
+
+pkg_pretend() {
+       if [[ ${MERGE_TYPE} != "binary" ]] && is-flagq "-g*" && ! is-flagq 
"-g*0" ; then
+               einfo "Checking for sufficient disk space to build ${PN} with 
debugging CFLAGS"
+               check-reqs_pkg_pretend
+       fi
+
+       if ! test-flag-CXX -std=c++11; then
+               die "You need at least GCC 4.7.x or Clang >= 3.3 for 
C++11-specific compiler flags"
+       fi
+}
+
+pkg_setup() {
+       # Check whether any of the debugging flags is enabled
+       if [[ ${MERGE_TYPE} != "binary" ]] && is-flagq "-g*" && ! is-flagq 
"-g*0" ; then
+               if is-flagq "-ggdb" && [[ ${WEBKIT_GTK_GGDB} != "yes" ]]; then
+                       replace-flags -ggdb -g
+                       ewarn "Replacing \"-ggdb\" with \"-g\" in your CFLAGS."
+                       ewarn "Building ${PN} with \"-ggdb\" produces binaries 
which are too"
+                       ewarn "large for current binutils releases (bug 
#432784) and has very"
+                       ewarn "high temporary build space and memory 
requirements."
+                       ewarn "If you really want to build ${PN} with 
\"-ggdb\", add"
+                       ewarn "WEBKIT_GTK_GGDB=yes"
+                       ewarn "to your make.conf file."
+               fi
+               einfo "You need to have at least 18GB of temporary build space 
available"
+               einfo "to build ${PN} with debugging CFLAGS. Note that it might 
still"
+               einfo "not be enough, as the total space requirements depend on 
the flags"
+               einfo "(-ggdb vs -g1) and enabled features."
+               check-reqs_pkg_setup
+       fi
+
+       [[ ${MERGE_TYPE} = "binary" ]] || python-any-r1_pkg_setup
+}
+
+src_prepare() {
+       # intermediate MacPorts hack while upstream bug is not fixed properly
+       # https://bugs.webkit.org/show_bug.cgi?id=28727
+       use aqua && epatch "${FILESDIR}"/${PN}-1.6.1-darwin-quartz.patch
+
+       # Leave optimization level to user CFLAGS
+       # FORTIFY_SOURCE is enabled by default in Gentoo
+       sed -e 's/-O[012]//g' \
+               -e 's/-D_FORTIFY_SOURCE=2//g' \
+               -i Source/autotools/SetupCompilerFlags.m4 || die
+
+       # Failing tests
+       # * webinspector -> https://bugs.webkit.org/show_bug.cgi?id=50744
+       # * keyevents is interactive
+       # * mimehandling test sometimes fails under Xvfb (works fine manually), 
bug #???
+       # * webdatasource test needs a network connection and intermittently 
fails with icedtea-web
+       # * webplugindatabase intermittently fails with icedtea-web, bug #????
+       sed -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testwebinspector/ d' \
+               -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testkeyevents/ d' \
+               -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testmimehandling/ d' \
+               -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testwebdatasource/ d' \
+               -e '/Programs\/TestWebKitAPI\/WebKitGtk\/testwebplugindatabase/ 
d' \
+               -i Tools/TestWebKitAPI/GNUmakefile.am || die
+
+       # bug #459978, upstream bug #113397
+       epatch "${FILESDIR}/${PN}-1.11.90-gtk-docize-fix.patch"
+
+       # Do not build unittests unless requested, upstream bug #128163
+       epatch "${FILESDIR}"/${PN}-2.2.4-unittests-build.patch
+
+       # Deadlock causing infinite compilations with nvidia-drivers:
+       # https://bugs.gentoo.org/show_bug.cgi?id=463960
+       # http://osdyson.org/issues/161
+       # https://bugs.webkit.org/show_bug.cgi?id=125651
+       epatch "${FILESDIR}"/${PN}-2.2.5-gir-nvidia-hangs.patch
+
+       # Debian patches to fix support for some arches
+       # https://bugs.webkit.org/show_bug.cgi?id=129540
+       epatch "${FILESDIR}"/${PN}-2.2.5-{hppa,ia64}-platform.patch
+       # https://bugs.webkit.org/show_bug.cgi?id=129542
+       epatch "${FILESDIR}"/${PN}-2.4.1-ia64-malloc.patch
+
+       AT_M4DIR=Source/autotools eautoreconf
+
+       gnome2_src_prepare
+}
+
+src_configure() {
+       # Respect CC, otherwise fails on prefix #395875
+       tc-export CC
+
+       # Arches without JIT support also need this to really disable it in all 
places
+       use jit || append-cppflags -DENABLE_JIT=0 -DENABLE_YARR_JIT=0 
-DENABLE_ASSEMBLER=0
+
+       # It doesn't compile on alpha without this in LDFLAGS, bug #???
+       use alpha && append-ldflags "-Wl,--no-relax"
+
+       # Sigbuses on SPARC with mcpu and co., bug #???
+       use sparc && filter-flags "-mvis"
+
+       # https://bugs.webkit.org/show_bug.cgi?id=42070 , #301634
+       use ppc64 && append-flags "-mminimal-toc"
+
+       # Try to use less memory, bug #469942 (see Fedora .spec for reference)
+       # --no-keep-memory doesn't work on ia64, bug #502492
+       if ! use ia64; then
+               append-ldflags "-Wl,--no-keep-memory"
+       fi
+       if ! $(tc-getLD) --version | grep -q "GNU gold"; then
+               append-ldflags "-Wl,--reduce-memory-overheads"
+       fi
+
+       local myconf=""
+
+       if has_version "virtual/rubygems[ruby_targets_ruby21]"; then
+               myconf="${myconf} RUBY=$(type -P ruby21)"
+       elif has_version "virtual/rubygems[ruby_targets_ruby20]"; then
+               myconf="${myconf} RUBY=$(type -P ruby20)"
+       else
+               myconf="${myconf} RUBY=$(type -P ruby19)"
+       fi
+
+       # TODO: Check Web Audio support
+       # should somehow let user select between them?
+       #
+       # * Aqua support in gtk3 is untested
+       # * dependency-tracking is required so parallel builds won't fail
+       gnome2_src_configure \
+               $(use_enable aqua quartz-target) \
+               $(use_enable coverage) \
+               $(use_enable debug) \
+               $(use_enable egl) \
+               $(use_enable geoloc geolocation) \
+               $(use_enable gles2) \
+               $(use_enable gstreamer video) \
+               $(use_enable gstreamer web-audio) \
+               $(use_enable introspection) \
+               $(use_enable jit) \
+               $(use_enable libsecret credential_storage) \
+               $(use_enable opengl glx) \
+               $(use_enable spell spellcheck) \
+               $(use_enable webgl) \
+               $(use_enable webgl accelerated-compositing) \
+               $(use_enable wayland wayland-target) \
+               $(use_enable X x11-target) \
+               --with-gtk=3.0 \
+               --enable-dependency-tracking \
+               --disable-gtk-doc \
+               ${myconf}
+}
+
+src_test() {
+       # Tests expect an out-of-source build in WebKitBuild
+       ln -s . WebKitBuild || die "ln failed"
+
+       # Prevents test failures on PaX systems
+       use jit && pax-mark m $(list-paxables Programs/*[Tt]ests/*) # 
Programs/unittests/.libs/test*
+
+       unset DISPLAY
+       # Tests need virtualx, bug #294691, bug #310695
+       # Parallel tests sometimes fail
+       Xemake -j1 check
+}
+
+src_install() {
+       DOCS="ChangeLog NEWS" # other ChangeLog files handled by src_install
+
+       # https://bugs.webkit.org/show_bug.cgi?id=129242
+       MAKEOPTS="${MAKEOPTS} -j1" gnome2_src_install
+
+       newdoc Source/WebKit/gtk/ChangeLog ChangeLog.gtk
+       newdoc Source/JavaScriptCore/ChangeLog ChangeLog.JavaScriptCore
+       newdoc Source/WebCore/ChangeLog ChangeLog.WebCore
+
+       # Prevents crashes on PaX systems
+       use jit && pax-mark m "${ED}usr/bin/jsc-3"
+}

Reply via email to