mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2026-01-21 00:57:24 +08:00
Compare commits
3 Commits
2e7a247cab
...
dab09cc0ee
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
dab09cc0ee | ||
|
|
693e3dcc44 | ||
|
|
b22593cf17 |
20
oh-my-zsh.sh
20
oh-my-zsh.sh
@ -159,10 +159,10 @@ _omz_source() {
|
|||||||
zstyle -T ":omz:${context}" aliases || disable_aliases=1
|
zstyle -T ":omz:${context}" aliases || disable_aliases=1
|
||||||
|
|
||||||
# Back up alias names prior to sourcing
|
# Back up alias names prior to sourcing
|
||||||
local -a aliases_pre galiases_pre
|
local -A aliases_pre galiases_pre
|
||||||
if (( disable_aliases )); then
|
if (( disable_aliases )); then
|
||||||
aliases_pre=("${(@k)aliases}")
|
aliases_pre=("${(@kv)aliases}")
|
||||||
galiases_pre=("${(@k)galiases}")
|
galiases_pre=("${(@kv)galiases}")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Source file from $ZSH_CUSTOM if it exists, otherwise from $ZSH
|
# 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
|
# Unset all aliases that don't appear in the backed up list of aliases
|
||||||
if (( disable_aliases )); then
|
if (( disable_aliases )); then
|
||||||
local -a disabled
|
if (( #aliases_pre )); then
|
||||||
# ${var:|array} gets the list of items in var not in array
|
aliases=("${(@kv)aliases_pre}")
|
||||||
disabled=("${(@k)aliases:|aliases_pre}" "${(@k)galiases:|galiases_pre}")
|
else
|
||||||
(( $#disabled == 0 )) || unalias "${(@)disabled}"
|
(( #aliases )) && unalias "${(@k)aliases}"
|
||||||
|
fi
|
||||||
|
if (( #galiases_pre )); then
|
||||||
|
galiases=("${(@kv)galiases_pre}")
|
||||||
|
else
|
||||||
|
(( #galiases )) && unalias "${(@k)galiases}"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -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 () {
|
_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 () {
|
_is_rails_app () {
|
||||||
@ -20,7 +43,14 @@ _tasks_changed () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_rake_generate () {
|
_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 () {
|
_rake () {
|
||||||
@ -29,7 +59,10 @@ _rake () {
|
|||||||
echo "\nGenerating .rake_tasks..." >&2
|
echo "\nGenerating .rake_tasks..." >&2
|
||||||
_rake_generate
|
_rake_generate
|
||||||
fi
|
fi
|
||||||
compadd $(cat .rake_tasks)
|
local -a rake_options
|
||||||
|
rake_options=("${(@f)$(cat .rake_tasks)}")
|
||||||
|
shift rake_options
|
||||||
|
_describe 'rake tasks' rake_options
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
compdef _rake rake
|
compdef _rake rake
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
function toon {
|
function toon {
|
||||||
echo -n ""
|
echo -n ""
|
||||||
}
|
}
|
||||||
|
|
||||||
autoload -Uz vcs_info
|
autoload -Uz vcs_info
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user