aboutsummaryrefslogtreecommitdiffhomepage
path: root/crates/shirabe/src/package/loader
diff options
context:
space:
mode:
Diffstat (limited to 'crates/shirabe/src/package/loader')
-rw-r--r--crates/shirabe/src/package/loader/array_loader.rs23
-rw-r--r--crates/shirabe/src/package/loader/json_loader.rs4
-rw-r--r--crates/shirabe/src/package/loader/loader_interface.rs4
-rw-r--r--crates/shirabe/src/package/loader/root_package_loader.rs11
-rw-r--r--crates/shirabe/src/package/loader/validating_array_loader.rs2
5 files changed, 29 insertions, 15 deletions
diff --git a/crates/shirabe/src/package/loader/array_loader.rs b/crates/shirabe/src/package/loader/array_loader.rs
index 87d6e35..e1cc60b 100644
--- a/crates/shirabe/src/package/loader/array_loader.rs
+++ b/crates/shirabe/src/package/loader/array_loader.rs
@@ -12,11 +12,14 @@ use shirabe_php_shim::{
use crate::package::CompleteAliasPackage;
use crate::package::CompletePackage;
+use crate::package::CompletePackageHandle;
use crate::package::CompletePackageInterface;
use crate::package::Link;
use crate::package::PackageInterface;
+use crate::package::PackageInterfaceHandle;
use crate::package::RootAliasPackage;
use crate::package::RootPackage;
+use crate::package::RootPackageHandle;
use crate::package::loader::LoaderInterface;
use crate::package::version::VersionParser;
use crate::package::{BasePackage, SUPPORTED_LINK_TYPES};
@@ -51,7 +54,7 @@ impl LoaderInterface for ArrayLoader {
&self,
mut config: IndexMap<String, PhpMixed>,
class: Option<String>,
- ) -> Result<Box<dyn BasePackage>> {
+ ) -> Result<PackageInterfaceHandle> {
let class = class.unwrap_or_else(|| "Composer\\Package\\CompletePackage".to_string());
if class != "Composer\\Package\\CompletePackage"
@@ -104,8 +107,8 @@ impl ArrayLoader {
pub fn load_packages(
&self,
versions: Vec<IndexMap<String, PhpMixed>>,
- ) -> Result<Vec<Box<dyn BasePackage>>> {
- let mut packages: Vec<Box<dyn BasePackage>> = vec![];
+ ) -> Result<Vec<PackageInterfaceHandle>> {
+ let mut packages: Vec<PackageInterfaceHandle> = vec![];
let mut link_cache: IndexMap<
String,
IndexMap<String, IndexMap<String, IndexMap<String, (String, Link)>>>,
@@ -226,7 +229,7 @@ impl ArrayLoader {
&self,
mut package: Box<CompletePackage>,
config: &mut IndexMap<String, PhpMixed>,
- ) -> Result<Box<dyn BasePackage>> {
+ ) -> Result<PackageInterfaceHandle> {
// PHP: if (!$package instanceof CompletePackage) — true by construction in Rust
// (create_object always returns Box<CompletePackage>); kept as a no-op for parity.
let _ = LogicException {
@@ -593,12 +596,20 @@ impl ArrayLoader {
// TODO(phase-b): `$package instanceof RootPackage` downcast from CompletePackage
let package_as_root: Option<RootPackage> = None;
if let Some(root) = package_as_root {
- let _ = RootAliasPackage::new(root, alias_normalized, pretty_alias);
+ let _ = RootAliasPackage::new(
+ RootPackageHandle::from_root_package(root),
+ alias_normalized,
+ pretty_alias,
+ );
// TODO(phase-b): return Box<RootAliasPackage> wrapped as Box<BasePackage>
todo!("phase-b: return RootAliasPackage as Box<BasePackage>")
}
- let _ = CompleteAliasPackage::new(*package, alias_normalized, pretty_alias);
+ let _ = CompleteAliasPackage::new(
+ CompletePackageHandle::from_complete_package(*package),
+ alias_normalized,
+ pretty_alias,
+ );
// TODO(phase-b): return Box<CompleteAliasPackage> wrapped as Box<BasePackage>
todo!("phase-b: return CompleteAliasPackage as Box<BasePackage>")
}
diff --git a/crates/shirabe/src/package/loader/json_loader.rs b/crates/shirabe/src/package/loader/json_loader.rs
index e0589bb..5f8cc4f 100644
--- a/crates/shirabe/src/package/loader/json_loader.rs
+++ b/crates/shirabe/src/package/loader/json_loader.rs
@@ -1,7 +1,7 @@
//! ref: composer/src/Composer/Package/Loader/JsonLoader.php
use crate::json::JsonFile;
-use crate::package::BasePackage;
+use crate::package::PackageInterfaceHandle;
use crate::package::loader::LoaderInterface;
use anyhow::Result;
use std::path::Path;
@@ -20,7 +20,7 @@ impl JsonLoader {
Self { loader }
}
- pub fn load(&self, json: JsonLoaderInput) -> Result<Box<dyn BasePackage>> {
+ pub fn load(&self, json: JsonLoaderInput) -> Result<PackageInterfaceHandle> {
let config = match json {
JsonLoaderInput::File(mut json_file) => json_file.read()?,
JsonLoaderInput::String(ref s) if Path::new(s).exists() => {
diff --git a/crates/shirabe/src/package/loader/loader_interface.rs b/crates/shirabe/src/package/loader/loader_interface.rs
index d10b7be..586905f 100644
--- a/crates/shirabe/src/package/loader/loader_interface.rs
+++ b/crates/shirabe/src/package/loader/loader_interface.rs
@@ -1,6 +1,6 @@
//! ref: composer/src/Composer/Package/Loader/LoaderInterface.php
-use crate::package::BasePackage;
+use crate::package::PackageInterfaceHandle;
use indexmap::IndexMap;
use shirabe_php_shim::PhpMixed;
@@ -9,5 +9,5 @@ pub trait LoaderInterface: std::fmt::Debug {
&self,
config: IndexMap<String, PhpMixed>,
class: Option<String>,
- ) -> anyhow::Result<Box<dyn BasePackage>>;
+ ) -> anyhow::Result<PackageInterfaceHandle>;
}
diff --git a/crates/shirabe/src/package/loader/root_package_loader.rs b/crates/shirabe/src/package/loader/root_package_loader.rs
index 3cdaaa7..e235e31 100644
--- a/crates/shirabe/src/package/loader/root_package_loader.rs
+++ b/crates/shirabe/src/package/loader/root_package_loader.rs
@@ -66,7 +66,7 @@ impl RootPackageLoader {
config: IndexMap<String, Box<shirabe_php_shim::PhpMixed>>,
class: &str,
cwd: Option<&str>,
- ) -> anyhow::Result<Box<dyn PackageInterface>> {
+ ) -> anyhow::Result<crate::package::PackageInterfaceHandle> {
if class != "Composer\\Package\\RootPackage" {
shirabe_php_shim::trigger_error(
"The $class arg is deprecated, please reach out to Composer maintainers ASAP if you still need this.",
@@ -193,11 +193,14 @@ impl RootPackageLoader {
Some("Composer\\Package\\RootPackage".to_string()),
)?;
- // TODO(phase-b): as_any_mut is not available on BasePackage; downcast via Any is not
- // possible without it. Skipping real downcast and using todo!() placeholder.
+ // TODO(phase-c): mutating the loaded RootPackage through a PackageInterfaceHandle
+ // requires going through as_root_package() + a RefCell borrow; the inherent
+ // RootPackage mutators used below are not yet reachable that way.
let real_package: &mut RootPackage = {
let _ = &mut package;
- todo!("downcast Box<dyn BasePackage> to &mut RootPackage requires as_any_mut on trait")
+ todo!(
+ "mutate RootPackage through PackageInterfaceHandle (as_root_package + borrow_mut)"
+ )
};
if auto_versioned {
diff --git a/crates/shirabe/src/package/loader/validating_array_loader.rs b/crates/shirabe/src/package/loader/validating_array_loader.rs
index a2dd5a7..fbaa0f8 100644
--- a/crates/shirabe/src/package/loader/validating_array_loader.rs
+++ b/crates/shirabe/src/package/loader/validating_array_loader.rs
@@ -66,7 +66,7 @@ impl ValidatingArrayLoader {
&mut self,
config: IndexMap<String, Box<PhpMixed>>,
class: &str,
- ) -> anyhow::Result<Box<dyn BasePackage>> {
+ ) -> anyhow::Result<crate::package::PackageInterfaceHandle> {
self.errors = Vec::new();
self.warnings = Vec::new();
self.config = config.clone();