aboutsummaryrefslogtreecommitdiffhomepage
path: root/crates/shirabe/src/installer/metapackage_installer.rs
blob: 8be21e70cddc11edeedbdee17e5d91334ec1f711 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
//! ref: composer/src/Composer/Installer/MetapackageInstaller.php

use anyhow::Result;
use shirabe_php_shim::InvalidArgumentException;
use shirabe_external_packages::react::promise::promise_interface::PromiseInterface;
use crate::dependency_resolver::operation::install_operation::InstallOperation;
use crate::dependency_resolver::operation::uninstall_operation::UninstallOperation;
use crate::dependency_resolver::operation::update_operation::UpdateOperation;
use crate::installer::installer_interface::InstallerInterface;
use crate::io::io_interface::IOInterface;
use crate::package::package_interface::PackageInterface;
use crate::repository::installed_repository_interface::InstalledRepositoryInterface;

#[derive(Debug)]
pub struct MetapackageInstaller {
    io: Box<dyn IOInterface>,
}

impl MetapackageInstaller {
    pub fn new(io: Box<dyn IOInterface>) -> 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)
    }

    fn download(&self, _package: &dyn PackageInterface, _prev_package: Option<&dyn PackageInterface>) -> Result<Option<Box<dyn PromiseInterface>>> {
        Ok(Some(shirabe_external_packages::react::promise::resolve(None)))
    }

    fn prepare(&self, _type: &str, _package: &dyn PackageInterface, _prev_package: Option<&dyn PackageInterface>) -> Result<Option<Box<dyn PromiseInterface>>> {
        Ok(Some(shirabe_external_packages::react::promise::resolve(None)))
    }

    fn cleanup(&self, _type: &str, _package: &dyn PackageInterface, _prev_package: Option<&dyn PackageInterface>) -> Result<Option<Box<dyn PromiseInterface>>> {
        Ok(Some(shirabe_external_packages::react::promise::resolve(None)))
    }

    fn install(&self, repo: &mut dyn InstalledRepositoryInterface, package: &dyn PackageInterface) -> Result<Option<Box<dyn PromiseInterface>>> {
        self.io.write_error(&format!("  - {}", InstallOperation::format(package, false)), true, IOInterface::NORMAL);

        repo.add_package(package.clone_box());

        Ok(Some(shirabe_external_packages::react::promise::resolve(None)))
    }

    fn update(&self, repo: &mut dyn InstalledRepositoryInterface, initial: &dyn PackageInterface, target: &dyn PackageInterface) -> Result<Option<Box<dyn PromiseInterface>>> {
        if !repo.has_package(initial) {
            return Err(InvalidArgumentException {
                message: format!("Package is not installed: {}", initial),
                code: 0,
            }.into());
        }

        self.io.write_error(&format!("  - {}", UpdateOperation::format(initial, target, false)), true, IOInterface::NORMAL);

        repo.remove_package(initial);
        repo.add_package(target.clone_box());

        Ok(Some(shirabe_external_packages::react::promise::resolve(None)))
    }

    fn uninstall(&self, repo: &mut dyn InstalledRepositoryInterface, package: &dyn PackageInterface) -> Result<Option<Box<dyn PromiseInterface>>> {
        if !repo.has_package(package) {
            return Err(InvalidArgumentException {
                message: format!("Package is not installed: {}", package),
                code: 0,
            }.into());
        }

        self.io.write_error(&format!("  - {}", UninstallOperation::format(package, false)), true, IOInterface::NORMAL);

        repo.remove_package(package);

        Ok(Some(shirabe_external_packages::react::promise::resolve(None)))
    }

    fn get_install_path(&self, _package: &dyn PackageInterface) -> Option<String> {
        None
    }
}