From 95c6b979ca399671eed8bf9c72f53cfe5d46f431 Mon Sep 17 00:00:00 2001 From: Weicao-CatilGrass <1992414357@qq.com> Date: Wed, 13 May 2026 07:28:02 +0800 Subject: Migrate exit code control to resource-based system --- mingling/src/setups/exit_code.rs | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 mingling/src/setups/exit_code.rs (limited to 'mingling/src/setups/exit_code.rs') diff --git a/mingling/src/setups/exit_code.rs b/mingling/src/setups/exit_code.rs new file mode 100644 index 0000000..3267f85 --- /dev/null +++ b/mingling/src/setups/exit_code.rs @@ -0,0 +1,40 @@ +use std::marker::PhantomData; + +use mingling_core::{ProgramCollect, hook::ProgramHook, setup::ProgramSetup, this}; + +use crate::res::ExitCode; + +/// Provides the ability to control the program's exit code, which is returned when the program ends. +/// +/// - Use `mingling::update_exit_code` to update the exit code. +/// - Use `mingling::current_exit_code` to query the current exit code. +pub struct ExitCodeSetup { + _collect: PhantomData, +} + +impl Default for ExitCodeSetup +where + C: ProgramCollect + 'static, +{ + fn default() -> Self { + Self { + _collect: Default::default(), + } + } +} + +impl ProgramSetup for ExitCodeSetup +where + C: ProgramCollect + 'static, +{ + fn setup(&mut self, program: &mut crate::Program) { + // Insert resource + program.with_resource(ExitCode { exit_code: 0 }); + + // Insert hook to override exit code before program ends + program.with_hook(ProgramHook::empty().on_finish(|| { + let this = this::().res_or_default(); + *this + })); + } +} -- cgit