diff options
author | 2025-02-13 14:13:49 +0530 | |
---|---|---|
committer | 2025-02-13 14:13:49 +0530 | |
commit | 8a2e1006b3b272126332aa064f3ad95387129544 (patch) | |
tree | 944c80ac612a65980d94a54ba11b6c7102037ecf /.config/zsh/oh-my-zsh/plugins/mix-fast | |
parent | dcbb16d8b08ff5956abef5e6478b59df2e93ad35 (diff) | |
download | dotfiles-master.tar.gz dotfiles-master.tar.bz2 dotfiles-master.zip |
Diffstat (limited to '.config/zsh/oh-my-zsh/plugins/mix-fast')
-rw-r--r-- | .config/zsh/oh-my-zsh/plugins/mix-fast/README.md | 28 | ||||
-rw-r--r-- | .config/zsh/oh-my-zsh/plugins/mix-fast/mix-fast.plugin.zsh | 30 |
2 files changed, 58 insertions, 0 deletions
diff --git a/.config/zsh/oh-my-zsh/plugins/mix-fast/README.md b/.config/zsh/oh-my-zsh/plugins/mix-fast/README.md new file mode 100644 index 0000000..644f124 --- /dev/null +++ b/.config/zsh/oh-my-zsh/plugins/mix-fast/README.md @@ -0,0 +1,28 @@ +# mix-fast + +Fast mix autocompletion plugin. + +This script caches the output for later usage and significantly speeds it up. +It generates a .mix_tasks cache file for current project. Currently if you want +to update cache you should remove .mix_tasks file + +Inspired by and based on rake-fast zsh plugin. + +This is entirely based on [this pull request by Ullrich Schäfer](https://github.com/robb/.dotfiles/pull/10/), which is inspired by [this Ruby on Rails trick from 2006](https://weblog.rubyonrails.org/2006/3/9/fast-rake-task-completion-for-zsh/). + + +## Installation + +Just add the plugin to your `.zshrc`: + +```bash +plugins=(foo bar mix-fast) +``` + +You might consider adding `.mix_tasks` to your [global .gitignore](https://help.github.com/articles/ignoring-files#global-gitignore) + +## Usage + +`mix`, then press tab + +Currently maintained by [styx](https://github.com/styx/) diff --git a/.config/zsh/oh-my-zsh/plugins/mix-fast/mix-fast.plugin.zsh b/.config/zsh/oh-my-zsh/plugins/mix-fast/mix-fast.plugin.zsh new file mode 100644 index 0000000..564c505 --- /dev/null +++ b/.config/zsh/oh-my-zsh/plugins/mix-fast/mix-fast.plugin.zsh @@ -0,0 +1,30 @@ +_mix_refresh () { + if [ -f .mix_tasks ]; then + rm .mix_tasks + fi + echo "Generating .mix_tasks..." > /dev/stderr + _mix_generate + cat .mix_tasks +} + +_mix_does_task_list_need_generating () { + [ ! -f .mix_tasks ]; +} + +_mix_generate () { + mix help | grep '^mix [^ ]' | sed -E "s/mix ([^ ]*) *# (.*)/\1:\2/" > .mix_tasks +} + +_mix () { + if [ -f mix.exs ]; then + if _mix_does_task_list_need_generating; then + echo "\nGenerating .mix_tasks..." > /dev/stderr + _mix_generate + fi + local tasks=(${(f)"$(cat .mix_tasks)"}) + _describe 'tasks' tasks + fi +} + +compdef _mix mix +alias mix_refresh='_mix_refresh' |