blob: e1f60eea5612b077de64fa866d31dd4cb45f80a7 (
plain) (
blame)
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
|
//! Example Error Handling
//!
//! > This example demonstrates how to handle errors in Mingling, including custom error types and error rendering.
//!
//! Run:
//! ```bash
//! cargo run --manifest-path examples/example-exitcode/Cargo.toml --quiet -- hello Alice
//! cargo run --manifest-path examples/example-exitcode/Cargo.toml --quiet -- hello
//! ```
//!
//! Output:
//! ```plaintext
//! Hello, Alice
//! No name provided (with exit code 1)
//! ```
use mingling::{prelude::*, res::ExitCode, setup::ExitCodeSetup};
fn main() {
let mut program = ThisProgram::new();
// --------- IMPORTANT ---------
// Register `ExitCodeSetup` for the program to enable exit codes
program.with_setup(ExitCodeSetup::default());
// --------- IMPORTANT ---------
program.with_dispatcher(CMDHello);
program.exec_and_exit();
}
dispatcher!("hello", CMDHello => EntryHello);
pack!(ErrorNoNameProvided = ());
pack!(ResultName = String);
#[chain]
fn handle_hello(args: EntryHello) -> Next {
let Some(name) = args.inner.first().cloned() else {
// If no name is provided, pass ErrorNoNameProvided
return ErrorNoNameProvided::default().to_render();
};
// If the name is valid, pass ResultName
ResultName::new(name).to_render()
}
/// Renders a successful greeting with the given name.
#[renderer]
fn render_result_name(name: ResultName) {
r_println!("Hello, {}", *name);
}
// Define renderer, render error message _____________ Inject exit code resource
// /
/// Renders the error when no name is provided |
#[renderer] // vvvvvvvvvvvvv
fn render_error_no_name_provided(_: ErrorNoNameProvided, ec: &mut ExitCode) {
ec.exit_code = 1;
// Prompt when no name is provided
r_println!("No name provided (with exit code 1)");
}
gen_program!();
|