aboutsummaryrefslogtreecommitdiffhomepage
path: root/crates/shirabe/src/package/loader/validating_array_loader.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/package/loader/validating_array_loader.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/package/loader/validating_array_loader.rs')
-rw-r--r--crates/shirabe/src/package/loader/validating_array_loader.rs20
1 files changed, 15 insertions, 5 deletions
diff --git a/crates/shirabe/src/package/loader/validating_array_loader.rs b/crates/shirabe/src/package/loader/validating_array_loader.rs
index 5009a0d..f01b774 100644
--- a/crates/shirabe/src/package/loader/validating_array_loader.rs
+++ b/crates/shirabe/src/package/loader/validating_array_loader.rs
@@ -12,6 +12,7 @@ use shirabe_php_shim::{
strtolower, strtotime, substr, trigger_error, trim, var_export,
};
use shirabe_semver::constraint::constraint::Constraint;
+use shirabe_semver::constraint::constraint_interface::ConstraintInterface;
use shirabe_semver::constraint::match_none_constraint::MatchNoneConstraint;
use shirabe_semver::intervals::Intervals;
@@ -215,7 +216,7 @@ impl ValidatingArrayLoader {
let license_to_validate = str_replace("proprietary", "MIT", &license_str);
if !license_validator.validate(&license_to_validate) {
if license_validator
- .validate(&trim(&license_to_validate, " \t\n\r\0\u{0B}"))
+ .validate(&trim(&license_to_validate, Some(" \t\n\r\0\u{0B}")))
{
self.warnings.push(sprintf(
"License %s must not contain extra spaces, make sure to trim it.",
@@ -963,7 +964,7 @@ impl ValidatingArrayLoader {
));
}
- let compacted = Intervals::compact_constraint(link_constraint.as_ref());
+ let compacted = Intervals::compact_constraint(link_constraint.as_ref())?;
if compacted.as_any().is::<MatchNoneConstraint>() {
self.warnings.push(format!(
"{}.{} : this version constraint cannot possibly match anything ({})",
@@ -985,7 +986,16 @@ impl ValidatingArrayLoader {
.and_then(|v| v.as_array())
.cloned()
.unwrap_or_default();
- let keys = array_intersect_key(&replace_map, &conflict_map);
+ // TODO(phase-b): convert Box<PhpMixed> maps for the shim signature.
+ let replace_map_flat: IndexMap<String, PhpMixed> = replace_map
+ .iter()
+ .map(|(k, v)| (k.clone(), (**v).clone()))
+ .collect();
+ let conflict_map_flat: IndexMap<String, PhpMixed> = conflict_map
+ .iter()
+ .map(|(k, v)| (k.clone(), (**v).clone()))
+ .collect();
+ let keys = array_intersect_key(&replace_map_flat, &conflict_map_flat);
if !keys.is_empty() {
self.errors.push(format!(
"{}.{} : you cannot conflict with a package that is also replaced, as replace already creates an implicit conflict rule",
@@ -1238,7 +1248,7 @@ impl ValidatingArrayLoader {
0,
Some((target_branch_str.len() as i64) - 4),
);
- let validated_target_branch = self.version_parser.normalize_branch(&trimmed);
+ let validated_target_branch = self.version_parser.normalize_branch(&trimmed)?;
if substr(&validated_target_branch, -4, None) != "-dev" {
self.warnings.push(format!(
"extra.branch-alias.{} : the target branch ({}) must be a parseable number like 2.0-dev",
@@ -1418,7 +1428,7 @@ impl ValidatingArrayLoader {
let is_empty = !self.config.contains_key(property)
|| trim(
self.config[property].as_string().unwrap_or(""),
- " \t\n\r\0\u{0B}",
+ Some(" \t\n\r\0\u{0B}"),
) == "";
if is_empty {
if mandatory {