aboutsummaryrefslogtreecommitdiffhomepage
path: root/crates/mozart-registry
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2026-05-03 10:54:36 +0900
committernsfisis <nsfisis@gmail.com>2026-05-03 10:54:36 +0900
commitc865a24596084eec90d10860265748c93bf7eb6a (patch)
treee22f32c6560a37ab245e3458fe3b69d89996e415 /crates/mozart-registry
parentb60cf8d9cb6776e5df85f080b5bb3fba252e154c (diff)
downloadphp-mozart-c865a24596084eec90d10860265748c93bf7eb6a.tar.gz
php-mozart-c865a24596084eec90d10860265748c93bf7eb6a.tar.zst
php-mozart-c865a24596084eec90d10860265748c93bf7eb6a.zip
fix(resolver): substitute self.version in pool link constraints
Composer's ArrayLoader and AliasPackage rewrite "self.version" to the declaring package's own version when building Link objects, so a package's replace/provide/conflict/require constraints carry a concrete "= <version>" rather than the literal string. Mozart was passing "self.version" through verbatim, which then failed to parse in Pool::matches_package and caused replace_alias.test to fail to find a provider for c/c 1.* via a/a's branch alias. Push the substitution into make_pool_links, threading the source package's normalized version through the call sites in resolver.rs (packagist/inline/composer-repo) and vcs_bridge.rs. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Diffstat (limited to 'crates/mozart-registry')
-rw-r--r--crates/mozart-registry/src/resolver.rs4
-rw-r--r--crates/mozart-registry/src/vcs_bridge.rs4
2 files changed, 8 insertions, 0 deletions
diff --git a/crates/mozart-registry/src/resolver.rs b/crates/mozart-registry/src/resolver.rs
index e8076b4..9cc0751 100644
--- a/crates/mozart-registry/src/resolver.rs
+++ b/crates/mozart-registry/src/resolver.rs
@@ -409,6 +409,7 @@ fn packagist_to_pool_inputs(
pretty_version: version_str.to_string(),
requires: make_pool_links(
package_name,
+ version_normalized,
&pv.require
.iter()
.map(|(k, v)| (k.clone(), v.clone()))
@@ -416,6 +417,7 @@ fn packagist_to_pool_inputs(
),
replaces: make_pool_links(
package_name,
+ version_normalized,
&pv.replace
.iter()
.map(|(k, v)| (k.clone(), v.clone()))
@@ -423,6 +425,7 @@ fn packagist_to_pool_inputs(
),
provides: make_pool_links(
package_name,
+ version_normalized,
&pv.provide
.iter()
.map(|(k, v)| (k.clone(), v.clone()))
@@ -430,6 +433,7 @@ fn packagist_to_pool_inputs(
),
conflicts: make_pool_links(
package_name,
+ version_normalized,
&pv.conflict
.iter()
.map(|(k, v)| (k.clone(), v.clone()))
diff --git a/crates/mozart-registry/src/vcs_bridge.rs b/crates/mozart-registry/src/vcs_bridge.rs
index 7714630..1f93a51 100644
--- a/crates/mozart-registry/src/vcs_bridge.rs
+++ b/crates/mozart-registry/src/vcs_bridge.rs
@@ -73,6 +73,7 @@ pub fn vcs_to_pool_inputs(
pretty_version: vpkg.version.clone(),
requires: make_pool_links(
&vpkg.name,
+ &vpkg.version_normalized,
&require
.iter()
.map(|(k, v)| (k.clone(), v.clone()))
@@ -80,6 +81,7 @@ pub fn vcs_to_pool_inputs(
),
replaces: make_pool_links(
&vpkg.name,
+ &vpkg.version_normalized,
&replace
.iter()
.map(|(k, v)| (k.clone(), v.clone()))
@@ -87,6 +89,7 @@ pub fn vcs_to_pool_inputs(
),
provides: make_pool_links(
&vpkg.name,
+ &vpkg.version_normalized,
&provide
.iter()
.map(|(k, v)| (k.clone(), v.clone()))
@@ -94,6 +97,7 @@ pub fn vcs_to_pool_inputs(
),
conflicts: make_pool_links(
&vpkg.name,
+ &vpkg.version_normalized,
&conflict
.iter()
.map(|(k, v)| (k.clone(), v.clone()))