aboutsummaryrefslogtreecommitdiff
path: root/examples/example-panic-unwind/src
diff options
context:
space:
mode:
authorWeicao-CatilGrass <1992414357@qq.com>2026-05-23 23:41:04 +0800
committerWeicao-CatilGrass <1992414357@qq.com>2026-05-23 23:49:34 +0800
commit0a2ef958c0dca21d19e4ffc38ba5a7c4078e182a (patch)
treec82fc4242ed393b132ba514eb434d722e7d9c387 /examples/example-panic-unwind/src
parentccab1940c019dfbfb7dfcbbe4cb927258933755f (diff)
Rework examples and add entry macro for testing
Diffstat (limited to 'examples/example-panic-unwind/src')
-rw-r--r--examples/example-panic-unwind/src/main.rs56
1 files changed, 56 insertions, 0 deletions
diff --git a/examples/example-panic-unwind/src/main.rs b/examples/example-panic-unwind/src/main.rs
new file mode 100644
index 0000000..18cf4d6
--- /dev/null
+++ b/examples/example-panic-unwind/src/main.rs
@@ -0,0 +1,56 @@
+//! Example Panic Unwind
+//!
+//! > This example introduces how to catch Panic in the Mingling program loop
+//!
+//! Run:
+//! ```bash
+//! cargo run --manifest-path examples/example-panic-unwind/Cargo.toml --quiet -- panic
+//! cargo run --manifest-path examples/example-panic-unwind/Cargo.toml --quiet -- panic OhMyGod
+//! ```
+//!
+//! Output:
+//! ```plaintext
+//! Program not panic
+//! Program panic: OhMyGod
+//! OhMyGod
+//! ```
+
+use mingling::{hook::ProgramHook, prelude::*};
+
+dispatcher!("panic", CMDPanic => EntryPanic);
+pack!(NotPanic = ());
+
+fn main() {
+ let mut program = ThisProgram::new();
+ program.with_dispatcher(CMDPanic);
+
+ // --------- IMPORTANT ---------
+ // Enable silence_panic to suppress automatic Panic output
+ program.stdout_setting.silence_panic = true;
+
+ // Define a hook to output &ProgramPanic when a Panic occurs
+ program
+ .with_hook(ProgramHook::empty().on_exec_panic(|info| println!("Program panic: {}", info)));
+ // --------- IMPORTANT ---------
+
+ program.exec();
+}
+
+#[chain]
+fn handle_panic(prev: EntryPanic) -> Next {
+ let panic_info = prev.pick::<Option<String>>(()).unpack();
+ match panic_info {
+ Some(s) => {
+ // Panic happens here, will be caught
+ panic!("{}", s)
+ }
+ None => NotPanic::default(),
+ }
+}
+
+#[renderer]
+fn render(_: NotPanic) {
+ r_println!("Program not panic");
+}
+
+gen_program!();