1
0
mirror of https://github.com/ohmyzsh/ohmyzsh.git synced 2026-01-12 22:18:00 +08:00

Compare commits

...

3 Commits

Author SHA1 Message Date
Oleg Grigoriev
dab09cc0ee
feat(rake-fast): show task descriptions in autocomplete (#11653) 2023-05-02 12:27:57 +02:00
Carlo Sala
693e3dcc44
fix(apple): replace deprecated nerdfonts icon 2023-05-02 10:03:24 +02:00
Carlo Sala
b22593cf17 fix(init): avoid overwriting existing aliases
Fix regression introduced in #11550. If an existing alias was present in
the moment of sourcing, and oh-my-zsh aliases were disabled for that
file, it'd be overwritten aswell. See #11658.
2023-05-01 22:52:13 +02:00
3 changed files with 50 additions and 11 deletions

View File

@ -159,10 +159,10 @@ _omz_source() {
zstyle -T ":omz:${context}" aliases || disable_aliases=1
# Back up alias names prior to sourcing
local -a aliases_pre galiases_pre
local -A aliases_pre galiases_pre
if (( disable_aliases )); then
aliases_pre=("${(@k)aliases}")
galiases_pre=("${(@k)galiases}")
aliases_pre=("${(@kv)aliases}")
galiases_pre=("${(@kv)galiases}")
fi
# Source file from $ZSH_CUSTOM if it exists, otherwise from $ZSH
@ -174,10 +174,16 @@ _omz_source() {
# Unset all aliases that don't appear in the backed up list of aliases
if (( disable_aliases )); then
local -a disabled
# ${var:|array} gets the list of items in var not in array
disabled=("${(@k)aliases:|aliases_pre}" "${(@k)galiases:|galiases_pre}")
(( $#disabled == 0 )) || unalias "${(@)disabled}"
if (( #aliases_pre )); then
aliases=("${(@kv)aliases_pre}")
else
(( #aliases )) && unalias "${(@k)aliases}"
fi
if (( #galiases_pre )); then
galiases=("${(@kv)galiases_pre}")
else
(( #galiases )) && unalias "${(@k)galiases}"
fi
fi
}

View File

@ -1,5 +1,28 @@
# The version of the format of .rake_tasks. If the output of _rake_generate
# changes, incrementing this number will force it to regenerate
_rake_tasks_version=2
_rake_does_task_list_need_generating () {
[[ ! -f .rake_tasks ]] || [[ Rakefile -nt .rake_tasks ]] || { _is_rails_app && _tasks_changed }
_rake_tasks_missing || _rake_tasks_version_changed || _rakefile_has_changes || { _is_rails_app && _tasks_changed }
}
_rake_tasks_missing () {
[[ ! -f .rake_tasks ]]
}
_rake_tasks_version_changed () {
local -a file_version
file_version=`head -n 1 .rake_tasks | sed "s/^version\://"`
if ! [[ $file_version =~ '^[0-9]*$' ]]; then
return true
fi
[[ $file_version -ne $_rake_tasks_version ]]
}
_rakefile_has_changes () {
[[ Rakefile -nt .rake_tasks ]]
}
_is_rails_app () {
@ -20,7 +43,14 @@ _tasks_changed () {
}
_rake_generate () {
rake --silent --tasks | cut -d " " -f 2 | sed 's/\[.*\]//g' > .rake_tasks
echo "version:$_rake_tasks_version" > .rake_tasks
rake --silent --tasks --all \
| sed "s/^rake //" | sed "s/\:/\\\:/g" \
| sed "s/\[[^]]*\]//g" \
| sed "s/ *# /\:/" \
| sed "s/\:$//" \
>> .rake_tasks
}
_rake () {
@ -29,7 +59,10 @@ _rake () {
echo "\nGenerating .rake_tasks..." >&2
_rake_generate
fi
compadd $(cat .rake_tasks)
local -a rake_options
rake_options=("${(@f)$(cat .rake_tasks)}")
shift rake_options
_describe 'rake tasks' rake_options
fi
}
compdef _rake rake

View File

@ -1,5 +1,5 @@
function toon {
echo -n ""
echo -n "󰐀"
}
autoload -Uz vcs_info