summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOleg Grigoriev <mehanoid.ru@gmail.com>2023-05-02 13:27:57 +0300
committerGitHub <noreply@github.com>2023-05-02 12:27:57 +0200
commitdab09cc0eec220f5c1a541ccb75449c62c20bdb4 (patch)
tree3413a64a38796380d40a9431a2c0613b1a0ccb5f
parent693e3dcc447b5d6fa611eea43166ea2b4e0ed877 (diff)
downloadzsh-dab09cc0eec220f5c1a541ccb75449c62c20bdb4.tar.gz
zsh-dab09cc0eec220f5c1a541ccb75449c62c20bdb4.tar.bz2
zsh-dab09cc0eec220f5c1a541ccb75449c62c20bdb4.zip
feat(rake-fast): show task descriptions in autocomplete (#11653)
-rw-r--r--plugins/rake-fast/rake-fast.plugin.zsh39
1 files changed, 36 insertions, 3 deletions
diff --git a/plugins/rake-fast/rake-fast.plugin.zsh b/plugins/rake-fast/rake-fast.plugin.zsh
index 19dab154b..86e5ed586 100644
--- a/plugins/rake-fast/rake-fast.plugin.zsh
+++ b/plugins/rake-fast/rake-fast.plugin.zsh
@@ -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