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/repository/vcs_repository.rs | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) (limited to 'crates/shirabe/src/repository/vcs_repository.rs') diff --git a/crates/shirabe/src/repository/vcs_repository.rs b/crates/shirabe/src/repository/vcs_repository.rs index a256fb8..804ba51 100644 --- a/crates/shirabe/src/repository/vcs_repository.rs +++ b/crates/shirabe/src/repository/vcs_repository.rs @@ -15,6 +15,7 @@ use crate::config::Config; use crate::downloader::TransportException; use crate::event_dispatcher::EventDispatcher; use crate::io::IOInterface; +use crate::io::IOInterfaceImmutable; use crate::package::loader::ArrayLoader; use crate::package::loader::InvalidPackageException; use crate::package::loader::LoaderInterface; @@ -43,7 +44,7 @@ pub struct VcsRepository { /// @var bool pub(crate) is_very_verbose: bool, /// @var IOInterface - pub(crate) io: Box, + pub(crate) io: std::rc::Rc>, /// @var Config pub(crate) config: std::rc::Rc>, /// @var VersionParser @@ -87,7 +88,7 @@ impl VcsRepository { /// @param array>|null $drivers pub fn new( mut repo_config: IndexMap, - io: Box, + io: std::rc::Rc>, config: std::rc::Rc>, http_downloader: std::rc::Rc>, dispatcher: Option>>, @@ -158,7 +159,7 @@ impl VcsRepository { let is_very_verbose = io.is_very_verbose(); let process_executor = process.unwrap_or_else(|| { std::rc::Rc::new(std::cell::RefCell::new(ProcessExecutor::new(Some( - io.clone_box(), + io.clone(), )))) }); -- cgit v1.3.1