1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
//! # macros
//!
//! Defines the library macros
//!
/// Enables to invoke the run_script::run function more easily without providing all input.
///
/// # Arguments
///
/// * `script` - The script content
/// * `args` - Optional, script command line arguments. If provided, the last options argument must also be provided.
/// * `options` - Optional, options provided to the script runner
///
/// # Examples
///
/// ```rust
/// #[macro_use]
/// extern crate run_script;
///
/// use run_script::ScriptOptions;
///
/// fn main() {
/// // simple call to run script with only the script text
/// let (code, output, error) = run_script!(
/// r#"
/// echo "Test"
/// exit 0
/// "#
/// ).unwrap();
///
/// // run script invoked with the script text and options
/// let options = ScriptOptions::new();
/// let (code, output, error) = run_script!(
/// r#"
/// echo "Test"
/// exit 0
/// "#,
/// &options
/// ).unwrap();
///
/// // run script invoked with all arguments
/// let options = ScriptOptions::new();
/// let (code, output, error) = run_script!(
/// r#"
/// echo "Test"
/// exit 0
/// "#,
/// &vec!["ARG1".to_string(), "ARG2".to_string()],
/// &options
/// ).unwrap();
/// }
/// ```