Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tynanbe/shellout
🐢 A Gleam library for cross-platform shell operations
https://github.com/tynanbe/shellout
Last synced: 4 days ago
JSON representation
🐢 A Gleam library for cross-platform shell operations
- Host: GitHub
- URL: https://github.com/tynanbe/shellout
- Owner: tynanbe
- License: apache-2.0
- Created: 2021-01-25T23:18:10.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-02-12T20:30:00.000Z (12 months ago)
- Last Synced: 2024-11-21T16:26:56.041Z (2 months ago)
- Language: Gleam
- Homepage:
- Size: 143 KB
- Stars: 49
- Watchers: 2
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-gleam - shellout - [📚](https://hexdocs.pm/shellout/) - A Gleam library for cross-platform shell operations (Packages / Command Line)
README
# shellout 🐢
[![Hex Package](https://img.shields.io/hexpm/v/shellout?color=ffaff3&label&labelColor=2f2f2f&logo=)](https://hex.pm/packages/shellout)
[![Hex Docs](https://img.shields.io/badge/hex-docs-ffaff3?label&labelColor=2f2f2f&logo=)](https://hexdocs.pm/shellout/)
[![License](https://img.shields.io/hexpm/l/shellout?color=ffaff3&label&labelColor=2f2f2f&logo=)](https://github.com/tynanbe/shellout/blob/main/LICENSE)
[![Build](https://img.shields.io/github/actions/workflow/status/tynanbe/shellout/ci.yml?branch=main&color=ffaff3&label&labelColor=2f2f2f&logo=github-actions&logoColor=fefefc)](https://github.com/tynanbe/shellout/actions)A Gleam library for cross-platform shell operations.
## Usage
### Example
• In `my_project/src/my_project.gleam`
```gleam
import gleam/dict
import gleam/io
import gleam/result
import shellout.{type Lookups}pub const lookups: Lookups = [
#(
["color", "background"],
[
#("buttercup", ["252", "226", "174"]),
#("mint", ["182", "255", "234"]),
#("pink", ["255", "175", "243"]),
],
),
]pub fn main() {
shellout.arguments()
|> shellout.command(run: "ls", in: ".", opt: [])
|> result.map(with: fn(output) {
io.print(output)
0
})
|> result.map_error(with: fn(detail) {
let #(status, message) = detail
let style =
shellout.display(["bold", "italic"])
|> dict.merge(from: shellout.color(["pink"]))
|> dict.merge(from: shellout.background(["brightblack"]))
message
|> shellout.style(with: style, custom: lookups)
|> io.print_error
status
})
|> result.unwrap_both
|> shellout.exit
}
```### 🐚 You can test the above example with your shell!
• In your terminal
```shell
> cd my_project
> gleam run -- -lah
# ..
> gleam run -- --lah
# ..
> gleam run --target=javascript -- -lah
# ..
> gleam run --target=javascript -- --lah
# ..
```
## Installation
### As a dependency of your Gleam project
• Add `shellout` to `gleam.toml`
```shell
gleam add shellout
```### As a dependency of your Mix project
• Add `shellout` to `mix.exs`
```elixir
defp deps do
[
{:shellout, "~> 1.6"},
]
end
```### As a dependency of your Rebar3 project
• Add `shellout` to `rebar.config`
```erlang
{deps, [
{shellout, "1.6.0"}
]}.
```