From 1921f173ea219cb4b25847294d2d3fa465550fbb Mon Sep 17 00:00:00 2001 From: nsfisis Date: Mon, 25 May 2026 00:58:20 +0900 Subject: refactor(package): introduce Rc> handles for packages PHP packages have reference semantics, so introduce shared-ownership handles over an AnyPackage enum (PackageInterfaceHandle and friends) and replace Box throughout. Co-Authored-By: Claude Opus 4.7 (1M context) --- .../src/repository/installed_array_repository.rs | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) (limited to 'crates/shirabe/src/repository/installed_array_repository.rs') diff --git a/crates/shirabe/src/repository/installed_array_repository.rs b/crates/shirabe/src/repository/installed_array_repository.rs index b089df6..f0244b6 100644 --- a/crates/shirabe/src/repository/installed_array_repository.rs +++ b/crates/shirabe/src/repository/installed_array_repository.rs @@ -4,8 +4,9 @@ use indexmap::IndexMap; use shirabe_php_shim::Countable; use shirabe_semver::constraint::AnyConstraint; -use crate::package::BasePackage; +use crate::package::BasePackageHandle; use crate::package::PackageInterface; +use crate::package::PackageInterfaceHandle; use crate::repository::AdvisoryProviderInterface; use crate::repository::InstalledRepositoryInterface; use crate::repository::WritableArrayRepository; @@ -24,7 +25,7 @@ impl InstalledArrayRepository { Self::new_with_packages(Vec::new()) } - pub fn new_with_packages(packages: Vec>) -> anyhow::Result { + pub fn new_with_packages(packages: Vec) -> anyhow::Result { Ok(Self { inner: WritableArrayRepository::new(packages)?, }) @@ -56,7 +57,7 @@ impl WritableRepositoryInterface for InstalledArrayRepository { fn add_package( &mut self, - package: Box, + package: crate::package::PackageInterfaceHandle, ) -> anyhow::Result<()> { todo!() } @@ -68,7 +69,7 @@ impl WritableRepositoryInterface for InstalledArrayRepository { todo!() } - fn get_canonical_packages(&self) -> Vec> { + fn get_canonical_packages(&self) -> Vec { todo!() } @@ -99,17 +100,17 @@ impl RepositoryInterface for InstalledArrayRepository { &self, _name: &str, _constraint: FindPackageConstraint, - ) -> Option> { + ) -> Option { todo!() } fn find_packages( &self, _name: &str, _constraint: Option, - ) -> Vec> { + ) -> Vec { todo!() } - fn get_packages(&self) -> Vec> { + fn get_packages(&self) -> Vec { todo!() } fn load_packages( @@ -117,7 +118,7 @@ impl RepositoryInterface for InstalledArrayRepository { _package_name_map: IndexMap>, _acceptable_stabilities: IndexMap, _stability_flags: IndexMap, - _already_loaded: IndexMap>>, + _already_loaded: IndexMap>, ) -> LoadPackagesResult { todo!() } -- cgit v1.3.1