#command-runner #orchestration #version

app awesome-cli

A command runner designed to streamline command orchestration

5 releases

0.1.1 Jun 2, 2024
0.1.0 May 8, 2024
0.1.0-beta.1 Mar 4, 2024
0.0.1 Jan 10, 2024

#847 in Command line utilities

MIT/Apache

29KB
634 lines

IMPORTANT Deprecated: Use arun

This is deprecated. The new crate is arun.

arun is the maintained version. It provides the lib arun that can be embedded in code, or the CLI arun-cli which uses the lib.




For history only (DO NOT USE, use )

DISCLAIMER: Version 0.1.x is still a work in progress and might see some changes. Awesome-cli will follow semver more strictly for version 0.2.x and onwards.

awesome-cli allows you to describe a set of commands as either groups or individually, and run them accordingly.

The configuration file is named Awesome.toml and should be located in the same directory as this file.

A Runner is a command description that can be executed by awesome-cli.

There are two types of "Runners":

  • Grouped Runners

    • Described with the [[runners._group_name_]] TOML array of tables for each group name (e.g., [[runners.dev]]).
    • Group execution: When invoking awesome _group_name_ (e.g., awesome dev), all the runners in this group will be executed in the order they are listed in the file.
    • Individual execution: Dot notation can be used to execute only one runner in a group with awesome _group_name_._runner_name (e.g., awesome dev.cargo_build).
    • Constraint: Runner names in a group must be unique within that group.
  • Solo Runner

    • Described with the [[runner]] TOML array of tables, where each runner has a name or ref property.
    • These can be called with awesome _runner_name (e.g., awesome list_files).
    • Constraint: Solo runner names must be unique and cannot overlap with group names.

Example

# Solo Runner 
[[runner]]
name = "list_files"
cmd = "ls"
args = ["-ll"]

[[runner]]
name = "list_files_human"
cmd = "ls"
args = ["-llh"]

[[runners.build]]
name = "tauri_icons"
working_dir = "crates/app-desktop/"
when.no_file_at = "icons/32x32.png"
cmd = "cargo"
args = ["tauri", "icon", "icons/app-icon.png"]

[[runners.build]]
name = "cargo_build"
working_dir = "crates/app-desktop/"
cmd = "cargo"
args = ["build"]

[[runners.build]]
name = "pcss"
working_dir = "frontend/"
cmd = "npm"
args = ["run", "pcss"]


# Now: runners, can ref other runner (only one hop for now)

[[runners.dev]]
ref = "build.tauri_icons"

[[runners.dev]]
ref = "build.pcss"
# The args from the target will be extended with the args_add items
args_add = ["--", "-w"]
# will run concurrently
concurrent = true 
# if this process exit, end the dev session
end_all_on_exit = true

Then we can just run like so:

  • awesome build - Will run all of the runners.build in order
  • awesome dev - Will run all runnders.dev in order
  • awesome build.tauri_icons - Will only run tauri icons command
  • awesome list_files - Will execute the solo runner named list_files

This repo on GitHub

Dependencies

~7–33MB
~496K SLoC