diff options
author | 2022-10-03 21:42:20 +0530 | |
---|---|---|
committer | 2022-10-03 21:42:20 +0530 | |
commit | af120ab348f2e1a5a39dec035ed9dcf84189a64e (patch) | |
tree | 2a3aadd7ce1b7b771dfe3fe7c983569726c8d7ed /zsh/oh-my-zsh/plugins/gradle/gradle.plugin.zsh | |
download | dotfiles-af120ab348f2e1a5a39dec035ed9dcf84189a64e.tar.gz dotfiles-af120ab348f2e1a5a39dec035ed9dcf84189a64e.tar.bz2 dotfiles-af120ab348f2e1a5a39dec035ed9dcf84189a64e.zip |
dotfiles
Diffstat (limited to 'zsh/oh-my-zsh/plugins/gradle/gradle.plugin.zsh')
-rw-r--r-- | zsh/oh-my-zsh/plugins/gradle/gradle.plugin.zsh | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/zsh/oh-my-zsh/plugins/gradle/gradle.plugin.zsh b/zsh/oh-my-zsh/plugins/gradle/gradle.plugin.zsh new file mode 100644 index 0000000..5bca364 --- /dev/null +++ b/zsh/oh-my-zsh/plugins/gradle/gradle.plugin.zsh @@ -0,0 +1,26 @@ +# Looks for a gradlew file in the current working directory +# or any of its parent directories, and executes it if found. +# Otherwise it will call gradle directly. +function gradle-or-gradlew() { + # find project root + # taken from https://github.com/gradle/gradle-completion + local dir="$PWD" project_root="$PWD" + while [[ "$dir" != / ]]; do + if [[ -f "$dir/settings.gradle" || -f "$dir/settings.gradle.kts" || -f "$dir/gradlew" ]]; then + project_root="$dir" + break + fi + dir="${dir:h}" + done + + # if gradlew found, run it instead of gradle + if [[ -f "$project_root/gradlew" ]]; then + echo "executing gradlew instead of gradle" + "$project_root/gradlew" "$@" + else + command gradle "$@" + fi +} + +alias gradle=gradle-or-gradlew +compdef _gradle gradle-or-gradlew |