aboutsummaryrefslogtreecommitdiffhomepage
path: root/crates/shirabe/src/package/locker.rs
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2026-05-22 01:29:48 +0900
committernsfisis <nsfisis@gmail.com>2026-05-22 01:43:48 +0900
commit0b06f54103490e3ce5658e82bbc0119633e26cd8 (patch)
tree687b075131d3679725e77e0931ff7c503a6c3034 /crates/shirabe/src/package/locker.rs
parent2914770fba6b3cc03a68fae493f60470a41962ec (diff)
downloadphp-shirabe-0b06f54103490e3ce5658e82bbc0119633e26cd8.tar.gz
php-shirabe-0b06f54103490e3ce5658e82bbc0119633e26cd8.tar.zst
php-shirabe-0b06f54103490e3ce5658e82bbc0119633e26cd8.zip
refactor(composer): unify Composer/PartialComposer via Rc handles
Model PHP's `Composer extends PartialComposer` as a PartialOrFullComposer enum and merge partial_composer.rs into composer.rs. Introduce ComposerHandle / PartialComposerHandle (plus their Weak variants) so the graph can be shared, and build it at once with Rc::new_cyclic in the factory to resolve the back-reference cycles. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Diffstat (limited to 'crates/shirabe/src/package/locker.rs')
-rw-r--r--crates/shirabe/src/package/locker.rs9
1 files changed, 6 insertions, 3 deletions
diff --git a/crates/shirabe/src/package/locker.rs b/crates/shirabe/src/package/locker.rs
index 5dd7ab4..ecd96e3 100644
--- a/crates/shirabe/src/package/locker.rs
+++ b/crates/shirabe/src/package/locker.rs
@@ -40,7 +40,7 @@ pub struct Locker {
/// @var JsonFile
lock_file: JsonFile,
/// @var InstallationManager
- installation_manager: InstallationManager,
+ installation_manager: std::rc::Rc<std::cell::RefCell<InstallationManager>>,
/// @var string
hash: String,
/// @var string
@@ -62,7 +62,7 @@ impl Locker {
pub fn new(
io: Box<dyn IOInterface>,
lock_file: JsonFile,
- installation_manager: InstallationManager,
+ installation_manager: std::rc::Rc<std::cell::RefCell<InstallationManager>>,
composer_file_contents: &str,
process: std::rc::Rc<std::cell::RefCell<ProcessExecutor>>,
) -> Self {
@@ -824,7 +824,10 @@ impl Locker {
return Ok(None);
}
- let path = self.installation_manager.get_install_path(package);
+ let path = self
+ .installation_manager
+ .borrow_mut()
+ .get_install_path(package);
if path.is_none() {
return Ok(None);
}