zsh: improve config to make it more oh-my-zsh like
This commit is contained in:
parent
eb8601d2ac
commit
c2e80ffddd
@ -22,53 +22,16 @@ in {
|
|||||||
programs.zsh = {
|
programs.zsh = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
||||||
initExtra = ''
|
initExtra = builtins.readFile ./key-bindings.zsh
|
||||||
function go_dir_up() {
|
+ builtins.readFile ./functions.zsh
|
||||||
cd .. || return 1
|
+ builtins.readFile ./last-working-dir.zsh
|
||||||
}
|
+ builtins.readFile ./dir-navigation.zsh;
|
||||||
|
|
||||||
function zle_go_dir_up() {
|
|
||||||
zle .kill-buffer
|
|
||||||
go_dir_up
|
|
||||||
zle .accept-line
|
|
||||||
}
|
|
||||||
|
|
||||||
fzf-z() {
|
|
||||||
dir=$(z | fzf --tiebreak=index --tac | sed -E 's/^[0-9]+[[:space:]]+//')
|
|
||||||
cd $dir
|
|
||||||
}
|
|
||||||
|
|
||||||
mkcd ()
|
|
||||||
{
|
|
||||||
mkdir -p -- "$1" && cd -P -- "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
zle -N zle_go_dir_up
|
|
||||||
# Alt+Up
|
|
||||||
bindkey "^[[1;3A" zle_go_dir_up
|
|
||||||
|
|
||||||
# Alt+Down
|
|
||||||
bindkey "^[[1;3B" kill-buffer
|
|
||||||
|
|
||||||
# Up/Down
|
|
||||||
bindkey "^[[A" history-substring-search-up
|
|
||||||
bindkey "^[[B" history-substring-search-down
|
|
||||||
|
|
||||||
# Ctrl+Left/Right
|
|
||||||
bindkey "^[[1;5C" forward-word
|
|
||||||
bindkey "^[[1;5D" backward-word
|
|
||||||
|
|
||||||
# Alt+Left/Right
|
|
||||||
bindkey "^[[1;3C" forward-word
|
|
||||||
bindkey "^[[1;3D" backward-word
|
|
||||||
'';
|
|
||||||
|
|
||||||
zplug = {
|
zplug = {
|
||||||
enable = true;
|
enable = true;
|
||||||
plugins = [
|
plugins = [
|
||||||
# list of plugins: https://github.com/unixorn/awesome-zsh-plugins
|
# list of plugins: https://github.com/unixorn/awesome-zsh-plugins
|
||||||
{ name = "agkozak/zsh-z"; }
|
{ name = "agkozak/zsh-z"; }
|
||||||
{ name = "mdumitru/last-working-dir"; }
|
|
||||||
{
|
{
|
||||||
name = "zsh-users/zsh-completions";
|
name = "zsh-users/zsh-completions";
|
||||||
}
|
}
|
||||||
|
17
home-manager/modules/shell/zsh/dir-navigation.zsh
Normal file
17
home-manager/modules/shell/zsh/dir-navigation.zsh
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
#!/usr/bin/env zsh
|
||||||
|
# Use Alt+Up to go one directory upwards
|
||||||
|
|
||||||
|
function go_dir_up() {
|
||||||
|
cd .. || return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function zle_go_dir_up() {
|
||||||
|
zle .kill-buffer
|
||||||
|
go_dir_up
|
||||||
|
zle .accept-line
|
||||||
|
}
|
||||||
|
|
||||||
|
zle -N zle_go_dir_up
|
||||||
|
|
||||||
|
# Alt+Up
|
||||||
|
bindkey "^[[1;3A" zle_go_dir_up
|
12
home-manager/modules/shell/zsh/functions.zsh
Normal file
12
home-manager/modules/shell/zsh/functions.zsh
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
#!/usr/bin/env zsh
|
||||||
|
# My custom zsh functions
|
||||||
|
|
||||||
|
fzf-z() {
|
||||||
|
dir=$(z | fzf --tiebreak=index --tac | sed -E 's/^[0-9]+[[:space:]]+//')
|
||||||
|
cd $dir
|
||||||
|
}
|
||||||
|
|
||||||
|
mkcd ()
|
||||||
|
{
|
||||||
|
mkdir -p -- "$1" && cd -P -- "$1"
|
||||||
|
}
|
131
home-manager/modules/shell/zsh/key-bindings.zsh
Normal file
131
home-manager/modules/shell/zsh/key-bindings.zsh
Normal file
@ -0,0 +1,131 @@
|
|||||||
|
#!/usr/bin/env zsh
|
||||||
|
# Based on the oh-my-zsh default keybinding config: https://github.com/ohmyzsh/ohmyzsh/blob/master/lib/key-bindings.zsh
|
||||||
|
|
||||||
|
# Make sure that the terminal is in application mode when zle is active, since
|
||||||
|
# only then values from $terminfo are valid
|
||||||
|
if (( ${+terminfo[smkx]} )) && (( ${+terminfo[rmkx]} )); then
|
||||||
|
function zle-line-init() {
|
||||||
|
echoti smkx
|
||||||
|
}
|
||||||
|
function zle-line-finish() {
|
||||||
|
echoti rmkx
|
||||||
|
}
|
||||||
|
zle -N zle-line-init
|
||||||
|
zle -N zle-line-finish
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Use emacs key bindings
|
||||||
|
bindkey -e
|
||||||
|
|
||||||
|
# [PageUp] - Up a line of history
|
||||||
|
if [[ -n "${terminfo[kpp]}" ]]; then
|
||||||
|
bindkey -M emacs "${terminfo[kpp]}" up-line-or-history
|
||||||
|
bindkey -M viins "${terminfo[kpp]}" up-line-or-history
|
||||||
|
bindkey -M vicmd "${terminfo[kpp]}" up-line-or-history
|
||||||
|
fi
|
||||||
|
# [PageDown] - Down a line of history
|
||||||
|
if [[ -n "${terminfo[knp]}" ]]; then
|
||||||
|
bindkey -M emacs "${terminfo[knp]}" down-line-or-history
|
||||||
|
bindkey -M viins "${terminfo[knp]}" down-line-or-history
|
||||||
|
bindkey -M vicmd "${terminfo[knp]}" down-line-or-history
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Start typing + [Up-Arrow] - fuzzy find history forward
|
||||||
|
if [[ -n "${terminfo[kcuu1]}" ]]; then
|
||||||
|
bindkey -M emacs "${terminfo[kcuu1]}" history-substring-search-up
|
||||||
|
bindkey -M viins "${terminfo[kcuu1]}" history-substring-search-up
|
||||||
|
bindkey -M vicmd "${terminfo[kcuu1]}" history-substring-search-up
|
||||||
|
fi
|
||||||
|
# Start typing + [Down-Arrow] - fuzzy find history backward
|
||||||
|
if [[ -n "${terminfo[kcud1]}" ]]; then
|
||||||
|
bindkey -M emacs "${terminfo[kcud1]}" history-substring-search-down
|
||||||
|
bindkey -M viins "${terminfo[kcud1]}" history-substring-search-down
|
||||||
|
bindkey -M vicmd "${terminfo[kcud1]}" history-substring-search-down
|
||||||
|
fi
|
||||||
|
|
||||||
|
# [Home] - Go to beginning of line
|
||||||
|
if [[ -n "${terminfo[khome]}" ]]; then
|
||||||
|
bindkey -M emacs "${terminfo[khome]}" beginning-of-line
|
||||||
|
bindkey -M viins "${terminfo[khome]}" beginning-of-line
|
||||||
|
bindkey -M vicmd "${terminfo[khome]}" beginning-of-line
|
||||||
|
fi
|
||||||
|
# [End] - Go to end of line
|
||||||
|
if [[ -n "${terminfo[kend]}" ]]; then
|
||||||
|
bindkey -M emacs "${terminfo[kend]}" end-of-line
|
||||||
|
bindkey -M viins "${terminfo[kend]}" end-of-line
|
||||||
|
bindkey -M vicmd "${terminfo[kend]}" end-of-line
|
||||||
|
fi
|
||||||
|
|
||||||
|
# [Shift-Tab] - move through the completion menu backwards
|
||||||
|
if [[ -n "${terminfo[kcbt]}" ]]; then
|
||||||
|
bindkey -M emacs "${terminfo[kcbt]}" reverse-menu-complete
|
||||||
|
bindkey -M viins "${terminfo[kcbt]}" reverse-menu-complete
|
||||||
|
bindkey -M vicmd "${terminfo[kcbt]}" reverse-menu-complete
|
||||||
|
fi
|
||||||
|
|
||||||
|
# [Backspace] - delete backward
|
||||||
|
bindkey -M emacs '^?' backward-delete-char
|
||||||
|
bindkey -M viins '^?' backward-delete-char
|
||||||
|
bindkey -M vicmd '^?' backward-delete-char
|
||||||
|
# [Delete] - delete forward
|
||||||
|
if [[ -n "${terminfo[kdch1]}" ]]; then
|
||||||
|
bindkey -M emacs "${terminfo[kdch1]}" delete-char
|
||||||
|
bindkey -M viins "${terminfo[kdch1]}" delete-char
|
||||||
|
bindkey -M vicmd "${terminfo[kdch1]}" delete-char
|
||||||
|
else
|
||||||
|
bindkey -M emacs "^[[3~" delete-char
|
||||||
|
bindkey -M viins "^[[3~" delete-char
|
||||||
|
bindkey -M vicmd "^[[3~" delete-char
|
||||||
|
|
||||||
|
bindkey -M emacs "^[3;5~" delete-char
|
||||||
|
bindkey -M viins "^[3;5~" delete-char
|
||||||
|
bindkey -M vicmd "^[3;5~" delete-char
|
||||||
|
fi
|
||||||
|
|
||||||
|
# [Ctrl-Delete] - delete whole forward-word
|
||||||
|
bindkey -M emacs '^[[3;5~' kill-word
|
||||||
|
bindkey -M viins '^[[3;5~' kill-word
|
||||||
|
bindkey -M vicmd '^[[3;5~' kill-word
|
||||||
|
|
||||||
|
# [Ctrl-RightArrow] - move forward one word
|
||||||
|
bindkey -M emacs '^[[1;5C' forward-word
|
||||||
|
bindkey -M viins '^[[1;5C' forward-word
|
||||||
|
bindkey -M vicmd '^[[1;5C' forward-word
|
||||||
|
# [Ctrl-LeftArrow] - move backward one word
|
||||||
|
bindkey -M emacs '^[[1;5D' backward-word
|
||||||
|
bindkey -M viins '^[[1;5D' backward-word
|
||||||
|
bindkey -M vicmd '^[[1;5D' backward-word
|
||||||
|
|
||||||
|
|
||||||
|
bindkey '\ew' kill-region # [Esc-w] - Kill from the cursor to the mark
|
||||||
|
bindkey -s '\el' 'ls\n' # [Esc-l] - run command: ls
|
||||||
|
bindkey '^r' history-incremental-search-backward # [Ctrl-r] - Search backward incrementally for a specified string. The string may begin with ^ to anchor the search to the beginning of the line.
|
||||||
|
bindkey ' ' magic-space # [Space] - don't do history expansion
|
||||||
|
|
||||||
|
|
||||||
|
# Edit the current command line in $EDITOR
|
||||||
|
autoload -U edit-command-line
|
||||||
|
zle -N edit-command-line
|
||||||
|
bindkey '\C-x\C-e' edit-command-line
|
||||||
|
|
||||||
|
# file rename magick
|
||||||
|
bindkey "^[m" copy-prev-shell-word
|
||||||
|
|
||||||
|
# consider emacs keybindings:
|
||||||
|
|
||||||
|
#bindkey -e ## emacs key bindings
|
||||||
|
#
|
||||||
|
#bindkey '^[[A' up-line-or-search
|
||||||
|
#bindkey '^[[B' down-line-or-search
|
||||||
|
#bindkey '^[^[[C' emacs-forward-word
|
||||||
|
#bindkey '^[^[[D' emacs-backward-word
|
||||||
|
#
|
||||||
|
#bindkey -s '^X^Z' '%-^M'
|
||||||
|
#bindkey '^[e' expand-cmd-path
|
||||||
|
#bindkey '^[^I' reverse-menu-complete
|
||||||
|
#bindkey '^X^N' accept-and-infer-next-history
|
||||||
|
#bindkey '^W' kill-region
|
||||||
|
#bindkey '^I' complete-word
|
||||||
|
## Fix weird sequence that rxvt produces
|
||||||
|
#bindkey -s '^[[Z' '\t'
|
||||||
|
#
|
20
home-manager/modules/shell/zsh/last-working-dir.zsh
Normal file
20
home-manager/modules/shell/zsh/last-working-dir.zsh
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
#!/usr/bin/zsh
|
||||||
|
# My version of the last-working-dir plugin (https://github.com/ohmyzsh/ohmyzsh/blob/master/plugins/last-working-dir/last-working-dir.plugin.zsh)
|
||||||
|
|
||||||
|
# Updates the last directory once directory is changed
|
||||||
|
autoload -U add-zsh-hook
|
||||||
|
add-zsh-hook chpwd chpwd_last_working_dir
|
||||||
|
chpwd_last_working_dir() {
|
||||||
|
# Don't run in subshells
|
||||||
|
[[ "$ZSH_SUBSHELL" -eq 0 ]] || return 0
|
||||||
|
pwd > ~/.last-working-dir
|
||||||
|
}
|
||||||
|
|
||||||
|
# Changes directory to the last working directory
|
||||||
|
lwd() {
|
||||||
|
if [[ -r ~/.last-working-dir ]]; then
|
||||||
|
lwd=$(cat ~/.last-working-dir)
|
||||||
|
cd $lwd
|
||||||
|
echo $lwd
|
||||||
|
fi
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user