mirror of
https://github.com/nix-community/home-manager.git
synced 2025-11-08 11:36:05 +01:00
zed-editor: option to generate immutable settings
This commit is contained in:
parent
80437a57ca
commit
5c54b182ab
6 changed files with 220 additions and 15 deletions
|
|
@ -54,6 +54,33 @@ in
|
|||
description = "Extra packages available to Zed.";
|
||||
};
|
||||
|
||||
mutableUserSettings = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
example = false;
|
||||
description = ''
|
||||
Whether user settings (settings.json) can be updated by zed.
|
||||
'';
|
||||
};
|
||||
|
||||
mutableUserKeymaps = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
example = false;
|
||||
description = ''
|
||||
Whether user keymaps (keymap.json) can be updated by zed.
|
||||
'';
|
||||
};
|
||||
|
||||
mutableUserTasks = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
example = false;
|
||||
description = ''
|
||||
Whether user tasks (tasks.json) can be updated by zed.
|
||||
'';
|
||||
};
|
||||
|
||||
userSettings = mkOption {
|
||||
type = jsonFormat.type;
|
||||
default = { };
|
||||
|
|
@ -191,14 +218,14 @@ in
|
|||
);
|
||||
|
||||
home.activation = mkMerge [
|
||||
(mkIf (mergedSettings != { }) {
|
||||
(mkIf (cfg.mutableUserSettings && mergedSettings != { }) {
|
||||
zedSettingsActivation = lib.hm.dag.entryAfter [ "linkGeneration" ] (
|
||||
impureConfigMerger "{}" "$dynamic * $static" "${config.xdg.configHome}/zed/settings.json" (
|
||||
jsonFormat.generate "zed-user-settings" mergedSettings
|
||||
)
|
||||
);
|
||||
})
|
||||
(mkIf (cfg.userKeymaps != [ ]) {
|
||||
(mkIf (cfg.mutableUserKeymaps && cfg.userKeymaps != [ ]) {
|
||||
zedKeymapActivation = lib.hm.dag.entryAfter [ "linkGeneration" ] (
|
||||
impureConfigMerger "[]"
|
||||
"$dynamic + $static | group_by(.context) | map(reduce .[] as $item ({}; . * $item))"
|
||||
|
|
@ -206,7 +233,7 @@ in
|
|||
(jsonFormat.generate "zed-user-keymaps" cfg.userKeymaps)
|
||||
);
|
||||
})
|
||||
(mkIf (cfg.userTasks != [ ]) {
|
||||
(mkIf (cfg.mutableUserTasks && cfg.userTasks != [ ]) {
|
||||
zedTasksActivation = lib.hm.dag.entryAfter [ "linkGeneration" ] (
|
||||
impureConfigMerger "[]"
|
||||
"$dynamic + $static | group_by(.label) | map(reduce .[] as $item ({}; . * $item))"
|
||||
|
|
@ -216,18 +243,29 @@ in
|
|||
})
|
||||
];
|
||||
|
||||
xdg.configFile = lib.mapAttrs' (
|
||||
n: v:
|
||||
lib.nameValuePair "zed/themes/${n}.json" {
|
||||
source =
|
||||
if lib.isString v then
|
||||
pkgs.writeText "zed-theme-${n}" v
|
||||
else if builtins.isPath v || lib.isStorePath v then
|
||||
v
|
||||
else
|
||||
jsonFormat.generate "zed-theme-${n}" v;
|
||||
}
|
||||
) cfg.themes;
|
||||
xdg.configFile = mkMerge [
|
||||
(lib.mapAttrs' (
|
||||
n: v:
|
||||
lib.nameValuePair "zed/themes/${n}.json" {
|
||||
source =
|
||||
if lib.isString v then
|
||||
pkgs.writeText "zed-theme-${n}" v
|
||||
else if builtins.isPath v || lib.isStorePath v then
|
||||
v
|
||||
else
|
||||
jsonFormat.generate "zed-theme-${n}" v;
|
||||
}
|
||||
) cfg.themes)
|
||||
(mkIf (!cfg.mutableUserSettings && mergedSettings != { }) {
|
||||
"zed/settings.json".source = jsonFormat.generate "zed-user-settings" mergedSettings;
|
||||
})
|
||||
(mkIf (!cfg.mutableUserKeymaps && cfg.userKeymaps != { }) {
|
||||
"zed/keymap.json".source = jsonFormat.generate "zed-user-keymaps" cfg.userKeymaps;
|
||||
})
|
||||
(mkIf (!cfg.mutableUserTasks && cfg.userTasks != [ ]) {
|
||||
"zed/tasks.json".source = jsonFormat.generate "zed-user-tasks" cfg.userTasks;
|
||||
})
|
||||
];
|
||||
|
||||
assertions = [
|
||||
{
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue