2019-03-27 12:36:37 +01:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
|
|
|
|
cfg = config.programs.broot;
|
|
|
|
|
2021-03-13 04:20:00 +00:00
|
|
|
tomlFormat = pkgs.formats.toml { };
|
2019-03-27 12:36:37 +01:00
|
|
|
|
|
|
|
brootConf = {
|
2020-11-08 18:37:58 +01:00
|
|
|
verbs = cfg.verbs;
|
2019-03-27 12:36:37 +01:00
|
|
|
skin = cfg.skin;
|
2021-08-31 11:52:20 -05:00
|
|
|
modal = cfg.modal;
|
2019-03-27 12:36:37 +01:00
|
|
|
};
|
|
|
|
|
2020-02-02 00:39:17 +01:00
|
|
|
in {
|
2021-12-25 10:22:46 -08:00
|
|
|
meta.maintainers = [ hm.maintainers.aheaume ];
|
2019-03-27 12:36:37 +01:00
|
|
|
|
|
|
|
options.programs.broot = {
|
|
|
|
enable = mkEnableOption "Broot, a better way to navigate directories";
|
|
|
|
|
|
|
|
enableBashIntegration = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Whether to enable Bash integration.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
enableZshIntegration = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Whether to enable Zsh integration.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
enableFishIntegration = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = ''
|
|
|
|
Whether to enable Fish integration.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-08-31 11:52:20 -05:00
|
|
|
modal = mkEnableOption "modal (vim) mode";
|
|
|
|
|
2019-03-27 12:36:37 +01:00
|
|
|
verbs = mkOption {
|
2020-11-08 18:37:58 +01:00
|
|
|
type = with types; listOf (attrsOf (either bool str));
|
|
|
|
default = [
|
|
|
|
{
|
|
|
|
invocation = "p";
|
|
|
|
execution = ":parent";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
invocation = "edit";
|
2020-02-02 00:39:17 +01:00
|
|
|
shortcut = "e";
|
|
|
|
execution = "$EDITOR {file}";
|
2020-11-08 18:37:58 +01:00
|
|
|
}
|
|
|
|
{
|
|
|
|
invocation = "create {subpath}";
|
|
|
|
execution = "$EDITOR {directory}/{subpath}";
|
|
|
|
}
|
2019-03-27 12:36:37 +01:00
|
|
|
{
|
2020-11-08 18:37:58 +01:00
|
|
|
invocation = "view";
|
|
|
|
execution = "less {file}";
|
|
|
|
}
|
|
|
|
];
|
2021-10-09 11:14:08 +02:00
|
|
|
example = literalExpression ''
|
2020-11-08 18:37:58 +01:00
|
|
|
[
|
|
|
|
{ invocation = "p"; execution = ":parent"; }
|
|
|
|
{ invocation = "edit"; shortcut = "e"; execution = "$EDITOR {file}" ; }
|
|
|
|
{ invocation = "create {subpath}"; execution = "$EDITOR {directory}/{subpath}"; }
|
|
|
|
{ invocation = "view"; execution = "less {file}"; }
|
|
|
|
{
|
|
|
|
invocation = "blop {name}\\.{type}";
|
2019-03-27 12:36:37 +01:00
|
|
|
execution = "/bin/mkdir {parent}/{type} && /usr/bin/nvim {parent}/{type}/{name}.{type}";
|
|
|
|
from_shell = true;
|
2020-11-08 18:37:58 +01:00
|
|
|
}
|
|
|
|
]
|
2019-03-27 12:36:37 +01:00
|
|
|
'';
|
|
|
|
description = ''
|
2020-11-08 18:37:58 +01:00
|
|
|
Define new verbs. For more information, see
|
|
|
|
<link xlink:href="https://dystroy.org/broot/documentation/configuration/#verb-definition-attributes"/>.
|
2019-03-27 12:36:37 +01:00
|
|
|
</para><para>
|
|
|
|
The possible attributes are:
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
<variablelist>
|
2020-11-08 18:37:58 +01:00
|
|
|
<varlistentry>
|
|
|
|
<term><literal>invocation</literal> (optional)</term>
|
|
|
|
<listitem><para>how the verb is called by the user, with placeholders for arguments</para></listitem>
|
|
|
|
</varlistentry>
|
2019-03-27 12:36:37 +01:00
|
|
|
<varlistentry>
|
|
|
|
<term><literal>execution</literal> (mandatory)</term>
|
|
|
|
<listitem><para>how the verb is executed</para></listitem>
|
|
|
|
</varlistentry>
|
2020-11-08 18:37:58 +01:00
|
|
|
<varlistentry>
|
|
|
|
<term><literal>key</literal> (optional)</term>
|
|
|
|
<listitem><para>a keyboard key triggering execution</para></listitem>
|
|
|
|
</varlistentry>
|
2019-03-27 12:36:37 +01:00
|
|
|
<varlistentry>
|
|
|
|
<term><literal>shortcut</literal> (optional)</term>
|
|
|
|
<listitem><para>an alternate way to call the verb (without
|
|
|
|
the arguments part)</para></listitem>
|
|
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
|
|
<term><literal>leave_broot</literal> (optional)</term>
|
|
|
|
<listitem><para>whether to quit broot on execution
|
|
|
|
(default: <literal>true</literal>)</para></listitem>
|
|
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
|
|
<term><literal>from_shell</literal> (optional)</term>
|
|
|
|
<listitem><para>whether the verb must be executed from the
|
|
|
|
parent shell (default:
|
|
|
|
<literal>false</literal>)</para></listitem>
|
|
|
|
</varlistentry>
|
|
|
|
</variablelist>
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-01-06 11:16:36 +08:00
|
|
|
package = mkOption {
|
|
|
|
type = types.package;
|
|
|
|
default = pkgs.broot;
|
2021-10-09 11:14:08 +02:00
|
|
|
defaultText = literalExpression "pkgs.broot";
|
2021-01-06 11:16:36 +08:00
|
|
|
description = "Package providing broot";
|
|
|
|
};
|
|
|
|
|
2019-03-27 12:36:37 +01:00
|
|
|
skin = mkOption {
|
|
|
|
type = types.attrsOf types.str;
|
2020-02-02 00:39:17 +01:00
|
|
|
default = { };
|
2021-10-09 11:14:08 +02:00
|
|
|
example = literalExpression ''
|
2019-03-27 12:36:37 +01:00
|
|
|
{
|
|
|
|
status_normal_fg = "grayscale(18)";
|
|
|
|
status_normal_bg = "grayscale(3)";
|
|
|
|
status_error_fg = "red";
|
|
|
|
status_error_bg = "yellow";
|
|
|
|
tree_fg = "red";
|
|
|
|
selected_line_bg = "grayscale(7)";
|
|
|
|
permissions_fg = "grayscale(12)";
|
|
|
|
size_bar_full_bg = "red";
|
|
|
|
size_bar_void_bg = "black";
|
|
|
|
directory_fg = "lightyellow";
|
|
|
|
input_fg = "cyan";
|
|
|
|
flag_value_fg = "lightyellow";
|
|
|
|
table_border_fg = "red";
|
|
|
|
code_fg = "lightyellow";
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
description = ''
|
|
|
|
Color configuration.
|
|
|
|
</para><para>
|
|
|
|
Complete list of keys (expected to change before the v1 of broot):
|
|
|
|
|
|
|
|
<itemizedlist>
|
|
|
|
<listitem><para><literal>char_match</literal></para></listitem>
|
|
|
|
<listitem><para><literal>code</literal></para></listitem>
|
|
|
|
<listitem><para><literal>directory</literal></para></listitem>
|
|
|
|
<listitem><para><literal>exe</literal></para></listitem>
|
|
|
|
<listitem><para><literal>file</literal></para></listitem>
|
|
|
|
<listitem><para><literal>file_error</literal></para></listitem>
|
|
|
|
<listitem><para><literal>flag_label</literal></para></listitem>
|
|
|
|
<listitem><para><literal>flag_value</literal></para></listitem>
|
|
|
|
<listitem><para><literal>input</literal></para></listitem>
|
|
|
|
<listitem><para><literal>link</literal></para></listitem>
|
|
|
|
<listitem><para><literal>permissions</literal></para></listitem>
|
|
|
|
<listitem><para><literal>selected_line</literal></para></listitem>
|
|
|
|
<listitem><para><literal>size_bar_full</literal></para></listitem>
|
|
|
|
<listitem><para><literal>size_bar_void</literal></para></listitem>
|
|
|
|
<listitem><para><literal>size_text</literal></para></listitem>
|
|
|
|
<listitem><para><literal>spinner</literal></para></listitem>
|
|
|
|
<listitem><para><literal>status_error</literal></para></listitem>
|
|
|
|
<listitem><para><literal>status_normal</literal></para></listitem>
|
|
|
|
<listitem><para><literal>table_border</literal></para></listitem>
|
|
|
|
<listitem><para><literal>tree</literal></para></listitem>
|
|
|
|
<listitem><para><literal>unlisted</literal></para></listitem>
|
|
|
|
</itemizedlist></para>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
Add <literal>_fg</literal> for a foreground color and
|
|
|
|
<literal>_bg</literal> for a background colors.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2021-01-06 11:16:36 +08:00
|
|
|
home.packages = [ cfg.package ];
|
2019-03-27 12:36:37 +01:00
|
|
|
|
2021-03-13 04:20:00 +00:00
|
|
|
xdg.configFile."broot/conf.toml".source =
|
|
|
|
tomlFormat.generate "broot-config" brootConf;
|
2019-03-27 12:36:37 +01:00
|
|
|
|
|
|
|
# Dummy file to prevent broot from trying to reinstall itself
|
2020-06-04 18:24:38 +02:00
|
|
|
xdg.configFile."broot/launcher/installed-v1".text = "";
|
2019-03-27 12:36:37 +01:00
|
|
|
|
2020-02-02 00:39:17 +01:00
|
|
|
programs.bash.initExtra = mkIf cfg.enableBashIntegration (
|
2020-04-06 12:51:11 +02:00
|
|
|
# Using mkAfter to make it more likely to appear after other
|
|
|
|
# manipulations of the prompt.
|
2020-02-02 00:39:17 +01:00
|
|
|
mkAfter ''
|
|
|
|
# This script was automatically generated by the broot function
|
|
|
|
# More information can be found in https://github.com/Canop/broot
|
|
|
|
# This function starts broot and executes the command
|
|
|
|
# it produces, if any.
|
|
|
|
# It's needed because some shell commands, like `cd`,
|
|
|
|
# have no useful effect if executed in a subshell.
|
|
|
|
function br {
|
|
|
|
f=$(mktemp)
|
|
|
|
(
|
|
|
|
set +e
|
|
|
|
broot --outcmd "$f" "$@"
|
|
|
|
code=$?
|
|
|
|
if [ "$code" != 0 ]; then
|
|
|
|
rm -f "$f"
|
|
|
|
exit "$code"
|
|
|
|
fi
|
|
|
|
)
|
|
|
|
code=$?
|
|
|
|
if [ "$code" != 0 ]; then
|
|
|
|
return "$code"
|
|
|
|
fi
|
|
|
|
d=$(cat "$f")
|
|
|
|
rm -f "$f"
|
|
|
|
eval "$d"
|
|
|
|
}
|
|
|
|
'');
|
2019-03-27 12:36:37 +01:00
|
|
|
|
|
|
|
programs.zsh.initExtra = mkIf cfg.enableZshIntegration ''
|
|
|
|
# This script was automatically generated by the broot function
|
|
|
|
# More information can be found in https://github.com/Canop/broot
|
|
|
|
# This function starts broot and executes the command
|
|
|
|
# it produces, if any.
|
|
|
|
# It's needed because some shell commands, like `cd`,
|
|
|
|
# have no useful effect if executed in a subshell.
|
|
|
|
function br {
|
|
|
|
f=$(mktemp)
|
|
|
|
(
|
|
|
|
set +e
|
|
|
|
broot --outcmd "$f" "$@"
|
|
|
|
code=$?
|
|
|
|
if [ "$code" != 0 ]; then
|
|
|
|
rm -f "$f"
|
|
|
|
exit "$code"
|
|
|
|
fi
|
|
|
|
)
|
|
|
|
code=$?
|
|
|
|
if [ "$code" != 0 ]; then
|
|
|
|
return "$code"
|
|
|
|
fi
|
|
|
|
d=$(cat "$f")
|
|
|
|
rm -f "$f"
|
|
|
|
eval "$d"
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
|
|
|
|
programs.fish.shellInit = mkIf cfg.enableFishIntegration ''
|
|
|
|
# This script was automatically generated by the broot function
|
|
|
|
# More information can be found in https://github.com/Canop/broot
|
|
|
|
# This function starts broot and executes the command
|
|
|
|
# it produces, if any.
|
|
|
|
# It's needed because some shell commands, like `cd`,
|
|
|
|
# have no useful effect if executed in a subshell.
|
|
|
|
function br
|
|
|
|
set f (mktemp)
|
|
|
|
broot --outcmd $f $argv
|
|
|
|
if test $status -ne 0
|
|
|
|
rm -f "$f"
|
|
|
|
return "$code"
|
|
|
|
end
|
|
|
|
set d (cat "$f")
|
|
|
|
rm -f "$f"
|
|
|
|
eval "$d"
|
|
|
|
end
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
}
|