powerline-go: add support for -modules-right
Add modulesRight setting to instruct powerline-go to configure right side prompt. Use eval mode when this setting is set.
This commit is contained in:
parent
fbb80207f3
commit
f46972e466
|
@ -21,6 +21,13 @@ let
|
||||||
modulesArgument = optionalString (cfg.modules != null)
|
modulesArgument = optionalString (cfg.modules != null)
|
||||||
" -modules ${valueToString cfg.modules}";
|
" -modules ${valueToString cfg.modules}";
|
||||||
|
|
||||||
|
modulesRightArgument = optionalString (cfg.modulesRight != null)
|
||||||
|
" -modules-right ${valueToString cfg.modulesRight}";
|
||||||
|
|
||||||
|
evalMode = cfg.modulesRight != null;
|
||||||
|
|
||||||
|
evalArgument = optionalString (evalMode) " -eval";
|
||||||
|
|
||||||
newlineArgument = optionalString cfg.newline " -newline";
|
newlineArgument = optionalString cfg.newline " -newline";
|
||||||
|
|
||||||
pathAliasesArgument = optionalString (cfg.pathAliases != null)
|
pathAliasesArgument = optionalString (cfg.pathAliases != null)
|
||||||
|
@ -34,7 +41,7 @@ let
|
||||||
(mapAttrsToList otherSettingPairArgument cfg.settings));
|
(mapAttrsToList otherSettingPairArgument cfg.settings));
|
||||||
|
|
||||||
commandLineArguments = ''
|
commandLineArguments = ''
|
||||||
${modulesArgument} ${newlineArgument} ${pathAliasesArgument} ${otherSettingsArgument}
|
${evalArgument}${modulesArgument}${modulesRightArgument}${newlineArgument}${pathAliasesArgument}${otherSettingsArgument}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
in {
|
in {
|
||||||
|
@ -56,6 +63,18 @@ in {
|
||||||
example = [ "host" "ssh" "cwd" "gitlite" "jobs" "exit" ];
|
example = [ "host" "ssh" "cwd" "gitlite" "jobs" "exit" ];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
modulesRight = mkOption {
|
||||||
|
default = null;
|
||||||
|
type = types.nullOr (types.listOf types.str);
|
||||||
|
description = ''
|
||||||
|
List of module names to load to be displayed on the right side.
|
||||||
|
Currently not supported by bash. Specifying a value for this
|
||||||
|
option will force powerline-go to use the eval format to set
|
||||||
|
the prompt.
|
||||||
|
'';
|
||||||
|
example = [ "host" "venv" "git" ];
|
||||||
|
};
|
||||||
|
|
||||||
newline = mkOption {
|
newline = mkOption {
|
||||||
default = false;
|
default = false;
|
||||||
type = types.bool;
|
type = types.bool;
|
||||||
|
@ -111,7 +130,9 @@ in {
|
||||||
mkIf (cfg.enable && config.programs.bash.enable) ''
|
mkIf (cfg.enable && config.programs.bash.enable) ''
|
||||||
function _update_ps1() {
|
function _update_ps1() {
|
||||||
local old_exit_status=$?
|
local old_exit_status=$?
|
||||||
PS1="$(${pkgs.powerline-go}/bin/powerline-go -error $old_exit_status ${commandLineArguments})"
|
${
|
||||||
|
if evalMode then "eval " else "PS1="
|
||||||
|
}"$(${pkgs.powerline-go}/bin/powerline-go -error $old_exit_status -shell bash${commandLineArguments})"
|
||||||
${cfg.extraUpdatePS1}
|
${cfg.extraUpdatePS1}
|
||||||
return $old_exit_status
|
return $old_exit_status
|
||||||
}
|
}
|
||||||
|
@ -123,7 +144,9 @@ in {
|
||||||
|
|
||||||
programs.zsh.initExtra = mkIf (cfg.enable && config.programs.zsh.enable) ''
|
programs.zsh.initExtra = mkIf (cfg.enable && config.programs.zsh.enable) ''
|
||||||
function powerline_precmd() {
|
function powerline_precmd() {
|
||||||
PS1="$(${pkgs.powerline-go}/bin/powerline-go -error $? -shell zsh ${commandLineArguments})"
|
${
|
||||||
|
if evalMode then "eval " else "PS1="
|
||||||
|
}"$(${pkgs.powerline-go}/bin/powerline-go -error $? -shell zsh${commandLineArguments})"
|
||||||
${cfg.extraUpdatePS1}
|
${cfg.extraUpdatePS1}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,10 @@ with lib;
|
||||||
assertFileExists home-files/.bashrc
|
assertFileExists home-files/.bashrc
|
||||||
assertFileContains \
|
assertFileContains \
|
||||||
home-files/.bashrc \
|
home-files/.bashrc \
|
||||||
'/bin/powerline-go -error $old_exit_status -modules nix-shell -newline -path-aliases \~/project/foo=prj-foo -ignore-repos /home/me/project1,/home/me/project2'
|
'PS1='
|
||||||
|
assertFileContains \
|
||||||
|
home-files/.bashrc \
|
||||||
|
'/bin/powerline-go -error $old_exit_status -shell bash -modules nix-shell -newline -path-aliases \~/project/foo=prj-foo -ignore-repos /home/me/project1,/home/me/project2'
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
34
tests/modules/programs/powerline-go/bashmodulesright.nix
Normal file
34
tests/modules/programs/powerline-go/bashmodulesright.nix
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
|
||||||
|
{
|
||||||
|
config = {
|
||||||
|
programs = {
|
||||||
|
bash.enable = true;
|
||||||
|
|
||||||
|
powerline-go = {
|
||||||
|
enable = true;
|
||||||
|
newline = true;
|
||||||
|
modules = [ "nix-shell" ];
|
||||||
|
modulesRight = [ "git" ];
|
||||||
|
pathAliases = { "\\~/project/foo" = "prj-foo"; };
|
||||||
|
settings = {
|
||||||
|
ignore-repos = [ "/home/me/project1" "/home/me/project2" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
test.stubs.powerline-go = { };
|
||||||
|
|
||||||
|
nmt.script = ''
|
||||||
|
assertFileExists home-files/.bashrc
|
||||||
|
assertFileContains \
|
||||||
|
home-files/.bashrc \
|
||||||
|
'eval'
|
||||||
|
assertFileContains \
|
||||||
|
home-files/.bashrc \
|
||||||
|
'/bin/powerline-go -error $old_exit_status -shell bash -eval -modules nix-shell -modules-right git -newline -path-aliases \~/project/foo=prj-foo -ignore-repos /home/me/project1,/home/me/project2'
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
|
@ -2,4 +2,6 @@
|
||||||
powerline-go-bash = ./bash.nix;
|
powerline-go-bash = ./bash.nix;
|
||||||
powerline-go-zsh = ./zsh.nix;
|
powerline-go-zsh = ./zsh.nix;
|
||||||
powerline-go-fish = ./fish.nix;
|
powerline-go-fish = ./fish.nix;
|
||||||
|
powerline-go-bashmodulesright = ./bashmodulesright.nix;
|
||||||
|
powerline-go-zshmodulesright = ./zshmodulesright.nix;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,9 @@ with lib;
|
||||||
|
|
||||||
nmt.script = ''
|
nmt.script = ''
|
||||||
assertFileExists home-files/.zshrc
|
assertFileExists home-files/.zshrc
|
||||||
|
assertFileContains \
|
||||||
|
home-files/.zshrc \
|
||||||
|
'PS1='
|
||||||
assertFileContains \
|
assertFileContains \
|
||||||
home-files/.zshrc \
|
home-files/.zshrc \
|
||||||
'/bin/powerline-go -error $? -shell zsh -modules nix-shell -newline -path-aliases \~/project/foo=prj-foo -ignore-repos /home/me/project1,/home/me/project2'
|
'/bin/powerline-go -error $? -shell zsh -modules nix-shell -newline -path-aliases \~/project/foo=prj-foo -ignore-repos /home/me/project1,/home/me/project2'
|
||||||
|
|
37
tests/modules/programs/powerline-go/zshmodulesright.nix
Normal file
37
tests/modules/programs/powerline-go/zshmodulesright.nix
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
|
||||||
|
{
|
||||||
|
config = {
|
||||||
|
programs = {
|
||||||
|
zsh.enable = true;
|
||||||
|
|
||||||
|
powerline-go = {
|
||||||
|
enable = true;
|
||||||
|
newline = true;
|
||||||
|
modules = [ "nix-shell" ];
|
||||||
|
modulesRight = [ "git" ];
|
||||||
|
pathAliases = { "\\~/project/foo" = "prj-foo"; };
|
||||||
|
settings = {
|
||||||
|
ignore-repos = [ "/home/me/project1" "/home/me/project2" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
test.stubs = {
|
||||||
|
powerline-go = { };
|
||||||
|
zsh = { };
|
||||||
|
};
|
||||||
|
|
||||||
|
nmt.script = ''
|
||||||
|
assertFileExists home-files/.zshrc
|
||||||
|
assertFileContains \
|
||||||
|
home-files/.zshrc \
|
||||||
|
'eval'
|
||||||
|
assertFileContains \
|
||||||
|
home-files/.zshrc \
|
||||||
|
'/bin/powerline-go -error $? -shell zsh -eval -modules nix-shell -modules-right git -newline -path-aliases \~/project/foo=prj-foo -ignore-repos /home/me/project1,/home/me/project2'
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue