diff options
| author | nsfisis <nsfisis@gmail.com> | 2026-05-20 08:33:49 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2026-05-20 08:33:57 +0900 |
| commit | f31b101ce1e921a026ba234b1f0a83b0392bc118 (patch) | |
| tree | b7ac2aa84d71ebd162cc21aeab0240e7e0544988 /crates/shirabe/src/repository/artifact_repository.rs | |
| parent | 5e31fa33c3b5cf726a57a063b8e7a070869250fe (diff) | |
| download | php-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/artifact_repository.rs')
| -rw-r--r-- | crates/shirabe/src/repository/artifact_repository.rs | 25 |
1 files changed, 17 insertions, 8 deletions
diff --git a/crates/shirabe/src/repository/artifact_repository.rs b/crates/shirabe/src/repository/artifact_repository.rs index afaf9cb..2ca7420 100644 --- a/crates/shirabe/src/repository/artifact_repository.rs +++ b/crates/shirabe/src/repository/artifact_repository.rs @@ -52,8 +52,8 @@ impl ArtifactRepository { let url = repo_config["url"].as_string().unwrap_or("").to_string(); let lookup = Platform::expand_path(&url); Ok(Self { - inner: ArrayRepository::new(), - loader: Box::new(ArrayLoader::new()), + inner: ArrayRepository::new(Vec::new())?, + loader: Box::new(ArrayLoader::new(None, true)), lookup, repo_config, io, @@ -65,7 +65,7 @@ impl ArtifactRepository { } fn initialize(&mut self) -> anyhow::Result<()> { - self.inner.initialize()?; + self.inner.initialize(); let lookup = self.lookup.clone(); self.scan_directory(&lookup) } @@ -177,9 +177,10 @@ impl ArtifactRepository { return Ok(None); } - let mut package = - JsonFile::parse_json(&json.unwrap(), &format!("{}#composer.json", pathname))?; - let url_normalized = pathname.replace('\\', '/'); + let json_str = json.unwrap(); + let pathname_label = format!("{}#composer.json", pathname); + let mut package = JsonFile::parse_json(Some(&json_str), Some(&pathname_label))?; + let url_normalized = pathname.replace('\\', "/"); let real_path = file .canonicalize() .ok() @@ -197,9 +198,17 @@ impl ArtifactRepository { Box::new(PhpMixed::String(url_normalized)), ); dist.insert("shasum".to_string(), Box::new(PhpMixed::String(shasum))); - package.insert("dist".to_string(), Box::new(PhpMixed::Array(dist))); + if let Some(arr) = package.as_array_mut() { + arr.insert("dist".to_string(), Box::new(PhpMixed::Array(dist))); + } - match self.loader.load(package, None) { + // TODO(phase-b): load wants IndexMap<String, PhpMixed>; convert from PhpMixed::Array. + let cfg: IndexMap<String, PhpMixed> = package + .as_array() + .cloned() + .map(|m| m.into_iter().map(|(k, v)| (k, *v)).collect()) + .unwrap_or_default(); + match self.loader.load(cfg, None) { Ok(package) => Ok(Some(package)), Err(exception) => Err(UnexpectedValueException { message: format!("Failed loading package in {}: {}", pathname, exception), |
