diff options
author | worldofpeace <worldofpeace@protonmail.ch> | 2020-04-24 15:49:01 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-24 15:49:01 -0400 |
commit | 78a9359b2aae2bdf407ae4b1085fe84329c3cd5d (patch) | |
tree | 805e2feeb991d3c2aff72e41907906260f1b0039 /nixos | |
parent | a3467dfa824de34d56c6305c7b15911fb9fd4f32 (diff) | |
parent | 5b7ffe61403bdbc955e02f40ad0270f337a56475 (diff) | |
download | nixpkgs-78a9359b2aae2bdf407ae4b1085fe84329c3cd5d.tar nixpkgs-78a9359b2aae2bdf407ae4b1085fe84329c3cd5d.tar.gz nixpkgs-78a9359b2aae2bdf407ae4b1085fe84329c3cd5d.tar.bz2 nixpkgs-78a9359b2aae2bdf407ae4b1085fe84329c3cd5d.tar.lz nixpkgs-78a9359b2aae2bdf407ae4b1085fe84329c3cd5d.tar.xz nixpkgs-78a9359b2aae2bdf407ae4b1085fe84329c3cd5d.tar.zst nixpkgs-78a9359b2aae2bdf407ae4b1085fe84329c3cd5d.zip |
Merge pull request #85892 from symphorien/ibus-db
ibus: fix dconf db installation
Diffstat (limited to 'nixos')
-rw-r--r-- | nixos/modules/i18n/input-method/ibus.nix | 2 | ||||
-rw-r--r-- | nixos/modules/programs/dconf.nix | 35 | ||||
-rw-r--r-- | nixos/tests/installed-tests/ibus.nix | 14 |
3 files changed, 31 insertions, 20 deletions
diff --git a/nixos/modules/i18n/input-method/ibus.nix b/nixos/modules/i18n/input-method/ibus.nix index b4746b21b65..cf24ecf5863 100644 --- a/nixos/modules/i18n/input-method/ibus.nix +++ b/nixos/modules/i18n/input-method/ibus.nix @@ -64,7 +64,7 @@ in # Without dconf enabled it is impossible to use IBus programs.dconf.enable = true; - programs.dconf.profiles.ibus = "${ibusPackage}/etc/dconf/profile/ibus"; + programs.dconf.packages = [ ibusPackage ]; services.dbus.packages = [ ibusAutostart diff --git a/nixos/modules/programs/dconf.nix b/nixos/modules/programs/dconf.nix index 6702e8efd1c..30fbd72a9ab 100644 --- a/nixos/modules/programs/dconf.nix +++ b/nixos/modules/programs/dconf.nix @@ -4,13 +4,24 @@ with lib; let cfg = config.programs.dconf; - - mkDconfProfile = name: path: - { - name = "dconf/profile/${name}"; - value.source = path; - }; - + cfgDir = pkgs.symlinkJoin { + name = "dconf-system-config"; + paths = map (x: "${x}/etc/dconf") cfg.packages; + postBuild = '' + mkdir -p $out/profile + mkdir -p $out/db + '' + ( + concatStringsSep "\n" ( + mapAttrsToList ( + name: path: '' + ln -s ${path} $out/profile/${name} + '' + ) cfg.profiles + ) + ) + '' + ${pkgs.dconf}/bin/dconf update $out/db + ''; + }; in { ###### interface @@ -22,18 +33,22 @@ in profiles = mkOption { type = types.attrsOf types.path; default = {}; - description = "Set of dconf profile files."; + description = "Set of dconf profile files, installed at <filename>/etc/dconf/profiles/<replaceable>name</replaceable></filename>."; internal = true; }; + packages = mkOption { + type = types.listOf types.package; + default = []; + description = "A list of packages which provide dconf profiles and databases in <filename>/etc/dconf</filename>."; + }; }; }; ###### implementation config = mkIf (cfg.profiles != {} || cfg.enable) { - environment.etc = optionalAttrs (cfg.profiles != {}) - (mapAttrs' mkDconfProfile cfg.profiles); + environment.etc.dconf.source = mkIf (cfg.profiles != {} || cfg.packages != []) cfgDir; services.dbus.packages = [ pkgs.dconf ]; diff --git a/nixos/tests/installed-tests/ibus.nix b/nixos/tests/installed-tests/ibus.nix index af54b612b50..a4bc2a7d7de 100644 --- a/nixos/tests/installed-tests/ibus.nix +++ b/nixos/tests/installed-tests/ibus.nix @@ -5,16 +5,12 @@ makeInstalledTest { testConfig = { i18n.inputMethod.enabled = "ibus"; + systemd.user.services.ibus-daemon = { + serviceConfig.ExecStart = "${pkgs.ibus}/bin/ibus-daemon --xim --verbose"; + wantedBy = [ "graphical-session.target" ]; + partOf = [ "graphical-session.target" ]; + }; }; - preTestScript = '' - # ibus has ibus-desktop-testing-runner but it tries to manage desktop session so we just spawn ibus-daemon ourselves - machine.succeed("ibus-daemon --daemonize --verbose") - ''; - withX11 = true; - - # TODO: ibus-daemon is currently crashing or something - # maybe make ibus systemd service that auto-restarts? - meta.broken = true; } |