From 2eba732e17cf71dcf8a54b428a1c5e344582c2c2 Mon Sep 17 00:00:00 2001 From: 魏曹先生 <1992414357@qq.com> Date: Sat, 9 May 2026 17:37:37 +0800 Subject: Add exit code control and hook lifecycle features --- mingling_core/src/program/hook.rs | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) (limited to 'mingling_core/src/program/hook.rs') diff --git a/mingling_core/src/program/hook.rs b/mingling_core/src/program/hook.rs index d422e12..edbf996 100644 --- a/mingling_core/src/program/hook.rs +++ b/mingling_core/src/program/hook.rs @@ -56,7 +56,18 @@ pub struct ProgramAnonymousHook { pub post_render: Option, /// Executes before the program ends - pub finish: Option, + pub finish: Option i32>, +} + +impl Program +where + C: ProgramCollect, +{ + /// Adds an anonymous hook to the program. The hook will be called at the appropriate + /// lifecycle events, but receives string representations instead of typed references. + pub fn with_hook_anonymous(&mut self, hook: ProgramAnonymousHook) { + self.anonymous_hooks.push(hook); + } } impl Program @@ -69,12 +80,6 @@ where self.hooks.push(hook); } - /// Adds an anonymous hook to the program. The hook will be called at the appropriate - /// lifecycle events, but receives string representations instead of typed references. - pub fn with_hook_anonymous(&mut self, hook: ProgramAnonymousHook) { - self.anonymous_hooks.push(hook); - } - pub(crate) fn run_hook_on_begin(&self) { if !self.user_context.run_hook { return; @@ -342,7 +347,7 @@ impl ProgramAnonymousHook { } /// Sets the handler for the `finish` event. - pub fn on_finish(mut self, handler: fn()) -> Self { + pub fn on_finish(mut self, handler: fn() -> i32) -> Self { let _ = self.finish.insert(handler); self } -- cgit