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/perforce_driver.rs | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'crates/shirabe/src/repository/vcs/perforce_driver.rs') diff --git a/crates/shirabe/src/repository/vcs/perforce_driver.rs b/crates/shirabe/src/repository/vcs/perforce_driver.rs index 35da517..03948b3 100644 --- a/crates/shirabe/src/repository/vcs/perforce_driver.rs +++ b/crates/shirabe/src/repository/vcs/perforce_driver.rs @@ -77,7 +77,7 @@ impl PerforceDriver { self.inner.url.clone(), repo_dir, self.inner.process.clone(), - self.inner.io.clone_box(), + self.inner.io.clone(), )); Ok(()) @@ -167,9 +167,14 @@ impl PerforceDriver { .into()) } - pub fn supports(io: &dyn IOInterface, _config: &Config, url: &str, deep: bool) -> bool { + pub fn supports( + io: std::rc::Rc>, + _config: &Config, + url: &str, + deep: bool, + ) -> bool { if deep || Preg::is_match(r"#\b(perforce|p4)\b#i", url).unwrap_or(false) { - return Perforce::check_server_exists(url, &mut ProcessExecutor::new(io)); + return Perforce::check_server_exists(url, &mut ProcessExecutor::new(Some(io))); } false } -- cgit v1.3.1