You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Go to file
Taiki Endo 99b9abc536
Minimize GITHUB_TOKEN permissions
6 days ago
.github Minimize GITHUB_TOKEN permissions 6 days ago
examples ex: Add example for timed out process (#38) 2 weeks ago
src Add windows::CommandExt::raw_arg on Rust 1.62+ 3 months ago
tests Fix clippy::needless_borrow warning 3 months ago
.gitignore Initial commit 3 years ago
CHANGELOG.md Release 1.6.0 4 months ago
Cargo.toml ex: Add example for timed out process (#38) 2 weeks ago
LICENSE-APACHE Initial version 3 years ago
LICENSE-MIT Initial version 3 years ago
README.md Update license badge to match Cargo.toml 2 years ago
build.rs Add windows::CommandExt::raw_arg on Rust 1.62+ 3 months ago

README.md

async-process

Build License Cargo Documentation

Async interface for working with processes.

This crate is an async version of std::process.

Implementation

A background thread named "async-process" is lazily created on first use, which waits for spawned child processes to exit and then calls the wait() syscall to clean up the "zombie" processes. This is unlike the process API in the standard library, where dropping a running Child leaks its resources.

This crate uses async-io for async I/O on Unix-like systems and blocking for async I/O on Windows.

Examples

Spawn a process and collect its output:

use async_process::Command;

let out = Command::new("echo").arg("hello").arg("world").output().await?;
assert_eq!(out.stdout, b"hello world\n");

Read the output line-by-line as it gets produced:

use async_process::{Command, Stdio};
use futures_lite::{io::BufReader, prelude::*};

let mut child = Command::new("find")
    .arg(".")
    .stdout(Stdio::piped())
    .spawn()?;

let mut lines = BufReader::new(child.stdout.take().unwrap()).lines();

while let Some(line) = lines.next().await {
    println!("{}", line?);
}

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.