From f5f64ac022ed379442286a4e81a2a7cdc552cb28 Mon Sep 17 00:00:00 2001 From: ThinkChaos Date: Wed, 28 Jun 2023 05:12:58 -0400 Subject: [PATCH] zsh: allow setting custom syntax highlighting styles (#4122) * zsh: allow setting custom syntax highlighting styles Custom styles allow overriding the default colors. Example: ```nix zsh.syntaxHighlighting.styles.comment = "fg=#6c6c6c"; ``` See https://github.com/zsh-users/zsh-syntax-highlighting/blob/master/docs/highlighters.md * zsh: allow configuring syntax-highlighting package --- modules/programs/zsh.nix | 40 ++++++++++++++++--- tests/modules/programs/zsh/default.nix | 1 + .../programs/zsh/syntax-highlighting.nix | 23 +++++++++++ 3 files changed, 58 insertions(+), 6 deletions(-) create mode 100644 tests/modules/programs/zsh/syntax-highlighting.nix diff --git a/modules/programs/zsh.nix b/modules/programs/zsh.nix index b7ab7615..34df1a76 100644 --- a/modules/programs/zsh.nix +++ b/modules/programs/zsh.nix @@ -208,9 +208,30 @@ let }; }; + syntaxHighlightingModule = types.submodule { + options = { + enable = mkEnableOption "zsh syntax highlighting"; + + package = mkPackageOption pkgs "zsh-syntax-highlighting" { }; + + styles = mkOption { + type = types.attrsOf types.str; + default = {}; + description = '' + Custom styles for syntax highlighting. + See each highlighter's options: + ''; + }; + }; + }; + in { + imports = [ + (mkRenamedOptionModule [ "programs" "zsh" "enableSyntaxHighlighting" ] [ "programs" "zsh" "syntaxHighlighting" "enable" ]) + ]; + options = { programs.zsh = { enable = mkEnableOption "Z shell (Zsh)"; @@ -312,9 +333,10 @@ in description = "Enable zsh autosuggestions"; }; - enableSyntaxHighlighting = mkOption { - default = false; - description = "Enable zsh syntax highlighting"; + syntaxHighlighting = mkOption { + type = syntaxHighlightingModule; + default = {}; + description = "Options related to zsh-syntax-highlighting."; }; historySubstringSearch = mkOption { @@ -584,11 +606,17 @@ in ${dirHashesStr} '') - (optionalString cfg.enableSyntaxHighlighting + (optionalString cfg.syntaxHighlighting.enable # Load zsh-syntax-highlighting after all custom widgets have been created # https://github.com/zsh-users/zsh-syntax-highlighting#faq - "source ${pkgs.zsh-syntax-highlighting}/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh" - ) + '' + source ${cfg.syntaxHighlighting.package}/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh + ${lib.concatStringsSep "\n" ( + lib.mapAttrsToList + (name: value: "ZSH_HIGHLIGHT_STYLES[${lib.escapeShellArg name}]=${lib.escapeShellArg value}") + cfg.syntaxHighlighting.styles + )} + '') (optionalString (cfg.historySubstringSearch.enable or false) # Load zsh-history-substring-search after zsh-syntax-highlighting diff --git a/tests/modules/programs/zsh/default.nix b/tests/modules/programs/zsh/default.nix index b9dc1b8c..fcfb642f 100644 --- a/tests/modules/programs/zsh/default.nix +++ b/tests/modules/programs/zsh/default.nix @@ -7,4 +7,5 @@ zsh-history-ignore-pattern = ./history-ignore-pattern.nix; zsh-history-substring-search = ./history-substring-search.nix; zsh-prezto = ./prezto.nix; + zsh-syntax-highlighting = ./syntax-highlighting.nix; } diff --git a/tests/modules/programs/zsh/syntax-highlighting.nix b/tests/modules/programs/zsh/syntax-highlighting.nix new file mode 100644 index 00000000..be2ad37e --- /dev/null +++ b/tests/modules/programs/zsh/syntax-highlighting.nix @@ -0,0 +1,23 @@ +{ config, lib, pkgs, ... }: + +with lib; + +{ + config = { + programs.zsh = { + enable = true; + syntaxHighlighting = { + enable = true; + package = pkgs.hello; + styles.comment = "fg=#6c6c6c"; + }; + }; + + test.stubs.zsh = { }; + + nmt.script = '' + assertFileContains home-files/.zshrc "source ${pkgs.hello}/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh" + assertFileContains home-files/.zshrc "ZSH_HIGHLIGHT_STYLES['comment']='fg=#6c6c6c'" + ''; + }; +}