@@ -49,7 +49,7 @@
|
||||
};
|
||||
|
||||
zsh = {
|
||||
initExtra = ''
|
||||
initContent = ''
|
||||
kubeswitch() {
|
||||
local target="$HOME/.kube/$1"
|
||||
local config="$HOME/.kube/config"
|
||||
|
@@ -12,7 +12,7 @@
|
||||
home-manager.users.${user}.programs.zsh = {
|
||||
shellAliases.nd = "nix-develop";
|
||||
|
||||
initExtra =
|
||||
initContent =
|
||||
let
|
||||
devShells = lib.strings.concatStringsSep " " (
|
||||
lib.attrsets.mapAttrsToList (key: _: key) inputs.self.devShells.${system}
|
||||
|
@@ -10,97 +10,19 @@
|
||||
...
|
||||
}:
|
||||
{
|
||||
home-manager.users.${user} = {
|
||||
programs = {
|
||||
direnv = {
|
||||
enable = true;
|
||||
silent = true;
|
||||
nix-direnv.enable = true;
|
||||
enableZshIntegration = true;
|
||||
home-manager.users.${user}.programs = {
|
||||
direnv = {
|
||||
enable = true;
|
||||
silent = true;
|
||||
nix-direnv.enable = true;
|
||||
enableZshIntegration = true;
|
||||
|
||||
config = {
|
||||
global.warn_timeout = 0;
|
||||
};
|
||||
|
||||
zsh = {
|
||||
shellAliases.nde = "nix-direnv";
|
||||
|
||||
initExtra =
|
||||
let
|
||||
devShells = lib.strings.concatStringsSep " " (
|
||||
lib.attrsets.mapAttrsToList (key: _: key) inputs.self.devShells.${system}
|
||||
);
|
||||
in
|
||||
''
|
||||
nix-direnv() {
|
||||
local devshell=""
|
||||
local hide=false
|
||||
|
||||
while getopts "s:h" opt; do
|
||||
case $opt in
|
||||
s)
|
||||
devshell="$OPTARG"
|
||||
;;
|
||||
h)
|
||||
hide=true
|
||||
;;
|
||||
*)
|
||||
echo "Usage: nix-direnv [-s <devshell>] [-h]"
|
||||
return 1
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
if [[ -z "$devshell" ]]; then
|
||||
if "$hide"; then
|
||||
echo "use flake path:." > .envrc;
|
||||
else
|
||||
echo "use flake" > .envrc;
|
||||
fi
|
||||
|
||||
if [ ! -f flake.nix ]; then
|
||||
cp "${../nix-develop/template.nix}" flake.nix
|
||||
chmod 755 flake.nix
|
||||
fi
|
||||
|
||||
if [ ! -f treefmt.nix ]; then
|
||||
cp "${../nix-develop/treefmt.nix}" treefmt.nix
|
||||
chmod 755 treefmt.nix
|
||||
fi
|
||||
else
|
||||
echo "use flake self#$devshell" > .envrc
|
||||
fi
|
||||
|
||||
if "$hide" && git rev-parse --is-inside-work-tree &>/dev/null; then
|
||||
local top
|
||||
top="$(git rev-parse --show-toplevel)"
|
||||
if ! grep -q "^\.envrc$" "$top/.gitignore" "$top/.git/info/exclude"; then echo "$(realpath --relative-to="$top" .envrc)" >> "$top/.git/info/exclude"; fi
|
||||
if [ -z "$devshell" ]; then
|
||||
if ! grep -q "^flake.nix$" "$top/.gitignore" "$top/.git/info/exclude"; then echo "flake.nix" >> "$top/.git/info/exclude"; fi
|
||||
if ! grep -q "^flake.lock$" "$top/.gitignore" "$top/.git/info/exclude"; then echo "flake.lock" >> "$top/.git/info/exclude"; fi
|
||||
if ! grep -q "^treefmt.nix$" "$top/.gitignore" "$top/.git/info/exclude"; then echo "treefmt.nix" >> "$top/.git/info/exclude"; fi
|
||||
fi
|
||||
fi
|
||||
|
||||
direnv allow
|
||||
}
|
||||
|
||||
_nix-direnv_completion() {
|
||||
local options=(
|
||||
'-s[Dev shell from root flake]:shell:(${devShells})'
|
||||
'-h[Hide .envrc and flake.nix in git]'
|
||||
)
|
||||
|
||||
_arguments -s $options
|
||||
}
|
||||
|
||||
compdef _nix-direnv_completion nix-direnv
|
||||
'';
|
||||
|
||||
p10k.extraRightPromptElements = [ "direnv" ];
|
||||
};
|
||||
};
|
||||
|
||||
# https://github.com/direnv/direnv/wiki/Customizing-cache-location
|
||||
xdg.configFile = {
|
||||
"direnv/direnvrc".text = ''
|
||||
# https://github.com/direnv/direnv/wiki/Customizing-cache-location
|
||||
stdlib = ''
|
||||
declare -A direnv_layout_dirs
|
||||
direnv_layout_dir() {
|
||||
local hash path
|
||||
@@ -111,10 +33,84 @@
|
||||
)}"
|
||||
}
|
||||
'';
|
||||
};
|
||||
|
||||
"direnv/direnv.toml".source = (
|
||||
(pkgs.formats.toml { }).generate "direnv.toml" { global.warn_timeout = 0; }
|
||||
);
|
||||
zsh = {
|
||||
shellAliases.nde = "nix-direnv";
|
||||
|
||||
initContent =
|
||||
let
|
||||
devShells = lib.strings.concatStringsSep " " (
|
||||
lib.attrsets.mapAttrsToList (key: _: key) inputs.self.devShells.${system}
|
||||
);
|
||||
in
|
||||
''
|
||||
nix-direnv() {
|
||||
local devshell=""
|
||||
local hide=false
|
||||
|
||||
while getopts "s:h" opt; do
|
||||
case $opt in
|
||||
s)
|
||||
devshell="$OPTARG"
|
||||
;;
|
||||
h)
|
||||
hide=true
|
||||
;;
|
||||
*)
|
||||
echo "Usage: nix-direnv [-s <devshell>] [-h]"
|
||||
return 1
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
if [[ -z "$devshell" ]]; then
|
||||
if "$hide"; then
|
||||
echo "use flake path:." > .envrc;
|
||||
else
|
||||
echo "use flake" > .envrc;
|
||||
fi
|
||||
|
||||
if [ ! -f flake.nix ]; then
|
||||
cp "${../nix-develop/template.nix}" flake.nix
|
||||
chmod 755 flake.nix
|
||||
fi
|
||||
|
||||
if [ ! -f treefmt.nix ]; then
|
||||
cp "${../nix-develop/treefmt.nix}" treefmt.nix
|
||||
chmod 755 treefmt.nix
|
||||
fi
|
||||
else
|
||||
echo "use flake self#$devshell" > .envrc
|
||||
fi
|
||||
|
||||
if "$hide" && git rev-parse --is-inside-work-tree &>/dev/null; then
|
||||
local top
|
||||
top="$(git rev-parse --show-toplevel)"
|
||||
if ! grep -q "^\.envrc$" "$top/.gitignore" "$top/.git/info/exclude"; then echo "$(realpath --relative-to="$top" .envrc)" >> "$top/.git/info/exclude"; fi
|
||||
if [ -z "$devshell" ]; then
|
||||
if ! grep -q "^flake.nix$" "$top/.gitignore" "$top/.git/info/exclude"; then echo "flake.nix" >> "$top/.git/info/exclude"; fi
|
||||
if ! grep -q "^flake.lock$" "$top/.gitignore" "$top/.git/info/exclude"; then echo "flake.lock" >> "$top/.git/info/exclude"; fi
|
||||
if ! grep -q "^treefmt.nix$" "$top/.gitignore" "$top/.git/info/exclude"; then echo "treefmt.nix" >> "$top/.git/info/exclude"; fi
|
||||
fi
|
||||
fi
|
||||
|
||||
direnv allow
|
||||
}
|
||||
|
||||
_nix-direnv_completion() {
|
||||
local options=(
|
||||
'-s[Dev shell from root flake]:shell:(${devShells})'
|
||||
'-h[Hide .envrc and flake.nix in git]'
|
||||
)
|
||||
|
||||
_arguments -s $options
|
||||
}
|
||||
|
||||
compdef _nix-direnv_completion nix-direnv
|
||||
'';
|
||||
|
||||
p10k.extraRightPromptElements = [ "direnv" ];
|
||||
};
|
||||
};
|
||||
|
||||
|
@@ -33,7 +33,7 @@
|
||||
file = "share/zsh-powerlevel10k/powerlevel10k.zsh-theme";
|
||||
}
|
||||
];
|
||||
initExtra = ''
|
||||
initContent = ''
|
||||
source ${./.p10k.zsh}
|
||||
'';
|
||||
};
|
||||
|
@@ -18,7 +18,7 @@ in
|
||||
with lib;
|
||||
with cfg;
|
||||
{
|
||||
initExtra = ''
|
||||
initContent = ''
|
||||
export P10K_EXTRA_RIGHT_PROMPT_ELEMENTS=(${strings.concatStringsSep " " p10k.extraRightPromptElements})
|
||||
'';
|
||||
};
|
||||
|
Reference in New Issue
Block a user