[libsoup/pgriffis/pygobject-overridedir] Fix pygobject override dir on multiarch
- From: Patrick Griffis <pgriffis src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libsoup/pgriffis/pygobject-overridedir] Fix pygobject override dir on multiarch
- Date: Thu, 23 Sep 2021 19:58:57 +0000 (UTC)
commit 9dfb095c74d87cda16c8680ec16c3eda9e82dd67
Author: Patrick Griffis <pgriffis igalia com>
Date: Thu Sep 23 14:58:36 2021 -0500
Fix pygobject override dir on multiarch
libsoup/meson.build | 24 +++++++++++++++++++-----
1 file changed, 19 insertions(+), 5 deletions(-)
---
diff --git a/libsoup/meson.build b/libsoup/meson.build
index a05f5752..d0ee091a 100644
--- a/libsoup/meson.build
+++ b/libsoup/meson.build
@@ -297,17 +297,29 @@ python3 = pymod.find_installation('python3')
get_overridedir = '''
import os
import sysconfig
-libdir = sysconfig.get_config_var('LIBDIR')
-if not libdir:
- libdir = '/usr/lib'
+
try:
import gi
overridedir = gi._overridesdir
except ImportError:
purelibdir = sysconfig.get_path('purelib')
overridedir = os.path.join(purelibdir, 'gi', 'overrides')
-if overridedir.startswith(libdir): # Should always be True..
- overridedir = overridedir[len(libdir) + 1:]
+
+# We need to strip the libdir from the path so files we install
+# are in our own prefix'd libdir.
+libdir = sysconfig.get_config_var('LIBDIR')
+if not libdir:
+ libdir = '/usr/lib'
+
+libdirs = [libdir,]
+multiarch = sysconfig.get_config_var('MULTIARCH')
+if multiarch:
+ libdirs.insert(0, os.path.join(libdir, multiarch))
+
+for d in libdirs:
+ if overridedir.startswith(d):
+ overridedir = overridedir[len(d) + 1:]
+
print(overridedir)
'''
@@ -318,4 +330,6 @@ else
pygobject_override_dir = join_paths(get_option('libdir'), ret.stdout().strip())
endif
+message('Found pygobject overridedir: @0@'.format(pygobject_override_dir))
+
install_data('Soup.py', install_dir: pygobject_override_dir)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]