#shell-completion #installer #command-line #build-tool

build package-bootstrap

An embeddable solution for installing build artifacts

9 unstable releases (3 breaking)

0.4.0 Jan 19, 2024
0.3.2 Jun 2, 2023
0.3.0 May 7, 2023
0.2.1 May 5, 2023
0.1.2 Mar 30, 2023

#322 in Build Utils


Used in gfret

GPL-3.0-only

18KB
272 lines

Contents

About

Package bootstrap is an embeddable installer for Rust binaries that allows the reuse of the code in your project to generate shell completions, manpages and other artifacts and install them into directories appropriate for a Unix system.

Usage

# Cargo.toml
[[bin]]
name = "bootstrap"
path = "src/bootstrap.rs

[dependencies.package_bootstrap]
version = "0.1"
features = ["complete", "mangen"]
// bootstrap.rs
use clap::Command;
use package_bootstrap::Bootstrap;

fn main() -> Result<(), Box<dyn std::error::Error>> {
    let cmd = Command::new("foo")
        .about("manage all of your bars");

    let bootstrap = Bootstrap::new("foo", cmd);
    bootstrap.install(Path::new("pkg/usr", 1)?;
}

With a little extra setup, bootstrap can use the same function as your binary to generate the clap::Command struct.

# Cargo.toml
[workspace]
members = "cli"

[workspace.dependencies]
clap = 4.1
cli = { path = "cli" }
// cli/src/lib.rs
pub fn cli() -> clap::Command {
    Command::new("foo")
        .about("Handle all of your bars")
}

Features

  • default: complete - generates and installs shell completions from your clap::Command struct
  • mangen: - generates and installs a Unix manual page from your clap::Command struct

Supported shells:

  • bash
  • elvish
  • fish
  • nushell
  • powershell
  • zsh

Dependencies

~0–0.8MB
~17K SLoC