Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/phatblat/shellexec

🐚 Gradle plugin with a simpler Exec task
https://github.com/phatblat/shellexec

bash exec gradle kotlin shell

Last synced: 3 months ago
JSON representation

🐚 Gradle plugin with a simpler Exec task

Awesome Lists containing this project

README

        

# ShellExec

A simpler extension point than [`Exec`](https://docs.gradle.org/current/dsl/org.gradle.api.tasks.Exec.html) for ad-hoc Gradle tasks that run shell commands.

## Features

- Specify entire `command` line in one string (instead of `List`).
- Append/prepend to the current `PATH`.
- Execute a `command | pipe` or `conditional && command || chain`.
- Easy access to `stdout` and `stderr`.

:warning: Not compatible with `Exec` tasks yet (see [#11](https://github.com/phatblat/ShellExec/issues/11)), but the current API is very similar.

## Example `build.gradle.kts`

```kts
import at.phatbl.shellexec.ShellExec

buildscript {
repositories.gradlePluginPortal()
dependencies.classpath("at.phatbl:shellexec:+")
}

val lolBoxFortune by registering(ShellExec::class) {
command = "fortune | boxes --design parchment --no-color | lolcat --force"
}
```

> Note that the `boxes` and `lolcat` tools need to be installed for the above `lolBoxFortune` to work.

### Task Output

```text
> Task :lolBoxFortune
____________
/\ \
\_| Ship it. |
| |
| _______|_
\_/_________/

BUILD SUCCESSFUL in 2s
1 actionable task: 1 executed
```

## License

This repo is licensed under the MIT License. See the [LICENSE](LICENSE.md) file for rights and limitations.