# shell-words Process command line according to parsing rules of Unix shell. ## Usage Add this to Cargo.toml: ```toml [dependencies] shell-words = "1.0.0" ``` Add this to your crate: ```rust extern crate shell_words; ``` ## Examples ### Split Compiling C source code into an executable as in default build rule found in GNU Make: ```rust extern crate shell_words; use std::env::var; use std::process::Command; fn main() { let cc = var("CC").unwrap_or_else(|_| "cc".to_owned()); let cflags = var("CFLAGS").unwrap_or_else(|_| String::new()); let cflags = shell_words::split(&cflags).expect("failed to parse CFLAGS"); let cppflags = var("CPPFLAGS").unwrap_or_else(|_| String::new()); let cppflags = shell_words::split(&cppflags).expect("failed to parse CPPFLAGS"); Command::new(cc) .args(cflags) .args(cppflags) .args(&["-c", "a.c", "-o", "a.out"]) .spawn() .expect("failed to start subprocess") .wait() .expect("failed to wait for subprocess"); } ``` ### Join Logging executed commands in format that can be readily copied and pasted to a shell: ```rust extern crate shell_words; fn main() { let argv = &["python", "-c", "print('Hello world!')"]; println!("Executing: {}", shell_words::join(argv)); std::process::Command::new(&argv[0]) .args(&argv[1..]) .spawn() .expect("failed to start subprocess") .wait() .expect("failed to wait for subprocess"); } ``` ## Bugs Please report any issues at https://github.com/tmiasko/shell-words/issues. ## License Licensed under either of * Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0) * MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) 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.