From f411daceacad66e0bd774fda7d3c5ef8533cc55c Mon Sep 17 00:00:00 2001 From: nsfisis Date: Tue, 26 May 2026 20:04:02 +0900 Subject: refactor(io): share IOInterface via Rc> handle Co-Authored-By: Claude Opus 4.7 --- crates/shirabe/src/autoload/autoload_generator.rs | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) (limited to 'crates/shirabe/src/autoload/autoload_generator.rs') diff --git a/crates/shirabe/src/autoload/autoload_generator.rs b/crates/shirabe/src/autoload/autoload_generator.rs index 3786011..59cf6ae 100644 --- a/crates/shirabe/src/autoload/autoload_generator.rs +++ b/crates/shirabe/src/autoload/autoload_generator.rs @@ -25,6 +25,7 @@ use crate::filter::platform_requirement_filter::PlatformRequirementFilterFactory use crate::filter::platform_requirement_filter::PlatformRequirementFilterInterface; use crate::installer::InstallationManager; use crate::io::IOInterface; +use crate::io::IOInterfaceImmutable; use crate::io::NullIO; use crate::json::JsonFile; use crate::package::Locker; @@ -40,7 +41,7 @@ use crate::util::Platform; #[derive(Debug)] pub struct AutoloadGenerator { event_dispatcher: std::rc::Rc>, - io: Box, + io: std::rc::Rc>, dev_mode: Option, class_map_authoritative: bool, apcu: bool, @@ -53,9 +54,10 @@ pub struct AutoloadGenerator { impl AutoloadGenerator { pub fn new( event_dispatcher: std::rc::Rc>, - io: Option>, + io: Option>>, ) -> Self { - let io: Box = io.unwrap_or_else(|| Box::new(NullIO::new())); + let io: std::rc::Rc> = + io.unwrap_or_else(|| std::rc::Rc::new(std::cell::RefCell::new(NullIO::new()))); Self { event_dispatcher, -- cgit v1.3.1