diff options
| author | navewindre <boneyaard@gmail.com> | 2025-07-13 06:42:05 +0200 |
|---|---|---|
| committer | navewindre <boneyaard@gmail.com> | 2025-07-13 06:42:05 +0200 |
| commit | 02f14a9cb152561a5e44062aac79f3b700403b40 (patch) | |
| tree | 2db8ebda3b7f6f8777783aeb5c60018e6e1359d8 /home/.oh-my-zsh/plugins/gradle/gradle.plugin.zsh | |
| parent | cbbdeb2f6b40a102a829f0c47cff052937231f00 (diff) | |
omz
Diffstat (limited to 'home/.oh-my-zsh/plugins/gradle/gradle.plugin.zsh')
| -rw-r--r-- | home/.oh-my-zsh/plugins/gradle/gradle.plugin.zsh | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/home/.oh-my-zsh/plugins/gradle/gradle.plugin.zsh b/home/.oh-my-zsh/plugins/gradle/gradle.plugin.zsh new file mode 100644 index 0000000..dacc464 --- /dev/null +++ b/home/.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 [[ -x "$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 |
