mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2024-11-08 07:56:16 -05:00
d13f3a033e
Fixes <https://bugs.gnu.org/35597>. * gnu/packages/gnome.scm (gnome-tweak-tool): Deprecate and rename... (gnome-tweaks): ...to this. Update to 3.28.1. [build-system]: Use meson-build-system. [arguments]: Adjust configure flags; pass glib-or-gtk? flag; remove custom phases that are now provided by the meson-build-system; add phases "wrap" and "wrap-gi-typelib". [native-inputs]: Remove meson-for-build and ninja. [home-page]: Update. [description]: Use "Tweaks" instead of "Tweak Tool". * gnu/packages/patches/gnome-tweak-tool-search-paths.patch: Rename file... * gnu/packages/patches/gnome-tweaks-search-paths.patch: ...to this. * gnu/local.mk (dist_patch_DATA): Update patch file name.
52 lines
2 KiB
Diff
52 lines
2 KiB
Diff
Gnome-tweaks does not look at GSETTINGS_SCHEMA_PATH or XDG_DATA_DIRS, it
|
|
assumes that schemas are installed in one global directory
|
|
(GSETTINGS_SCHEMA_DIR/gsettingsschemadir).
|
|
|
|
Guix/GuixSD uses a different directory for every gir package and has
|
|
packages pick-up files using XDG_DATA_DIRS.
|
|
|
|
Upstream ticket: https://bugzilla.gnome.org/show_bug.cgi?id=764537
|
|
janneke@gnu.org
|
|
|
|
--- gnome-tweak-3.18.1.orig/gtweak/gsettings.py 2015-04-08 15:21:32.000000000 +0200
|
|
+++ gnome-tweak-tool-3.18.1/gtweak/gsettings.py 2016-04-03 11:26:38.658482704 +0200
|
|
@@ -16,7 +16,8 @@
|
|
# along with gnome-tweak-tool. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
import logging
|
|
-import os.path
|
|
+import os
|
|
+import sys
|
|
import xml.dom.minidom
|
|
import gettext
|
|
|
|
@@ -31,6 +32,13 @@
|
|
class GSettingsMissingError(Exception):
|
|
pass
|
|
|
|
+def file_from_path(path, file_name):
|
|
+ for dir in path:
|
|
+ f = os.path.join(dir, file_name)
|
|
+ if os.path.exists(f):
|
|
+ return f
|
|
+ return None
|
|
+
|
|
class _GSettingsSchema:
|
|
def __init__(self, schema_name, schema_dir=None, schema_filename=None, **options):
|
|
if not schema_dir:
|
|
@@ -38,9 +46,14 @@
|
|
if not schema_filename:
|
|
schema_filename = schema_name + ".gschema.xml"
|
|
|
|
+ schema_prefix = os.path.join('glib-2.0', 'schemas')
|
|
schema_path = os.path.join(schema_dir, schema_filename)
|
|
if not os.path.exists(schema_path):
|
|
- logging.critical("Could not find schema %s" % schema_path)
|
|
+ schema_path = file_from_path(os.environ.get ('GSETTINGS_SCHEMA_PATH', '').split(os.path.pathsep), schema_filename)
|
|
+ if not (schema_path and os.path.exists(schema_path)):
|
|
+ schema_path = file_from_path(os.environ.get ('XDG_DATA_DIRS', '').split(os.path.pathsep), os.path.join(schema_prefix, schema_filename))
|
|
+ if not (schema_path and os.path.exists(schema_path)):
|
|
+ logging.critical("Could not find schema %s" % schema_filename)
|
|
assert(False)
|
|
|
|
self._schema_name = schema_name
|