2020-01-14 02:23:20 +01:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
|
|
|
|
cfg = config.programs.kitty;
|
|
|
|
|
|
|
|
eitherStrBoolInt = with types; either str (either bool int);
|
|
|
|
|
|
|
|
optionalPackage = opt:
|
|
|
|
optional (opt != null && opt.package != null) opt.package;
|
|
|
|
|
|
|
|
toKittyConfig = generators.toKeyValue {
|
|
|
|
mkKeyValue = key: value:
|
|
|
|
let
|
2022-04-08 06:36:13 +02:00
|
|
|
value' =
|
|
|
|
(if isBool value then lib.hm.booleans.yesNo else toString) value;
|
2020-01-14 02:23:20 +01:00
|
|
|
in "${key} ${value'}";
|
|
|
|
};
|
|
|
|
|
|
|
|
toKittyKeybindings = generators.toKeyValue {
|
|
|
|
mkKeyValue = key: command: "map ${key} ${command}";
|
|
|
|
};
|
|
|
|
|
2021-08-27 04:08:34 +02:00
|
|
|
toKittyEnv =
|
|
|
|
generators.toKeyValue { mkKeyValue = name: value: "env ${name}=${value}"; };
|
|
|
|
|
2023-05-12 11:20:22 +02:00
|
|
|
shellIntegrationInit = {
|
|
|
|
bash = ''
|
|
|
|
if test -n "$KITTY_INSTALLATION_DIR"; then
|
|
|
|
source "$KITTY_INSTALLATION_DIR/shell-integration/bash/kitty.bash"
|
|
|
|
fi
|
|
|
|
'';
|
|
|
|
fish = ''
|
|
|
|
if set -q KITTY_INSTALLATION_DIR
|
|
|
|
source "$KITTY_INSTALLATION_DIR/shell-integration/fish/vendor_conf.d/kitty-shell-integration.fish"
|
|
|
|
set --prepend fish_complete_path "$KITTY_INSTALLATION_DIR/shell-integration/fish/vendor_completions.d"
|
|
|
|
end
|
|
|
|
'';
|
|
|
|
zsh = ''
|
|
|
|
if test -n "$KITTY_INSTALLATION_DIR"; then
|
|
|
|
autoload -Uz -- "$KITTY_INSTALLATION_DIR"/shell-integration/zsh/kitty-integration
|
|
|
|
kitty-integration
|
|
|
|
unfunction kitty-integration
|
|
|
|
fi
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
shellIntegrationDefaultOpt = {
|
|
|
|
default = cfg.shellIntegration.mode != "disabled";
|
|
|
|
defaultText = literalExpression ''
|
|
|
|
config.programs.kitty.shellIntegration.mode != "disabled"
|
|
|
|
'';
|
|
|
|
};
|
2020-01-14 02:23:20 +01:00
|
|
|
in {
|
|
|
|
options.programs.kitty = {
|
2023-07-01 01:30:13 +02:00
|
|
|
enable = mkEnableOption (lib.mdDoc "Kitty terminal emulator");
|
2020-01-14 02:23:20 +01:00
|
|
|
|
2022-01-17 00:19:32 +01:00
|
|
|
package = mkOption {
|
|
|
|
type = types.package;
|
|
|
|
default = pkgs.kitty;
|
|
|
|
defaultText = literalExpression "pkgs.kitty";
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc ''
|
2022-01-17 00:19:32 +01:00
|
|
|
Kitty package to install.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-08-27 04:08:34 +02:00
|
|
|
darwinLaunchOptions = mkOption {
|
|
|
|
type = types.nullOr (types.listOf types.str);
|
|
|
|
default = null;
|
2023-07-01 01:30:13 +02:00
|
|
|
description =
|
|
|
|
lib.mdDoc "Command-line options to use when launched by Mac OS GUI";
|
2021-10-09 11:14:08 +02:00
|
|
|
example = literalExpression ''
|
2021-08-27 04:08:34 +02:00
|
|
|
[
|
|
|
|
"--single-instance"
|
|
|
|
"--directory=/tmp/my-dir"
|
|
|
|
"--listen-on=unix:/tmp/my-socket"
|
|
|
|
]
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2020-01-14 02:23:20 +01:00
|
|
|
settings = mkOption {
|
|
|
|
type = types.attrsOf eitherStrBoolInt;
|
|
|
|
default = { };
|
2021-10-09 11:14:08 +02:00
|
|
|
example = literalExpression ''
|
2020-01-14 02:23:20 +01:00
|
|
|
{
|
|
|
|
scrollback_lines = 10000;
|
|
|
|
enable_audio_bell = false;
|
|
|
|
update_check_interval = 0;
|
|
|
|
}
|
|
|
|
'';
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc ''
|
2020-01-14 02:23:20 +01:00
|
|
|
Configuration written to
|
2023-07-01 01:30:13 +02:00
|
|
|
{file}`$XDG_CONFIG_HOME/kitty/kitty.conf`. See
|
|
|
|
<https://sw.kovidgoyal.net/kitty/conf.html>
|
2020-01-14 02:23:20 +01:00
|
|
|
for the documentation.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2022-02-08 19:54:24 +01:00
|
|
|
theme = mkOption {
|
|
|
|
type = types.nullOr types.str;
|
|
|
|
default = null;
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc ''
|
2022-02-08 19:54:24 +01:00
|
|
|
Apply a Kitty color theme. This option takes the friendly name of
|
2023-07-01 01:30:13 +02:00
|
|
|
any theme given by the command {command}`kitty +kitten themes`.
|
|
|
|
See <https://github.com/kovidgoyal/kitty-themes>
|
2022-02-08 19:54:24 +01:00
|
|
|
for more details.
|
|
|
|
'';
|
|
|
|
example = "Space Gray Eighties";
|
|
|
|
};
|
|
|
|
|
2020-01-14 02:23:20 +01:00
|
|
|
font = mkOption {
|
|
|
|
type = types.nullOr hm.types.fontType;
|
|
|
|
default = null;
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc "The font to use.";
|
2020-01-14 02:23:20 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
keybindings = mkOption {
|
|
|
|
type = types.attrsOf types.str;
|
|
|
|
default = { };
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc "Mapping of keybindings to actions.";
|
2021-10-09 11:14:08 +02:00
|
|
|
example = literalExpression ''
|
2020-01-14 02:23:20 +01:00
|
|
|
{
|
|
|
|
"ctrl+c" = "copy_or_interrupt";
|
|
|
|
"ctrl+f>2" = "set_font_size 20";
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-08-27 04:08:34 +02:00
|
|
|
environment = mkOption {
|
|
|
|
type = types.attrsOf types.str;
|
|
|
|
default = { };
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc "Environment variables to set or override.";
|
2021-10-09 11:14:08 +02:00
|
|
|
example = literalExpression ''
|
2021-08-27 04:08:34 +02:00
|
|
|
{
|
|
|
|
"LS_COLORS" = "1";
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2023-05-12 11:20:22 +02:00
|
|
|
shellIntegration = {
|
|
|
|
mode = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = "enabled";
|
2023-05-12 23:19:59 +02:00
|
|
|
example = "no-cursor";
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc ''
|
2023-05-12 11:20:22 +02:00
|
|
|
Set the mode of the shell integration. This accepts the same options
|
2023-07-01 01:30:13 +02:00
|
|
|
as the `shell_integration` option of Kitty. Note that
|
|
|
|
`no-rc` is always implied. See
|
|
|
|
<https://sw.kovidgoyal.net/kitty/shell-integration>
|
2023-05-12 11:20:22 +02:00
|
|
|
for more details.
|
|
|
|
'';
|
|
|
|
};
|
2023-05-12 23:19:59 +02:00
|
|
|
|
2023-07-01 01:30:13 +02:00
|
|
|
enableBashIntegration =
|
|
|
|
mkEnableOption (lib.mdDoc "Kitty Bash integration")
|
2023-05-12 11:20:22 +02:00
|
|
|
// shellIntegrationDefaultOpt;
|
2023-05-12 23:19:59 +02:00
|
|
|
|
2023-07-01 01:30:13 +02:00
|
|
|
enableFishIntegration =
|
|
|
|
mkEnableOption (lib.mdDoc "Kitty fish integration")
|
2023-05-12 11:20:22 +02:00
|
|
|
// shellIntegrationDefaultOpt;
|
2023-05-12 23:19:59 +02:00
|
|
|
|
2023-07-01 01:30:13 +02:00
|
|
|
enableZshIntegration =
|
|
|
|
mkEnableOption (lib.mdDoc "Kitty Z Shell integration")
|
2023-05-12 11:20:22 +02:00
|
|
|
// shellIntegrationDefaultOpt;
|
|
|
|
};
|
|
|
|
|
2020-01-14 02:23:20 +01:00
|
|
|
extraConfig = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.lines;
|
2023-07-01 01:30:13 +02:00
|
|
|
description = lib.mdDoc "Additional configuration to add.";
|
2020-01-14 02:23:20 +01:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2022-01-17 00:19:32 +01:00
|
|
|
home.packages = [ cfg.package ] ++ optionalPackage cfg.font;
|
2020-01-14 02:23:20 +01:00
|
|
|
|
2021-09-05 19:19:37 +02:00
|
|
|
xdg.configFile."kitty/kitty.conf" = {
|
|
|
|
text = ''
|
|
|
|
# Generated by Home Manager.
|
|
|
|
# See https://sw.kovidgoyal.net/kitty/conf.html
|
2022-08-21 01:04:23 +02:00
|
|
|
'' + concatStringsSep "\n" ([
|
2020-01-14 02:23:20 +01:00
|
|
|
|
2022-08-21 01:04:23 +02:00
|
|
|
(optionalString (cfg.font != null) ''
|
2021-09-05 19:19:37 +02:00
|
|
|
font_family ${cfg.font.name}
|
|
|
|
${optionalString (cfg.font.size != null)
|
|
|
|
"font_size ${toString cfg.font.size}"}
|
2022-08-21 01:04:23 +02:00
|
|
|
'')
|
2020-01-14 02:23:20 +01:00
|
|
|
|
2022-08-21 01:04:23 +02:00
|
|
|
(optionalString (cfg.theme != null) ''
|
2023-03-13 14:37:26 +01:00
|
|
|
include ${pkgs.kitty-themes}/share/kitty-themes/${
|
2023-05-14 12:05:10 +02:00
|
|
|
let
|
|
|
|
matching = filter (x: x.name == cfg.theme) (builtins.fromJSON
|
|
|
|
(builtins.readFile
|
|
|
|
"${pkgs.kitty-themes}/share/kitty-themes/themes.json"));
|
|
|
|
in throwIf (length matching == 0)
|
|
|
|
"kitty-themes does not contain a theme named ${cfg.theme}"
|
|
|
|
(head matching).file
|
2022-02-08 19:54:24 +01:00
|
|
|
}
|
2022-08-21 01:04:23 +02:00
|
|
|
'')
|
2023-05-12 11:20:22 +02:00
|
|
|
''
|
|
|
|
# Shell integration is sourced and configured manually
|
|
|
|
shell_integration no-rc ${cfg.shellIntegration.mode}
|
|
|
|
''
|
2022-08-21 01:04:23 +02:00
|
|
|
(toKittyConfig cfg.settings)
|
|
|
|
(toKittyKeybindings cfg.keybindings)
|
|
|
|
(toKittyEnv cfg.environment)
|
|
|
|
cfg.extraConfig
|
|
|
|
]);
|
2021-10-04 18:20:04 +02:00
|
|
|
} // optionalAttrs pkgs.stdenv.hostPlatform.isLinux {
|
|
|
|
onChange = ''
|
|
|
|
${pkgs.procps}/bin/pkill -USR1 -u $USER kitty || true
|
|
|
|
'';
|
2021-09-05 19:19:37 +02:00
|
|
|
};
|
2021-08-27 04:08:34 +02:00
|
|
|
|
2022-11-27 01:16:33 +01:00
|
|
|
xdg.configFile."kitty/macos-launch-services-cmdline" = mkIf
|
|
|
|
(cfg.darwinLaunchOptions != null && pkgs.stdenv.hostPlatform.isDarwin) {
|
2021-08-27 04:08:34 +02:00
|
|
|
text = concatStringsSep " " cfg.darwinLaunchOptions;
|
|
|
|
};
|
2023-05-12 23:19:59 +02:00
|
|
|
|
2023-05-12 11:20:22 +02:00
|
|
|
programs.bash.initExtra =
|
|
|
|
mkIf cfg.shellIntegration.enableBashIntegration shellIntegrationInit.bash;
|
2023-05-12 23:19:59 +02:00
|
|
|
|
2023-05-12 11:20:22 +02:00
|
|
|
programs.fish.interactiveShellInit =
|
|
|
|
mkIf cfg.shellIntegration.enableFishIntegration shellIntegrationInit.fish;
|
2023-05-12 23:19:59 +02:00
|
|
|
|
2023-05-12 11:20:22 +02:00
|
|
|
programs.zsh.initExtra =
|
|
|
|
mkIf cfg.shellIntegration.enableZshIntegration shellIntegrationInit.zsh;
|
2020-01-14 02:23:20 +01:00
|
|
|
};
|
|
|
|
}
|