cradle

Crates.iocradle
lib.rscradle
version0.2.2
sourcesrc
created_at2021-06-01 17:06:27.206019
updated_at2022-05-03 08:51:49.020022
descriptionExecute child processes with ease
homepagehttps://github.com/soenkehahn/cradle
repositoryhttps://github.com/soenkehahn/cradle
max_upload_size
id404820
size136,667
Sönke Hahn (soenkehahn)

documentation

README

ci status badge crates.io docs

cradle is a library for executing child processes. It provides a more convenient interface than std::process::Command. Here's an example:

use cradle::prelude::*;

fn main() {
    // output git version
    run!(%"git --version");
    // output configured git user
    let (StdoutTrimmed(git_user), Status(status)) = run_output!(%"git config --get user.name");
    if status.success() {
        eprintln!("git user: {}", git_user);
    } else {
        eprintln!("git user not configured");
    }
}

For comprehensive documentation, head over to docs.rs/cradle.

Design Goals

cradle is meant to make it as easy as possible to run child processes, while making it hard to use incorrectly. As such it provides an interface that is concise and flexible, and tries to avoid surprising behavior.

cradle does not try to emulate the syntax or functionality of bash or other shells, such as pipes (|), globs (*), or other string expansion. Instead, it aims to be a convenient wrapper around the operating system's interface for running child processes.

MSRV

The minimal supported rust version is 0.41.

Commit count: 148

cargo fmt