aboutsummaryrefslogtreecommitdiffhomepage
path: root/crates/shirabe/src/repository/composite_repository.rs
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2026-05-20 08:33:49 +0900
committernsfisis <nsfisis@gmail.com>2026-05-20 08:33:57 +0900
commitf31b101ce1e921a026ba234b1f0a83b0392bc118 (patch)
treeb7ac2aa84d71ebd162cc21aeab0240e7e0544988 /crates/shirabe/src/repository/composite_repository.rs
parent5e31fa33c3b5cf726a57a063b8e7a070869250fe (diff)
downloadphp-shirabe-f31b101ce1e921a026ba234b1f0a83b0392bc118.tar.gz
php-shirabe-f31b101ce1e921a026ba234b1f0a83b0392bc118.tar.zst
php-shirabe-f31b101ce1e921a026ba234b1f0a83b0392bc118.zip
fix(compile): fix all remaining compile errors
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Diffstat (limited to 'crates/shirabe/src/repository/composite_repository.rs')
-rw-r--r--crates/shirabe/src/repository/composite_repository.rs23
1 files changed, 21 insertions, 2 deletions
diff --git a/crates/shirabe/src/repository/composite_repository.rs b/crates/shirabe/src/repository/composite_repository.rs
index d956cdd..2c26469 100644
--- a/crates/shirabe/src/repository/composite_repository.rs
+++ b/crates/shirabe/src/repository/composite_repository.rs
@@ -120,11 +120,30 @@ impl RepositoryInterface for CompositeRepository {
let mut all_names_found = vec![];
for repository in &self.repositories {
+ // TODO(phase-b): manual deep clone since trait objects in maps don't derive Clone.
+ let name_map_cloned: IndexMap<String, Option<Box<dyn ConstraintInterface>>> =
+ package_name_map
+ .iter()
+ .map(|(k, v)| (k.clone(), v.as_ref().map(|c| c.clone_box())))
+ .collect();
+ let already_loaded_cloned: IndexMap<
+ String,
+ IndexMap<String, Box<dyn PackageInterface>>,
+ > = already_loaded
+ .iter()
+ .map(|(k, inner)| {
+ let inner_cloned: IndexMap<String, Box<dyn PackageInterface>> = inner
+ .iter()
+ .map(|(ik, iv)| (ik.clone(), iv.clone_package_box()))
+ .collect();
+ (k.clone(), inner_cloned)
+ })
+ .collect();
let result = repository.load_packages(
- package_name_map.clone(),
+ name_map_cloned,
acceptable_stabilities.clone(),
stability_flags.clone(),
- already_loaded.clone(),
+ already_loaded_cloned,
);
all_packages.extend(result.packages);
all_names_found.extend(result.names_found);