aboutsummaryrefslogtreecommitdiff
path: root/examples/example-hook/src/main.rs
blob: d6a2dd0e65591b1a54c14f1511531f7126b5f4ef (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
65
66
67
68
69
70
71
72
//! Example Hook
//!
//! > This example demonstrates how to use Mingling's hook system to obtain debugging information during program execution
//!
//! Run:
//! ```base
//! cargo run --manifest-path examples/example-hook/Cargo.toml --quiet -- greet Alice
//! ```
//!
//! Output:
//! ```plaintext
//! [DEBUG] Program is begin
//! [DEBUG] Pre dispatch: ["greet", "Alice"]
//! [DEBUG] Post dispatch: EntryGreet
//! [DEBUG] Pre chain: EntryGreet
//! [DEBUG] Post chain: ResultName
//! [DEBUG] Pre render: ResultName
//! [DEBUG] Post render
//! [DEBUG] Program end
//! Hello, Alice!
//! ```

use mingling::{hook::ProgramHook, prelude::*};

dispatcher!("greet", CMDGreet => EntryGreet);

fn main() {
    let mut program = ThisProgram::new();

    // --------- IMPORTANT ---------
    program.with_hook(
        ProgramHook::<ThisProgram>::empty()
            .on_begin(|| println!("[DEBUG] Program is begin"))
            .on_pre_dispatch(|args| println!("[DEBUG] Pre dispatch: {args:?}"))
            .on_post_dispatch(|c: &_| println!("[DEBUG] Post dispatch: {c:?}"))
            .on_pre_chain(|c: &_, _| {
                println!("[DEBUG] Pre chain: {c}");
            })
            .on_post_chain(|any_output| println!("[DEBUG] Post chain: {}", any_output.member_id))
            .on_finish(|| {
                println!("[DEBUG] Loop end");
                0 // Override exit code
            })
            .on_pre_render(|c: &_, _| println!("[DEBUG] Pre render: {c}"))
            .on_post_render(|_| println!("[DEBUG] Post render")),
    );
    // --------- IMPORTANT ---------

    program.with_dispatcher(CMDGreet);
    program.exec_and_exit();
}

pack!(ResultName = String);

#[chain]
fn handle_greet(args: EntryGreet) -> Next {
    let name: ResultName = args
        .inner
        .first()
        .cloned()
        .unwrap_or_else(|| "World".to_string())
        .into();
    name
}

/// Renders the greeting message with the provided name.
#[renderer]
fn render_name(name: ResultName) {
    r_println!("Hello, {}!", *name);
}

gen_program!();