//! ref: composer/src/Composer/Installer/MetapackageInstaller.php use crate::dependency_resolver::operation::InstallOperation; use crate::dependency_resolver::operation::UninstallOperation; use crate::dependency_resolver::operation::UpdateOperation; use crate::installer::InstallerInterface; use crate::io::IOInterface; use crate::io::io_interface; use crate::package::PackageInterface; use crate::repository::InstalledRepositoryInterface; use anyhow::Result; use shirabe_php_shim::{InvalidArgumentException, PhpMixed}; #[derive(Debug)] pub struct MetapackageInstaller { io: Box, } impl MetapackageInstaller { pub fn new(io: Box) -> Self { Self { io } } } impl InstallerInterface for MetapackageInstaller { fn supports(&self, package_type: &str) -> bool { package_type == "metapackage" } fn is_installed( &self, repo: &dyn InstalledRepositoryInterface, package: &dyn PackageInterface, ) -> bool { repo.has_package(package) } async fn download( &self, _package: &dyn PackageInterface, _prev_package: Option<&dyn PackageInterface>, ) -> Result> { Ok(Some(shirabe_external_packages::react::promise::resolve( None, ))) } async fn prepare( &self, _type: &str, _package: &dyn PackageInterface, _prev_package: Option<&dyn PackageInterface>, ) -> Result> { Ok(Some(shirabe_external_packages::react::promise::resolve( None, ))) } async fn cleanup( &self, _type: &str, _package: &dyn PackageInterface, _prev_package: Option<&dyn PackageInterface>, ) -> Result> { Ok(Some(shirabe_external_packages::react::promise::resolve( None, ))) } async fn install( &mut self, repo: &mut dyn InstalledRepositoryInterface, package: &dyn PackageInterface, ) -> Result> { self.io.write_error3( &format!(" - {}", InstallOperation::format(package, false)), true, io_interface::NORMAL, ); repo.add_package(package.clone_package_box()); Ok(Some(shirabe_external_packages::react::promise::resolve( None, ))) } async fn update( &mut self, repo: &mut dyn InstalledRepositoryInterface, initial: &dyn PackageInterface, target: &dyn PackageInterface, ) -> Result> { if !repo.has_package(initial) { return Err(InvalidArgumentException { message: format!("Package is not installed: {}", initial), code: 0, } .into()); } self.io.write_error3( &format!(" - {}", UpdateOperation::format(initial, target, false)), true, io_interface::NORMAL, ); repo.remove_package(initial); repo.add_package(target.clone_package_box()); Ok(Some(shirabe_external_packages::react::promise::resolve( None, ))) } async fn uninstall( &mut self, repo: &mut dyn InstalledRepositoryInterface, package: &dyn PackageInterface, ) -> Result> { if !repo.has_package(package) { return Err(InvalidArgumentException { message: format!("Package is not installed: {}", package), code: 0, } .into()); } self.io.write_error3( &format!(" - {}", UninstallOperation::format(package, false)), true, io_interface::NORMAL, ); repo.remove_package(package); Ok(Some(shirabe_external_packages::react::promise::resolve( None, ))) } fn get_install_path(&self, _package: &dyn PackageInterface) -> Option { None } }