feat: switch to fish as an interactive shell #375

Merged
jalil merged 1 commit from push-wzkrsvyqulvy into main 2025-03-24 21:23:49 +01:00
6 changed files with 117 additions and 139 deletions
Showing only changes of commit cd4fb19335 - Show all commits

View file

@ -12,7 +12,7 @@ in
modules = [ modules = [
inputs.self.nixosModules.default inputs.self.nixosModules.default
../example-vm # import vm configuration ../example-vm # import vm configuration
{ nix.registry.nixpkgs.flake = inputs.nixpkgs; } { nix.registry.nixpkgs.flake = inputs.nixpkgs; } # pin nixpkgs to the one used by the system
]; ];
}; };

View file

@ -58,6 +58,11 @@ in
git = true; git = true;
icons = "auto"; icons = "auto";
}; };
# Shell
fish = {
enable = true;
preferAbbrs = true; # when defining an alias, prefer instead to define an abbreviation
};
# GnuPG # GnuPG
gpg = { gpg = {
enable = true; enable = true;
@ -75,16 +80,6 @@ in
ssh.enable = true; ssh.enable = true;
# cd replacement # cd replacement
zoxide.enable = true; zoxide.enable = true;
# Shell
zsh = {
enable = true;
autosuggestion.enable = true;
enableCompletion = true;
autocd = true;
dotDir = ".config/zsh";
history.path = "${config.xdg.dataHome}/zsh/zsh_history";
syntaxHighlighting.enable = true;
};
}; };
services = { services = {

View file

@ -129,13 +129,13 @@ in
# PDF reader # PDF reader
zathura.enable = true; zathura.enable = true;
# Auto start sway # Auto start sway
zsh.loginExtra = fish.loginShellInit =
lib.optionalString cfg.sway.autostart # sh lib.optionalString cfg.sway.autostart # fish
'' ''
# Start Sway on login to TTY 1 # Start Sway on login to TTY 1
if [ "$TTY" = /dev/tty1 ]; then if test "$(tty)" = /dev/tty1
exec sway exec sway
fi end
''; '';
}; };
services = { services = {

View file

@ -35,6 +35,17 @@ in
]; ];
programs = { programs = {
# Launch fish if shell is interactive (from https://wiki.nixos.org/wiki/Fish)
bash.interactiveShellInit = # bash
''
if [[ $(${pkgs.procps}/bin/ps --no-header --pid=$PPID --format=comm) != "fish" && -z ''${BASH_EXECUTION_STRING} ]]
then
shopt -q login_shell && LOGIN_OPTION='--login' || LOGIN_OPTION=""
exec ${pkgs.fish}/bin/fish $LOGIN_OPTION
fi
'';
# Default shell
fish.enable = true;
# Shell prompt # Shell prompt
starship = { starship = {
enable = true; enable = true;
@ -58,8 +69,6 @@ in
(import ./starship-shorter-text.nix) (import ./starship-shorter-text.nix)
]; ];
}; };
# Default shell
zsh.enable = true;
}; };
environment.etc = keysFromGithub; environment.etc = keysFromGithub;
@ -74,7 +83,6 @@ in
builtins.attrNames keysFromGithub builtins.attrNames keysFromGithub
); );
}; };
users.defaultUserShell = pkgs.zsh;
# Open ports for spotifyd # Open ports for spotifyd
networking.firewall = { networking.firewall = {
allowedUDPPorts = [ 5353 ]; allowedUDPPorts = [ 5353 ];

View file

@ -21,6 +21,7 @@ let
"typos_lsp" "typos_lsp"
# "typst_lsp" # Not using it # "typst_lsp" # Not using it
"zls" "zls"
"fish_lsp"
]; ];
in in
{ {
@ -95,6 +96,7 @@ in
pkgs.stylua pkgs.stylua
pkgs.taplo pkgs.taplo
pkgs.yamlfmt pkgs.yamlfmt
pkgs.fish
]; ];
plugins.conform-nvim = { plugins.conform-nvim = {
enable = true; enable = true;
@ -111,6 +113,7 @@ in
toml = [ "taplo" ]; toml = [ "taplo" ];
yaml = [ "yamlfmt" ]; yaml = [ "yamlfmt" ];
zig = [ "zigfmt" ]; zig = [ "zigfmt" ];
fish = [ "fish_indent" ];
}; };
}; };
}; };
@ -127,7 +130,6 @@ in
# latex = [ "chktex" ]; # Not in use # latex = [ "chktex" ]; # Not in use
nix = [ "statix" ]; nix = [ "statix" ];
sh = [ "dash" ]; sh = [ "dash" ];
zsh = [ "zsh" ];
}; };
}; };
} }

View file

