[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables.
From: |
Ricardo Wurmus |
Subject: |
Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables. |
Date: |
Thu, 03 Dec 2015 22:59:09 +0100 |
User-agent: |
mu4e 0.9.13; emacs 24.5.1 |
Andy Wingo <address@hidden> writes:
> On Thu 03 Dec 2015 07:52, Ricardo Wurmus <address@hidden> writes:
>
>> From b8120ae8e21e234ffd0eb9f5de1d7809a0860c45 Mon Sep 17 00:00:00 2001
>> From: Ricardo Wurmus <address@hidden>
>> Date: Thu, 3 Dec 2015 08:32:06 +0100
>> Subject: [PATCH 2/3] gnu: gtk+: Add patch to support GUIX_GTK3_PATH.
>>
>> * gnu/packages/patches/gtk3-respect-GUIX_GTK3_PATH: New file.
>> * gnu-system.am (dist_patch_DATA): Add it.
>> * gnu/packages/gtk.scm (gtk+) [source]: Add patch.
>> [native-search-paths]: Add search path for GUIX_GTK3_PATH.
>> ---
>> gnu-system.am | 1 +
>> gnu/packages/gtk.scm | 9 +++++++--
>> 2 files changed, 8 insertions(+), 2 deletions(-)
>
> Missing the gtk3 patch?
Indeed. Attached is an updated patch 2.
>From 11f502281064525a067c1453cd2b7b663bf6c3bb Mon Sep 17 00:00:00 2001
From: Ricardo Wurmus <address@hidden>
Date: Thu, 3 Dec 2015 08:32:06 +0100
Subject: [PATCH 2/3] gnu: gtk+: Add patch to support GUIX_GTK3_PATH.
* gnu/packages/patches/gtk3-respect-GUIX_GTK3_PATH: New file.
* gnu-system.am (dist_patch_DATA): Add it.
* gnu/packages/gtk.scm (gtk+) [source]: Add patch.
[native-search-paths]: Add search path for GUIX_GTK3_PATH.
---
gnu-system.am | 1 +
gnu/packages/gtk.scm | 9 +++--
.../patches/gtk3-respect-GUIX_GTK3_PATH.patch | 38 ++++++++++++++++++++++
3 files changed, 46 insertions(+), 2 deletions(-)
create mode 100644 gnu/packages/patches/gtk3-respect-GUIX_GTK3_PATH.patch
diff --git a/gnu-system.am b/gnu-system.am
index 677ade5..580bd66 100644
--- a/gnu-system.am
+++ b/gnu-system.am
@@ -506,6 +506,7 @@ dist_patch_DATA =
\
gnu/packages/patches/guile-relocatable.patch \
gnu/packages/patches/guile-rsvg-pkgconfig.patch \
gnu/packages/patches/gtk2-respect-GUIX_GTK2_PATH.patch \
+ gnu/packages/patches/gtk3-respect-GUIX_GTK3_PATH.patch \
gnu/packages/patches/gtkglext-disable-disable-deprecated.patch \
gnu/packages/patches/hop-bigloo-4.0b.patch \
gnu/packages/patches/hop-linker-flags.patch \
diff --git a/gnu/packages/gtk.scm b/gnu/packages/gtk.scm
index 33feb2a..a4dd2d4 100644
--- a/gnu/packages/gtk.scm
+++ b/gnu/packages/gtk.scm
@@ -583,7 +583,8 @@ application suites.")
name "-" version ".tar.xz"))
(sha256
(base32
- "0lp1hn0qydxx03bianzzr0a4maqzsvylrkzr7c3p0050qihwbgjx"))))
+ "0lp1hn0qydxx03bianzzr0a4maqzsvylrkzr7c3p0050qihwbgjx"))
+ (patches (list (search-patch
"gtk3-respect-GUIX_GTK3_PATH.patch")))))
(propagated-inputs
`(("at-spi2-atk" ,at-spi2-atk)
("atk" ,atk)
@@ -642,7 +643,11 @@ application suites.")
(loaders.cache (find-files librsvg "^loaders\\.cache$")))
(wrap-program prog
`("GDK_PIXBUF_MODULE_FILE" = ,loaders.cache))))
- %standard-phases))))))
+ %standard-phases))))
+ (native-search-paths
+ (list (search-path-specification
+ (variable "GUIX_GTK3_PATH")
+ (files '("lib/gtk-3.0")))))))
;;;
;;; Guile bindings.
diff --git a/gnu/packages/patches/gtk3-respect-GUIX_GTK3_PATH.patch
b/gnu/packages/patches/gtk3-respect-GUIX_GTK3_PATH.patch
new file mode 100644
index 0000000..66fd2fd
--- /dev/null
+++ b/gnu/packages/patches/gtk3-respect-GUIX_GTK3_PATH.patch
@@ -0,0 +1,38 @@
+This patch makes GTK+ look for additional modules in a list of directories
+specified by the environment variable "GUIX_GTK3_PATH". This can be used
+instead of "GTK_PATH" to make GTK+ find modules that are incompatible with
+other major versions of GTK+.
+
+--- a/gtk/gtkmodules.c 2015-09-20 20:09:05.060590217 +0200
++++ b/gtk/gtkmodules.c 2015-09-20 20:10:33.423124833 +0200
+@@ -52,6 +52,7 @@
+ get_module_path (void)
+ {
+ const gchar *module_path_env;
++ const gchar *module_guix_gtk3_path_env;
+ const gchar *exe_prefix;
+ gchar *module_path;
+ gchar *default_dir;
+@@ -61,6 +62,7 @@
+ return result;
+
+ module_path_env = g_getenv ("GTK_PATH");
++ module_guix_gtk3_path_env = g_getenv ("GUIX_GTK3_PATH");
+ exe_prefix = g_getenv ("GTK_EXE_PREFIX");
+
+ if (exe_prefix)
+@@ -68,7 +70,13 @@
+ else
+ default_dir = g_build_filename (_gtk_get_libdir (), "gtk-3.0", NULL);
+
+- if (module_path_env)
++ if (module_guix_gtk3_path_env && module_path_env)
++ module_path = g_build_path (G_SEARCHPATH_SEPARATOR_S,
++ module_guix_gtk3_path_env, module_path_env,
default_dir, NULL);
++ else if (module_guix_gtk3_path_env)
++ module_path = g_build_path (G_SEARCHPATH_SEPARATOR_S,
++ module_guix_gtk3_path_env, default_dir, NULL);
++ else if (module_path_env)
+ module_path = g_build_path (G_SEARCHPATH_SEPARATOR_S,
+ module_path_env, default_dir, NULL);
+ else
--
2.5.0
> Only question for me would be, would these patches with s/GUIX_// be
> accepted upstream? They should be submitted at least.
I haven’t tried and I don’t really know how to present it. For
FHS-abiding distributions this is not a problem usually, because
GTK_EXE_PREFIX could be used instead. We cannot set GTK_EXE_PREFIX to
~/.guix-profile/lib because that would make it necessary for ibus (for
example) to propagate the gtk+ package, which is unacceptable for us.
I think FHS people simply have no need for it.
~~ Ricardo
- [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Ricardo Wurmus, 2015/12/03
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Andy Wingo, 2015/12/03
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables.,
Ricardo Wurmus <=
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Andy Wingo, 2015/12/04
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Ludovic Courtès, 2015/12/04
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Ricardo Wurmus, 2015/12/08
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Ludovic Courtès, 2015/12/09
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Ricardo Wurmus, 2015/12/25
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Mark H Weaver, 2015/12/28
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Mark H Weaver, 2015/12/29
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Ludovic Courtès, 2015/12/30
- Re: [PATCH] gtk+: Support GUIX_GTK{2,3}_PATH variables., Ricardo Wurmus, 2015/12/31