@ -4,129 +4,102 @@ let
in in
{ {
config.plugins = { config.plugins = {
cmp = { cmp =
enable = true; let
cmdline = { srcWithIndex = groupIndex: name: { inherit name groupIndex; };
"/" = { in
mapping = {
mkRaw enable = true;
# lua cmdline = {
'' "/" = {
cmp.mapping.preset.cmdline() mapping =
''; mkRaw
sources = [ # lua
{ name = "rg"; } ''
{ name = "buffer"; } cmp.mapping.preset.cmdline()
]; '';
sources = [
{ name = "rg"; }
{ name = "buffer"; }
];
};
":" = {
mapping =
mkRaw
# lua
"cmp.mapping.preset.cmdline()";
sources = [
{ name = "path"; }
{ name = "cmdline"; }
];
};
}; };
":" = { settings = {
mapping = # Snippets
mkRaw snippet.expand =
# lua
''
cmp.mapping.preset.cmdline()
'';
sources = [
{ name = "path"; }
{ name = "cmdline"; }
];
};
};
settings = {
# Snippets
snippet.expand =
# lua
''
function(args) require('luasnip').lsp_expand(args.body) end
'';
# Completion Sources
sources = [
{
name = "buffer";
groupIndex = 3;
}
{
name = "calc";
groupIndex = 2;
}
{
name = "conventionalcommits";
groupIndex = 1;
}
{
name = "crates";
groupIndex = 1;
}
{
name = "luasnip";
groupIndex = 1;
}
{
name = "nvim_lsp";
groupIndex = 1;
}
{
name = "nvim_lsp_document_symbol";
groupIndex = 1;
}
{
name = "nvim_lsp_signature_help";
groupIndex = 1;
}
{
name = "path";
groupIndex = 2;
}
{
name = "spell";
groupIndex = 2;
}
{
name = "treesitter";
groupIndex = 2;
}
];
mapping =
mkRaw
# lua # lua
'' "function(args) require('luasnip').lsp_expand(args.body) end";
cmp.mapping.preset.insert({ # Completion Sources
["<C-n>"] = function(fallback) sources = [
if cmp.visible() then # very specific (not noisy)
cmp.select_next_item() (srcWithIndex 1 "calc")
elseif require("luasnip").expand_or_jumpable() then (srcWithIndex 1 "crates")
require("luasnip").expand_or_jump() (srcWithIndex 1 "fish")
elseif has_words_before() then (srcWithIndex 1 "luasnip")
cmp.complete() (srcWithIndex 1 "nvim_lsp")
else # Generally ok
fallback() (srcWithIndex 2 "conventionalcommits")
end (srcWithIndex 2 "nvim_lsp_document_symbol")
end, (srcWithIndex 2 "nvim_lsp_signature_help")
["<C-p>"] = function(fallback) # Noisy
if cmp.visible() then (srcWithIndex 2 "path")
cmp.select_prev_item() (srcWithIndex 3 "spell")
elseif require("luasnip").jumpable(-1) then (srcWithIndex 3 "treesitter")
require("luasnip").jump(-1) # Very noisy
else (srcWithIndex 4 "buffer")
fallback() ];
end mapping =
end, mkRaw
["<C-u>"] = cmp.mapping(function(fallback) # lua
if require("luasnip").choice_active() then ''
require("luasnip").next_choice() cmp.mapping.preset.insert({
else ["<C-n>"] = function(fallback)
fallback() if cmp.visible() then
end cmp.select_next_item()
end), elseif require("luasnip").expand_or_jumpable() then
["<C-b>"] = cmp.mapping.scroll_docs(-4), require("luasnip").expand_or_jump()
["<C-f>"] = cmp.mapping.scroll_docs(4), elseif has_words_before() then
["<C-Space>"] = cmp.mapping.complete { }, cmp.complete()
["<C-e>"] = cmp.mapping.close(), else
["<CR>"] = cmp.mapping.confirm { select = true }, fallback()
}) end
''; end,
["<C-p>"] = function(fallback)
if cmp.visible() then
cmp.select_prev_item()
elseif require("luasnip").jumpable(-1) then
require("luasnip").jump(-1)
else
fallback()
end
end,
["<C-u>"] = cmp.mapping(function(fallback)
if require("luasnip").choice_active() then
require("luasnip").next_choice()
else
fallback()
end
end),
["<C-b>"] = cmp.mapping.scroll_docs(-4),
["<C-f>"] = cmp.mapping.scroll_docs(4),
["<C-Space>"] = cmp.mapping.complete { },
["<C-e>"] = cmp.mapping.close(),
["<CR>"] = cmp.mapping.confirm { select = true },
})
'';
};
}; };
}; cmp-fish.enable = true;
gitsigns.enable = true; gitsigns.enable = true;
lualine = { lualine = {
enable = true; enable = true;